当前位置: 首页 > 图文教程 > 数据库 > MSSQL > SQL Server管理常用的SQL和T-SQL简介

MSSQL
SQL Server 中死锁产生的原因及解决办法
教你在SQL Server 2000数据库中使用分区
数据仓库基本报表制作过程中的SQL写法
自动定时重启sql server回收内存
轻松解决SQL Server 2005中的常见问题
用一个案例讲解SQL Server数据库恢复
安装SQL Server 2005时出现计数器错误
讲解SQL Server 2005数据库的同义词Bug
利用SQL语句对不同数据库进行高效果分页
三种数据库利用SQL语句进行高效果分页
数据库连接字符串的常见问题和解决方法
教你快速掌握一些方便易用的SQL语句
深入分析SQL Server的数据转换服务
系统默认的MySQL用户名消失的解决方法
SQL 2008邮件故障排除:发送测试电子邮件
SQL Server 2005日志文件损坏的处理方法
在SQL Server 2005数据库中进行错误捕捉
SQL Server查询速度慢原因及优化方法
加密SQL Anywhere 提升政府行业数据安全
Windows Server 2008之数据安全保护

MSSQL 中的 SQL Server管理常用的SQL和T-SQL简介


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 123 ::
收藏到网摘: n/a

1. 查看数据库的版本  
  select @@version
 
  常见的几种SQL SERVER打补丁后的版本号:
 
  8.00.194   Microsoft SQL Server 2000
  8.00.384   Microsoft SQL Server 2000 SP1
  8.00.532   Microsoft SQL Server 2000 SP2
  8.00.760   Microsoft SQL Server 2000 SP3
  8.00.818   Microsoft SQL Server 2000 SP3 w/ Cumulative Patch MS03-031
  8.00.2039 Microsoft SQL Server 2000 SP4  
 
2. 查看数据库所在机器操作系统参数  
  exec master..xp_msver
 
3. 查看数据库启动的参数      
  sp_configure
     
4. 查看数据库启动时间      
  select convert(varchar(30),login_time,120) from master..sysprocesses where spid=1
 
  查看数据库服务器名和实例名
  print 'Server Name...............: ' + convert(varchar(30),@@SERVERNAME)      
  print 'Instance..................: ' + convert(varchar(30),@@SERVICENAME)    

5. 查看所有数据库名称及大小
  sp_helpdb
 
  重命名数据库用的SQL
  sp_renamedb 'old_dbname', 'new_dbname'
 
6. 查看所有数据库用户登录信息
  sp_helplogins
 
  查看所有数据库用户所属的角色信息  
  sp_helpsrvrolemember
 
  修复迁移服务器时孤立用户时,可以用的fix_orphan_user脚本或者LoneUser过程
 
  更改某个数据对象的用户属主
  sp_changeobjectowner [@objectname =] 'object', [@newowner =] 'owner'
 
  注意: 更改对象名的任一部分都可能破坏脚本和存储过程。
 
  把一台服务器上的数据库用户登录信息备份出来可以用add_login_to_aserver脚本
 
  查看某数据库下,对象级用户权限
  sp_helprotect
 
7. 查看链接服务器      
  sp_helplinkedsrvlogin
 
  查看远端数据库用户登录信息  
  sp_helpremotelogin
 
8.查看某数据库下某个数据对象的大小
  sp_spaceused @objname
 
  还可以用sp_toptables过程看最大的N(默认为50)个表
 
  查看某数据库下某个数据对象的索引信息
  sp_helpindex @objname
 
  还可以用SP_NChelpindex过程查看更详细的索引情况
  SP_NChelpindex @objname
 
  clustered索引是把记录按物理顺序排列的,索引占的空间比较少。
  对键值DML操作十分频繁的表我建议用非clustered索引和约束,fillfactor参数都用默认值。

  查看某数据库下某个数据对象的的约束信息
  sp_helpconstraint @objname
 
9.查看数据库里所有的存储过程和函数
  use @database_name
  sp_stored_procedures

  查看存储过程和函数的源代码
  sp_helptext '@procedure_name'
 
  查看包含某个字符串@str的数据对象名称
  select distinct object_name(id) from syscomments where text like '%@str%'
 
  创建加密的存储过程或函数在AS前面加WITH ENCRYPTION参数
 
  解密加密过的存储过程和函数可以用sp_decrypt过程
 
    10.查看数据库里用户和进程的信息
  sp_who

查看SQL Server数据库里的活动用户和进程的信息
  sp_who 'active'

查看SQL Server数据库里的锁的情况
  sp_lock
 
  进程号1--50是SQL Server系统内部用的,进程号大于50的才是用户的连接进程.

  spid是进程编号,dbid是数据库编号,objid是数据对象编号

  查看进程正在执行的SQL语句
  dbcc inputbuffer ()
       
推荐大家用经过改进后的sp_who3过程可以直接看到进程运行的SQL语句
  sp_who3
 
检查死锁用sp_who_lock过程
  sp_who_lock  
   
    11.查看和收缩数据库日志文件的方法