Sql Server日常运维看我这篇就够了!

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
日志服务 SLS,月写入数据量 50GB 1个月
简介: Sql Server日常运维看我这篇就够了!


一、基础命令

查看当前数据库的版本

  1. SELECT @@VERSION;

查看服务器部分特殊信息

  1. select SERVERPROPERTY(N'edition') as Edition     --数据版本,如企业版、开发版等
  2.    ,SERVERPROPERTY(N'collation') as Collation   --数据库字符集
  3.    ,SERVERPROPERTY(N'servername') as ServerName --服务名
  4.    ,@@VERSION as Version   --数据库版本号
  5.    ,@@LANGUAGE AS Language  --数据库使用的语言,如us_english

获取数据库当前时间

  1. SELECT GETDATE() AS CurrentDateTime;

查看数据库启动的参数

  1. sp_configure

查看所有数据库用户登录信息

  1. sp_helplogins

查看数据库启动时间(最近一次)

  1. select convert(varchar(30),login_time,120) from master..sysprocesses where spid=1

查看有多少个端口

  1. SELECT * FROM sys.dm_tcp_listener_states;

查看当前的连接数

  1. SELECT COUNT(*) AS [Connection Count] FROM sys.dm_exec_connections;

查看各个磁盘分区的剩余空间

  1. Exec master.dbo.xp_fixeddrives

查看数据库的磁盘使用情况

  1. Exec sp_spaceused

查看数据库服务器各数据库日志文件的大小及利用率

  1. DBCC SQLPERF(LOGSPACE)

查看当前占用 cpu 资源最高的会话和其中执行的语句

  1. select spid,cmd,cpu,physical_io,memusage,
  2. (select top 1 [text] from ::fn_get_sql(sql_handle)) sql_text
  3. from master..sysprocesses order by cpu desc,physical_io desc

查看缓存中重用次数少,占用内存大的查询语句(当前缓存中未释放的)

  1. SELECT TOP 100 usecounts, objtype, p.size_in_bytes,[sql].[text]
  2. FROM sys.dm_exec_cached_plans p OUTER APPLY sys.dm_exec_sql_text (p.plan_handle) sql
  3. ORDER BY usecounts,p.size_in_bytes  desc

BUFFER POOL中,都缓存了哪些表(当前数据库)的数据

  1. select OBJECT_NAME(object_id) 表名,COUNT(*) 页数,COUNT(*)*8/1024.0 Mb                              
  2. from   sys.dm_os_buffer_descriptors a,sys.allocation_units b,sys.partitions c                              
  3. where  a.allocation_unit_id=b.allocation_unit_id  
  4.       and b.container_id=c.hobt_id            
  5.       and database_id=DB_ID()                              
  6. group by OBJECT_NAME(object_id)                          
  7. order by 2 desc

查看用户的权限

  1. EXEC sp_helprotect;

查看当前数据库内存使用情况

  1. select * from sys.dm_os_process_memory

查询当前数据库缓存的所有数据页面,哪些数据表,缓存的数据页面数量

  1. -- 查询当前数据库缓存的所有数据页面,哪些数据表,缓存的数据页面数量
  2. -- 从这些信息可以看出,系统经常要访问的都是哪些表,有多大?
  3. select p.object_id, object_name=object_name(p.object_id), p.index_id, buffer_pages=count(*)
  4. from sys.allocation_units a,
  5.    sys.dm_os_buffer_descriptors b,
  6.    sys.partitions p
  7. where a.allocation_unit_id=b.allocation_unit_id
  8.    and a.container_id=p.hobt_id
  9.    and b.database_id=db_id()
  10. group by p.object_id,p.index_id
  11. order by buffer_pages desc

查询缓存中具体的执行计划,及对应的SQL

  1. -- 查询缓存中具体的执行计划,及对应的SQL
  2. -- 将此结果按照数据表或SQL进行统计,可以作为基线,调整索引时考虑
  3. -- 查询结果会很大,注意将结果集输出到表或文件中
  4. SELECT  usecounts ,
  5.        refcounts ,
  6.        size_in_bytes ,
  7.        cacheobjtype ,
  8.        objtype ,
  9.        TEXT
  10. FROM    sys.dm_exec_cached_plans cp
  11.        CROSS APPLY sys.dm_exec_sql_text(plan_handle)
  12. ORDER BY objtype DESC ;
  13. GO

查看具体某个用户的权限

SELECT p.class_desc, OBJECT_NAME(p.major_id) AS object_name, p.permission_name, p.state_desc, u.name AS user_name

FROM sys.database_permissions p

JOIN sys.database_principals u ON p.grantee_principal_id = u.principal_id

WHERE u.name = ‘test’

查看注册时的实例名

  1. SELECT * FROM sys.servers;

查询用户角色

  1. select SrvRole = g.name, MemberName = u.name, MemberSID = u.sid  
  2. from sys.server_principals u, sys.server_principals g, sys.server_role_members m  
  3. where g.principal_id = m.role_principal_id  
  4. and u.principal_id = m.member_principal_id  
  5. order by 1, 2  
  6. go

看服务器角色

  1. select 用户名 = u.name,管理员权限 = g.name,是否在用 = u.is_disabled,MemberSID = u.sid  
  2. from sys.server_principals u, sys.server_principals g, sys.server_role_members m  
  3. where g.principal_id = m.role_principal_id  
  4. and u.principal_id = m.member_principal_id  
  5. and g.name = 'sysadmin'
  6. order by 1, 2
  7. go

查询当前用户所有用户表

  1. select name from sysobjects where xtype='u' order by name

查看所有的数据库

  1. Select Name FROM Master..SysDatabases orDER BY Name

查看服务器角色相关信息

  1. SP_HELPSRVROLE
  2. SP_HELPSRVROLEMEMBER 服务器角色
  3. SP_HELPSRVROLE 服务器角色

查看数据库角色相关信息

  1. SP_HELPROLE
  2. SP_HELPROLEMEMBER 数据库角色
  3. SP_HELPROLE 数据库角色

查看用户相关信息

  1. SP_HELPUSER
  2. SP_HELPUSER 数据库用户名

查看上次启动以来尝试的连接数

  1. select @@connections //返回 SQL Server 自上次启动以来尝试的连接数,无论连接是成功还是失败

当前实例允许同时进行的最大用户连接数

  1. select @@max_connections
  2. //返回 SQL Server 实例允许同时进行的最大用户连接数。返回的数值不一定是当前配置的数值

查询当前最大的连接数

  1. SELECT value_in_use
  2. FROM sys.configurations c
  3. WHERE c.name = 'user connections'; #0表示无限制

设置修改连接数

  1. exec sp_configure 'show advanced options', 1
  2. RECONFIGURE WITH OVERRIDE
  3. exec sp_configure 'user connections', 300
  4. RECONFIGURE WITH OVERRIDE

查询当前会话超时时间

  1. select @@lock_timeout //返回当前会话的当前锁定超时设置(毫秒)。

查询每个用户的连接数

  1. select loginame,count(1) as Nums
  2. from sys.sysprocesses
  3. group by loginame
  4. order by 2 desc
  5. select spid,ecid,status,loginame,hostname,cmd,request_id
  6. from sys.sysprocesses where loginame='' and hostname=''

查看当前活动的实例

  1. SELECT CURRENT_USER AS [Current User], SESSION_USER AS [Session User];

查看当前活动进程

  1. SELECT * FROM sys.dm_exec_requests;

查看所有数据库的大小

  1. SELECT
  2.    DB_NAME(database_id) AS DatabaseName,
  3.    SUM(size/128.0) AS SizeInMB,
  4.    SUM(size/128.0)/1024 AS SizeInGB
  5. FROM
  6.    sys.master_files
  7. GROUP BY
  8.    database_id
  9. ORDER BY
  10.    SizeInMB DESC;

查看某个数据库的大小

  1. SELECT sys.databases.name AS [Database Name],
  2.    CAST(SUM(size * 8 / 1024.0) AS DECIMAL(10,2)) AS [Size (MB)]
  3. FROM sys.master_files
  4. INNER JOIN sys.databases ON sys.master_files.database_id = sys.databases.database_id
  5. WHERE sys.databases.name = 'master'
  6. GROUP BY sys.databases.name;
  7. #也可以用EXEC sp_spaceused @updateusage = N'TRUE';

查看当前数据库的日志大小

  1. SELECT sys.databases.name AS [Database Name],
  2.    CAST(size * 8 / 1024.0 AS DECIMAL(10,2)) AS [Log File Size (MB)]
  3. FROM sys.master_files
  4. INNER JOIN sys.databases ON sys.master_files.database_id = sys.databases.database_id
  5. WHERE sys.databases.name = 'master'
  6.    AND sys.master_files.type = 1;

查询当前数据库的表和视图

  1. SELECT TABLE_NAME AS [Table/View Name], TABLE_TYPE AS [Type]
  2. FROM INFORMATION_SCHEMA.TABLES
  3. WHERE TABLE_TYPE IN ('BASE TABLE', 'VIEW');

查询表结构信息

  1. sp_help 'test';

二、运维小技巧

一次性清除数据库所有表的数据(高危操作,谨慎)

  1. CREATE PROCEDURE sp_DeleteAllData  
  2. AS  
  3. EXEC sp_MSForEachTable 'ALTER TABLE ? NOCHECK CONSTRAINT ALL'  
  4. EXEC sp_MSForEachTable 'ALTER TABLE ? DISABLE TRIGGER ALL'  
  5. EXEC sp_MSForEachTable 'DELETE FROM ?'  
  6. EXEC sp_MSForEachTable 'ALTER TABLE ? CHECK CONSTRAINT ALL'  
  7. EXEC sp_MSForEachTable 'ALTER TABLE ? ENABLE TRIGGER ALL'  
  8. EXEC sp_MSFOREACHTABLE 'SELECT * FROM ?'  
  9. GO

数据备份与恢复

备份

  1. BACKUP DATABASE test TO DISK = 'C:\backup\MyDatabase.bak';

恢复

  1. RESTORE DATABASE MyDatabase FROM DISK = 'C:\backup\MyDatabase.bak';

完整数据库备份

  1. BACKUP DATABASE test
  2. TO DISK = 'C:\Backup\MyDatabase.bak'
  3. WITH FORMAT, MEDIANAME = 'MyDatabase_Full', NAME = 'Full Backup';

差异备份

  1. BACKUP DATABASE test
  2. TO DISK = 'C:\Backup\MyDatabase_diff.bak'
  3. WITH DIFFERENTIAL, FORMAT, MEDIANAME = 'MyDatabase_Diff', NAME = 'Differential Backup';

事务日志备份

  1. BACKUP LOG test
  2. TO DISK = 'C:\Backup\MyDatabase_log.trn'
  3. WITH NOFORMAT, NOINIT, NAME = N'MyDatabase_LogBackup', SKIP, NOREWIND, NOUNLOAD, STATS = 10;

还原数据库

  1. RESTORE DATABASE test
  2. FROM DISK = 'C:\Backup\MyDatabase.bak'
  3. WITH FILE = 1, NOUNLOAD, REPLACE, STATS = 5;

创建账户及数据库用户

  1. #创建账户
  2. CREATE LOGIN test WITH PASSWORD = '123123';
  3. #创建数据库用户并映射到登录名
  4. CREATE USER test FOR LOGIN test;
  5. ALTER ROLE db_datareader ADD MEMBER test; -- 给予读权限
  6. ALTER ROLE db_datawriter ADD MEMBER test; -- 给予写权限

SQL优化相关、执行时间

  1. SELECT creation_time  N'语句编译时间'  
  2.        ,last_execution_time  N'上次执行时间'  
  3.        ,total_physical_reads N'物理读取总次数'  
  4.        ,total_logical_reads/execution_count N'每次逻辑读次数'  
  5.        ,total_logical_reads  N'逻辑读取总次数'  
  6.        ,total_logical_writes N'逻辑写入总次数'  
  7.        ,execution_count  N'执行次数'  
  8.        ,total_worker_time/1000 N'所用的CPU总时间ms'  
  9.        ,total_elapsed_time/1000  N'总花费时间ms'  
  10.        ,(total_elapsed_time / execution_count)/1000  N'平均时间ms'  
  11.        ,SUBSTRING(st.text, (qs.statement_start_offset/2) + 1,  
  12.         ((CASE statement_end_offset  
  13.          WHEN -1 THEN DATALENGTH(st.text)  
  14.          ELSE qs.statement_end_offset END  
  15.            - qs.statement_start_offset)/2) + 1) N'执行语句'  
  16. FROM sys.dm_exec_query_stats AS qs  
  17. CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) st  
  18. WHERE SUBSTRING(st.text, (qs.statement_start_offset/2) + 1,  
  19.         ((CASE statement_end_offset  
  20.          WHEN -1 THEN DATALENGTH(st.text)  
  21.          ELSE qs.statement_end_offset END  
  22.            - qs.statement_start_offset)/2) + 1) NOT LIKE '%fetch%'  
  23. ORDER BY  total_elapsed_time / execution_count DESC;

查看job运行持续时间

  1. SELECT
  2.     [T1].[job_id]
  3.    ,[T1].[name] AS [job_name]
  4.    ,[T2].[run_status]
  5.    ,[T2].[run_date]
  6.    ,[T2].[run_time]
  7.    ,[dbo].[agent_datetime]([T2].[run_date], [T2].[run_time]) AS [run_datetime]
  8.    ,[T2].[run_duration]
  9.    ,DATEDIFF(SECOND, '1900-01-01', DATEADD(SECOND, 31, [dbo].[agent_datetime](19000101, [run_duration]))) AS [run_duration_s]
  10. FROM
  11.    [dbo].[sysjobs] AS T1
  12.    INNER JOIN [dbo].[sysjobhistory] AS T2
  13.        ON [T2].[job_id] = [T1].[job_id]
  14. WHERE
  15.    [T1].[enabled] = 1
  16.    AND [T2].[step_id] = 0
  17.    AND [T2].[run_duration] >= 1
  18.    and [T1].[name]='PIMS_CreatePaperCraftParameterAnalysisData'
  19. ORDER BY
  20.     [T2].[job_id] ASC
  21.    ,[T2].[run_date] ASC
  22. GO

从所有缓存中释放所有未使用的缓存条目

  1. DBCC FREESYSTEMCACHE('ALL');

查询、解除死锁

  1. --查询表死锁信息
  2. select object_name(resource_associated_entity_id) as tableName, request_session_id as pid from sys.dm_tran_locks
  3. where resource_type = 'OBJECT'

  4. dbcc opentran

  5. --查看死锁的详细信息、执行的sql语句
  6. exec sp_who2 53
  7. --exec sp_who 53
  8. DBCC inputbuffer (53)

  9. --解除死锁
  10. kill 53

查询SQL Server根据CPU消耗列出前5个最差性能的查询

  1. -- Worst performing CPU bound queries
  2. SELECT TOP 5
  3.    st.text,
  4.    qp.query_plan,
  5.    qs.*
  6. FROM sys.dm_exec_query_stats qs
  7. CROSS APPLY sys.dm_exec_sql_text(qs.plan_handle) st
  8. CROSS APPLY sys.dm_exec_query_plan(qs.plan_handle) qp
  9. ORDER BY total_worker_time DESC
  10. GO

查询数据库中各数据表大小

  1. -- =============================================
  2. --  述:更新查询数据库中各表的大小,结果存储到数据表中
  3. -- =============================================

  4.    --查询是否存在结果存储表
  5.    IF NOT EXISTS (SELECT * FROM sysobjects where id = OBJECT_ID(N'temp_tableSpaceInfo') AND OBJECTPROPERTY(id, N'IsUserTable') = 1)
  6.    BEGIN
  7.        --不存在则创建
  8.        CREATE TABLE temp_tableSpaceInfo
  9.        (name NVARCHAR(128),
  10.        rows char(11),
  11.        reserved VARCHAR(18),
  12.        data VARCHAR(18),
  13.        index_size VARCHAR(18),
  14.        unused VARCHAR(18))
  15.    END
  16.    --清空数据表
  17.    DELETE FROM temp_tableSpaceInfo

  18.    --定义临时变量在遍历时存储表名称
  19.    DECLARE @tablename VARCHAR(255)

  20.    --使用游标读取数据库内所有表表名
  21.    DECLARE table_list_cursor CURSOR FOR
  22.    SELECT name FROM sysobjects
  23.    WHERE OBJECTPROPERTY(id, N'IsTable') = 1 AND name NOT LIKE N'#%%' ORDER BY name

  24.    --打开游标
  25.    OPEN table_list_cursor
  26.    --读取第一条数据
  27.    FETCH NEXT FROM table_list_cursor INTO @tablename

  28.    --遍历查询到的表名
  29.    WHILE @@FETCH_STATUS = 0
  30.    BEGIN
  31.        --检查当前表是否为用户表
  32.        IF EXISTS (SELECT * FROM sysobjects WHERE id = OBJECT_ID(@tablename) AND OBJECTPROPERTY(id, N'IsUserTable') = 1)
  33.        BEGIN
  34.            --当前表则读取其信息插入到表格中
  35.            EXECUTE sp_executesql N'INSERT INTO temp_tableSpaceInfo EXEC sp_spaceused @tbname', N'@tbname varchar(255)', @tbname = @tablename
  36.        END
  37.        --读取下一条数据
  38.        FETCH NEXT FROM table_list_cursor INTO @tablename
  39.    END

  40.    --释放游标
  41.    CLOSE table_list_cursor
  42.    DEALLOCATE table_list_cursor

  43.    SELECT *,replace(reserved,'KB','')/1024 数据表大小M FROM temp_tableSpaceInfo order by replace(reserved,'KB','')/1024 desc
  44.    drop table temp_tableSpaceInfo

显示如何依据I/O消耗来找出你性能最差的查询

  1. -- Worst performing I/O bound queries
  2. SELECT TOP 5
  3.    st.text,
  4.    qp.query_plan,
  5.    qs.*
  6. FROM sys.dm_exec_query_stats qs
  7. CROSS APPLY sys.dm_exec_sql_text(qs.plan_handle) st
  8. CROSS APPLY sys.dm_exec_query_plan(qs.plan_handle) qp
  9. ORDER BY total_logical_reads DESC
  10. GO

压缩数据库、文件、日志

  1. DBCC ShrinkFile(‘数据库名’,  targetsize);            /* 收缩数据库文件 */
  2. DBCC ShrinkFile(‘数据库名_log’,  targetsize);        /* 收缩日志文件 */
  3. Targetsize:单位为兆,必须为整数,DBCC SHRINKFILE 尝试将文件收缩到指定大小。

  4. DBCC SHRINKFILE 不会将文件收缩到小于“实际使用的空间”大小,例如“分配空间”为10M,“实际使用空间”为6M,当制定targetsize1时,则将该文件收缩到6M,不会将文件收缩到1M

  5. --收缩数据库
  6. DBCC SHRINKDATABASE(数据库名,百分比)
  7. 百分比:即“收缩后文件中的最大可用空间”,取值范围“大于等于0 小于100%”,实际使用中设为0即可。

查询数据库表字段各项属性信息,便于直接复制导出excel表

  1. SELECT  
  2.     表名       = Case When A.colorder=1 Then D.name Else '' End,  
  3.     表说明     = Case When A.colorder=1 Then isnull(F.value,'') Else '' End,  
  4.     字段序号   = A.colorder,  
  5.     字段名     = A.name,  
  6.     字段说明   = isnull(G.[value],''),  
  7.     标识       = Case When COLUMNPROPERTY( A.id,A.name,'IsIdentity')=1 Then '√'Else '' End,  
  8.     主键       = Case When exists(SELECT 1 FROM sysobjects Where xtype='PK' and parent_obj=A.id and name in (  
  9.                      SELECT name FROM sysindexes WHERE indid in( SELECT indid FROM sysindexkeys WHERE id = A.id AND colid=A.colid))) then '√' else '' end,  
  10.     类型       = B.name,  
  11.     占用字节数 = A.Length,  
  12.     长度       = COLUMNPROPERTY(A.id,A.name,'PRECISION'),  
  13.     小数位数   = isnull(COLUMNPROPERTY(A.id,A.name,'Scale'),0),  
  14.     允许空     = Case When A.isnullable=1 Then '√'Else '' End,  
  15.     默认值     = isnull(E.Text,'')  
  16. FROM  
  17.     syscolumns A  
  18. Left Join  
  19.     systypes B  
  20. On  
  21.     A.xusertype=B.xusertype  
  22. Inner Join  
  23.     sysobjects D  
  24. On  
  25.     A.id=D.id  and D.xtype='U' and  D.name<>'dtproperties'  
  26. Left Join  
  27.     syscomments E  
  28. on  
  29.     A.cdefault=E.id  
  30. Left Join  
  31. sys.extended_properties  G  
  32. on  
  33.     A.id=G.major_id and A.colid=G.minor_id  
  34. Left Join  

  35. sys.extended_properties F  
  36. On  
  37.     D.id=F.major_id and F.minor_id=0  
  38.     --where d.name='OrderInfo'    --如果只查询指定表,加上此条件  
  39. Order By  
  40.     A.id,A.colorder

数据库缓存清理

  1. CREATE PROCEDURE [dbo].ClearMemory  
  2. AS  
  3. BEGIN
  4.    --清除所有缓存
  5.    DBCC DROPCLEANBUFFERS
  6.    --打开高级配置
  7.    exec sp_configure 'show advanced options', 1
  8.    --设置最大内存值,清除现有缓存空间
  9.    exec sp_configure 'max server memory', 25600
  10.    EXEC ('RECONFIGURE')
  11.    --设置等待时间
  12.    WAITFOR DELAY '00:00:01'
  13.    --重新设置最大内存值
  14.    EXEC  sp_configure 'max server memory',40960
  15.    EXEC ('RECONFIGURE')
  16.    --关闭高级配置
  17.    exec sp_configure 'show advanced options',0
  18. END
  19. GO

三、日常运维操作

数据库用户、权限操作

  1. USE [master]
  2. GO
  3. --待确认账号密码
  4. CREATE LOGIN [NDIT] WITH PASSWORD=N'1', DEFAULT_DATABASE=[PIMS], CHECK_EXPIRATION=OFF, CHECK_POLICY=OFF
  5. GO
  6. USE PIMS
  7. go
  8. CREATE USER [NDIT] FOR LOGIN [NDIT]
  9. GO
  10. --大权限, 如果是指定的部分表,不执行这个,如果是所有内容都可以读,用此脚本
  11. --EXEC sp_addrolemember N'db_datareader', N'NDIT'
  12. --GO
  13. --指定特定表名赋予新增/更新/查询
  14. DECLARE @Sql NVARCHAR(max)
  15. SET @Sql=''
  16. --table
  17. --SELECT @Sql=@Sql+'GRANT INSERT,UPDATE,SELECT ON ['+a.name+'] TO [NDIT];' FROM sys.tables AS a WHERE name IN ('Tab1','Tab2');
  18. --view
  19. --SELECT @Sql=@Sql+'GRANT INSERT,UPDATE,SELECT ON ['+a.name+'] TO [NDIT];' FROM sys.views AS a WHERE name IN ('view1','view2');
  20. --procedure
  21. --SELECT @Sql=@Sql+'GRANT INSERT,UPDATE,SELECT ON ['+a.name+'] TO [NDIT];' FROM sys.procedures AS a WHERE name IN ('proc1','proc2');

  22. PRINT @Sql

  23. EXEC(@Sql)
  24. go

  25. --禁用登陆帐户
  26. alter login NDIT disable
  27. --启用登陆帐户
  28. alter login NDIT enable

  29. --登陆帐户改名
  30. alter login NDIT with name=dba_tom

  31. --登陆帐户改密码:
  32. alter login NDIT with password='aabb@ccdd'

  33. --数据库用户改名:
  34. alter user NDIT with name=dba_tom

  35. --更改数据库用户 defult_schema
  36. alter user NDIT with default_schema=sales

  37. --删除数据库用户:
  38. drop user NDIT

  39. --删除 SQL Server登陆帐户:
  40. drop login NDIT


文中的概念来源于网络,如有侵权,请联系我删除。

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
SQL 运维 监控
Clickhouse运维之你最需要知道的SQL总结
Clickhouse运维之你最需要知道的SQL总结
Clickhouse运维之你最需要知道的SQL总结
|
3月前
|
SQL 运维 监控
SQL Server 运维常用sql语句(二)
SQL Server 运维常用sql语句(二)
31 3
|
3月前
|
SQL XML 运维
SQL Server 运维常用sql语句(三)
SQL Server 运维常用sql语句(三)
20 1
|
6月前
|
SQL 运维 Linux
SQL基础(1),从三流Linux运维外包到秒杀阿里P7,
SQL基础(1),从三流Linux运维外包到秒杀阿里P7,
|
SQL 人工智能 运维
运维面试,遇到的SQL笔试题
运维面试,遇到的SQL笔试题
172 2
|
SQL 运维 数据库
SQL Server DBA日常运维语句(上)
今天我们介绍一下,日常工作中的一些运维语句,可以当作工具直接来使用。
|
SQL 存储 Linux
【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作
SQLServer 虽然是微软开发的,但是目前已经支持 Windows、Linux、MACOS等。本文详细介绍在 Linux 环境下,如何对 SQL Server 进行安装、升级、回滚、卸载等操作。
541 0
【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作
|
SQL 运维 Oracle
【大数据开发运维解决方案】Oracle Sql基础查询
空字符串在oracle中常常相当于null,为什么不说空字符串等价于null呢,看案例: 可以看到,本身deptno是number类型的,而‘’字符串本身是varchar类型,这与null可以是任何类型不同,所以也就不等价。
【大数据开发运维解决方案】Oracle Sql基础查询
|
SQL 运维 监控
《阿里云认证的解析与实战-数据仓库ACP认证》——云原生数据仓库AnalyticDB PostgreSQL版功能演示(上)——七、常用运维SQL
《阿里云认证的解析与实战-数据仓库ACP认证》——云原生数据仓库AnalyticDB PostgreSQL版功能演示(上)——七、常用运维SQL
|
SQL 运维 监控
集群运维2:监控、SQL限流与索引优化 | 学习笔记(2)
快速学习集群运维2:监控、SQL限流与索引优化
集群运维2:监控、SQL限流与索引优化 | 学习笔记(2)