Bootstrap

SQL语句新建用户、对用户授权、删除用户实例

USE mydb

GO

--1. 新建测试用户

--1.1 添加登录用户和密码  

EXEC sp_addlogin N'tony','123'

--1.2 使其成为当前数据库的合法用户   

EXEC sp_grantdbaccess N'tony'  

 

--2.设置操作授权

--2.1 授予对自己数据库的所有权限     

EXEC sp_addrolemember N'db_owner', N'tony'

 

--2.2 以下是设置具体操作权限

--授予tony对所有用户表的操作权限

GRANT SELECT,INSERT,UPDATE,DELETE TO tony 

--授予tony SELECT,UPDATE到具体的表  

GRANT SELECT,UPDATE ON tb TO tony  

--授予tony SELECT,UPDATE到具体的表和列    

GRANT SELECT,UPDATE ON tb(id,col) TO tony  

--禁止tony对所有用户表的操作权限

DENY SELECT,INSERT,UPDATE,DELETE TO tony 

--禁止tony SELECT,UPDATE到具体的表

DENY SELECT,UPDATE ON tb TO tony  

--禁止tony SELECT,UPDATE到具体的表和列 

DENY SELECT,UPDATE ON tb(id,col) TO tony  

--删除tony 对所有用户表的授权信息

REVOKE SELECT,INSERT,UPDATE,DELETE TO tony

 

--授予tony对具有创建表、视图、存储过程等的操作权限

GRANT CREATE TABLE,CREATE VIEW,CREATE PROC TO tony 

--禁止tony对具有创建表、视图、存储过程等的操作权限

DENY CREATE TABLE,CREATE VIEW,CREATE PROC TO tony 

--删除tony对具有创建表、视图、存储过程等的授权信息

REVOKE CREATE TABLE,CREATE VIEW,CREATE PROC TO tony 

 

GO

--注:更多相关授权信息参考后面的附表中“数据库权限”列。

 

--3. 删除测试用户

EXEC sp_revokedbaccess N'tony'   --移除用户对数据库的访问权限

EXEC sp_droplogin N'tony'        --删除登录用户

GO

 

---------------

 

附表: 

数据库权限数据库权限隐含的权限服务器权限隐含的权限

ALTER

CONTROL

ALTER ANY DATABASE

ALTER ANY APPLICATION ROLE

ALTER

CONTROL SERVER

ALTER ANY ASSEMBLY

ALTER

CONTROL SERVER

ALTER ANY ASYMMETRIC KEY

ALTER

CONTROL SERVER

ALTER ANY CERTIFICATE

ALTER

CONTROL SERVER

ALTER ANY CONTRACT

ALTER

CONTROL SERVER

ALTER ANY DATABASE DDL TRIGGER

ALTER

CONTROL SERVER

ALTER ANY DATABASE EVENT NOTIFICATION

ALTER

ALTER ANY EVENT NOTIFICATION

ALTER ANY DATASPACE

ALTER

CONTROL SERVER

ALTER ANY FULLTEXT CATALOG

ALTER

CONTROL SERVER

ALTER ANY MESSAGE TYPE

ALTER

CONTROL SERVER

ALTER ANY REMOTE SERVICE BINDING

ALTER

CONTROL SERVER

ALTER ANY ROLE

ALTER

CONTROL SERVER

ALTER ANY ROUTE

ALTER

CONTROL SERVER

ALTER ANY SCHEMA

ALTER

CONTROL SERVER

ALTER ANY SERVICE

ALTER

CONTROL SERVER

ALTER ANY SYMMETRIC KEY

ALTER

CONTROL SERVER

ALTER ANY USER

ALTER

CONTROL SERVER

AUTHENTICATE

CONTROL

AUTHENTICATE SERVER

BACKUP DATABASE

CONTROL

CONTROL SERVER

BACKUP LOG

CONTROL

CONTROL SERVER

CHECKPOINT

CONTROL

CONTROL SERVER

CONNECT

CONNECT REPLICATION

CONTROL SERVER

CONNECT REPLICATION

CONTROL

CONTROL SERVER

CONTROL

CONTROL

CONTROL SERVER

CREATE AGGREGATE

ALTER

CONTROL SERVER

CREATE ASSEMBLY

ALTER ANY ASSEMBLY

CONTROL SERVER

CREATE ASYMMETRIC KEY

ALTER ANY ASYMMETRIC KEY

CONTROL SERVER

CREATE CERTIFICATE

ALTER ANY CERTIFICATE

CONTROL SERVER

CREATE CONTRACT

ALTER ANY CONTRACT

CONTROL SERVER

CREATE DATABASE

CONTROL

CREATE ANY DATABASE

CREATE DATABASE DDL EVENT NOTIFICATION

ALTER ANY DATABASE EVENT NOTIFICATION

CREATE DDL EVENT NOTIFICATION

CREATE DEFAULT

ALTER

CONTROL SERVER

CREATE FULLTEXT CATALOG

ALTER ANY FULLTEXT CATALOG

CONTROL SERVER

CREATE FUNCTION

ALTER

CONTROL SERVER

CREATE MESSAGE TYPE

ALTER ANY MESSAGE TYPE

CONTROL SERVER

CREATE PROCEDURE

ALTER

CONTROL SERVER

CREATE QUEUE

ALTER

CONTROL SERVER

CREATE REMOTE SERVICE BINDING

ALTER ANY REMOTE SERVICE BINDING

CONTROL SERVER

CREATE ROLE

ALTER ANY ROLE

CONTROL SERVER

CREATE ROUTE

ALTER ANY ROUTE

CONTROL SERVER

CREATE RULE

ALTER

CONTROL SERVER

CREATE SCHEMA

ALTER ANY SCHEMA

CONTROL SERVER

CREATE SERVICE

ALTER ANY SERVICE

CONTROL SERVER

CREATE SYMMETRIC KEY

ALTER ANY SYMMETRIC KEY

CONTROL SERVER

CREATE SYNONYM

ALTER

CONTROL SERVER

CREATE TABLE

ALTER

CONTROL SERVER

CREATE TYPE

ALTER

CONTROL SERVER

CREATE VIEW

ALTER

CONTROL SERVER

CREATE XML SCHEMA COLLECTION

ALTER

CONTROL SERVER

DELETE

CONTROL

CONTROL SERVER

EXECUTE

CONTROL

CONTROL SERVER

INSERT

CONTROL

CONTROL SERVER

REFERENCES

CONTROL

CONTROL SERVER

SELECT

CONTROL

CONTROL SERVER

SHOWPLAN

CONTROL

ALTER TRACE

SUBSCRIBE QUERY NOTIFICATIONS

CONTROL

CONTROL SERVER

TAKE OWNERSHIP

CONTROL

CONTROL SERVER

UPDATE

CONTROL

CONTROL SERVER

VIEW DATABASE STATE

CONTROL

VIEW SERVER STATE

VIEW DEFINITION

CONTROL

VIEW ANY DEFINITION


一个老外的sql教程
http://beginner-sql-tutorial.com/sql-commands.htm

微软的ms server msdn
http://msdn.microsoft.com/zh-cn/library/bb510741.aspx

DBCC SQL  Server 提供的一组控制台命令,如何用:
DBCC HELP('?')

DBCCSQL Server提供的一组控制台命令,功能很强大,掌握一些必要的语句,对操作数据库有不少帮助,所以决定整理一下,发现已有不少类似的整理,减少了不少工作,归类如下:

 

 

DBCC 帮助类命令

 

* DBCC HELP('?')

查询所有的DBCC命令

* DBCC HELP('checktable')

查询指定的DBCC命令的语法说明

* DBCC USEROPTIONS

返回当前连接的活动(设置)SET选项

 

DBCC 检查验证类命令

 

* DBCC CHECKALLOG ('数据库名称')

检查指定数据库的磁盘空间分配结构的一致性

* DBCC CHECKCATALOG ('数据库名称')

检查指定数据库的系统表内和系统表间的一致性

* DBCC CHECKCONSTAINTS ('tablename')

检查指定表上的指定约束或所有约束的完整性

* DBCC CHECKDB

检查数据库中的所有对象的分配和结构完整性

* DBCC CHECKFILEGROUP

检查指定文件组中所有表在当前数据库中的分配和结构完整性

* DBCC CHECKTABLE

检查指定表或索引视图的数据索引及testntestimage页的完整性

* DBCC CHECKIDENT

检查指定的当前标识值

* DBCC SQLPERF(UMSSTATS) undocumented in BOL

可以用来检查是否CPU使用达到瓶颈

最关键的一个参考数据num runnable,表明当前有多少个线程再等待运行

如果大于等于,考虑CPU达到瓶颈

 

DBCC 维护类命令

 

* DBCC CLEANTABLE ('db_name','table_name')

回收Alter table drop column语句删除可变长度列或text

* DBCC DBREINDEX

重建指定数据库的一个或多个索引

* DBCC INDEXDEFRAG

对表或视图上的索引和非聚集索引进行碎片整理

* DBCC PINTABLE (db_id,object_id)

将表数据驻留在内存中

查看哪些表驻留在内存的方法是:

select objectproperty(object_id('tablename'),'tableispinned')

* DBCC UNPINTABLE (db_id,object_id)

撤消驻留在内存中的表

* DBCC SHRINKDATABASE(db_id,int)

收缩指定数据库的数据文件和日志文件大小

* DBCC SHRINKFILE(file_name,int)

收缩相关数据库的指定数据文件和日志文件大小

 

DBCC 性能调节命令

 

* DBCC dllname(FREE)

sp_helpextendedproc 查看加载的扩展PROC

在内存中卸载指定的扩展过程动态链接库(dll)

* DBCC DROPCLEANBUFFERS

从缓冲池中删除所有缓冲区

* DBCC FREEPROCCACHE

从过程缓冲区删除所有元素

* DBCC INPUTBUFFER

显示从客户机发送到服务器的最后一个语句

* DBCC OPENTRAN (db_name)

查询某个数据库执行时间最久的事务,由哪个程序拥有

* DBCC SHOW_STATISTICS

显示指定表上的指定目标的当前分布统计信息

* DBCC SHOWCONTIG

显示指定表的数据和索引的碎片信息

* DBCC SQLPERF

(logspace) 查看各个DB的日志情况

(iostats) 查看IO情况

(threads) 查看线程消耗情况

返回多种有用的统计信息

* DBCC CACHESTATS

显示SQL Server 2000内存的统计信息

* DBCC CURSORSTATS

显示SQL Server 2000游标的统计信息

* DBCC MEMORYSTATS

显示SQL Server 2000内存是如何细分的

* DBCC SQLMGRSTATS

显示缓冲中先读和预读准备的SQL语句

 

DBCC 未公开的命令

 

* DBCC ERRLOG

初始化SQL Server 2000的错误日志文件

* DBCC FLUSHPROCINDB (db_id)

清除SQL Server 2000服务器内存中的某个数据库的存储过程缓存内容

* DBCC BUFFER (db_name,object_name,int(缓冲区个数))

显示缓冲区的头部信息和页面信息

* DBCC DBINFO (db_name)

显示数据库的结构信息

* DBCC DBTABLE

显示管理数据的表(数据字典)信息

* DBCC IND (db_name,table_name,index_id)

查看某个索引使用的页面信息

* DBCC REBUILDLOG

重建SQL Server 2000事务日志文件

* DBCC LOG (db_name,3) (-1--4)

查看某个数据库使用的事物日志信息

* DBCC PAGE

查看某个数据库数据页面信息

* DBCC PROCBUF

显示过程缓冲池中的缓冲区头和存储过程头

* DBCC PRTIPAGE

查看某个索引页面的每行指向的页面号

* DBCC PSS (user,spid,1)

显示当前连接到SQL Server 2000服务器的进程信息

* DBCC RESOURCE

显示服务器当前使用的资源情况

* DBCC TAB (db_id,object_id)

显示数据页面的结构

 

DBCC跟踪标记

 

跟踪标记用于临时设置服务器的特定特征或关闭特定行为,常用于诊断性能问题或调试存储过程或复杂的计算机系统

* DBCC TRACEON (3604)

打开跟踪标记

* DBCC TRACEOFF

关闭跟踪标记

* DBCC TRACESTATS

查看跟踪标记状态

 

使用 DBCC 结果集输出

 

  许多 DBCC 命令可以产生表格格式的输出(使用 WITH TABLERESULTS 选项)该信息可装载到表中以便将来使用以下显示一个示例脚本:

  CREATE TABLE DBCCResult (

  DBCCFlag INT,

  Result INT

  )

  INSERT INTO DBCCResult

  EXEC ('DBCC TRACESTATUS (-1) WITH NO_INFOMSGS')

  SELECT *

  FROM DBCCResult

官方使用DBCC的建议

1在系统使用率较低时运行 CHECKDB

2请确保未同时执行其它磁盘 I/O 操作,例如磁盘备份

3 tempdb 放到单独的磁盘系统或快速磁盘子系统中

4允许 tempdb 在驱动器上有足够的扩展空间使用带有 ESTIMATE ONLY  DBCC

估计 tempdb 将需要多少空间

5避免运行占用大量 CPU 的查询或批处理作业

6 DBCC 命令运行时,减少活动事务

7使用 NO_INFOMSGS 选项显著减少处理和 tempdb 的使用

8考虑使用带有 PHYSICAL_ONLY 选项的 DBCC CHECKDB 来检查页和记录首部

的物理结构当硬件导致的错误被置疑时,这个操作将执行快速检查

 

在发布,订阅复制时要用服务器实名时可以这样:

select * from sysservers   (可以找到原来服务器的名称)

exec sp_dropserver 'jmsql9'    (删除原来的服务器名)

exec sp_addserver 'jmSQL9' ,LOCAL    (改为新的服务器名)

ALTER DATABASE [jm] SET SINGLE_USER          (改为单用户模式)

DBCC CHECKDB("databasename",REPAIR_REBUILD) WITH TABLOCK    (修复数据库) 

DBCC  CHECKTABLE("tablename",repair_rebuild) with tablock  (修复表)

DBCC DBREINDEX ('t_icitem'  ,  '   ')       修复此表所有的索引

ALTER DATABASE [jm] SET MULTI_USER                    (改为多用户模式)

REPAIR_ALLOW_DATA_LOSS:执行由REPAIR_REBUILD 完成的所有修复,包括对行和页进行分配和取消分配以改正分配错误结构行或页的错误,以及删除已损坏的文本对象这些修复可能会导致一些数据丢失修复操作可以在用户事务下完成以允许用户回滚所做的更改如果回滚修复,则数据库仍会含有错误,应该从备份进行恢复如果由于所提供修复等级的缘故遗漏某个错误的修复,则将遗漏任何取决于该修复的修复修复完成后,备份数据库

 

REPAIR_FAST 进行小的不耗时的修复操作,如修复非聚集索引中的附加键这些修复可以很快完成,并且不会有丢失数据的危险

 

REPAIR_REBUILD 执行由REPAIR_FAST 完成的所有修复,包括需要较长时间的修复(如重建索引),执行这些修复时不会有丢失数据的危险

 

dbcc shrinkdatabase  (jm)      压缩数据库

------------------------

SQL维护常用语句

 

1. 查看数据库的版本 
select @@version 

2. 查看数据库所在机器操作系统参数 
exec master..xp_msver 3. 查看数据库启动的参数 
sp_configure 

4. 查看数据库启动时间 
select convert(varchar(30),login_time,120from 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脚本 

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

11.查看对象的被关联信息

exec sp_depends 对象名

12.查看正在连接使用的进程

select  db_name(dbid),from  master..sysprocesses where spid>50 and db_name(dbid)='dbname'


;