Transact-SQL 数据库任务对应的SQL语句

1.sp_attach_db【附加数据库】
将数据库附加到服务器。

语法
sp_attach_db [ @dbname = ] 'dbname'
    , [ @filename1 = ] 'filename_n' [ ,...16 ]

参数
[@dbname =] 'dbname'

要附加到服务器的数据库的名称。该名称必须是唯一的。dbname 的数据类型为 sysname,默认值为 NULL。

[@filename1 =] 'filename_n'

数据库文件的物理名称,包括路径。filename_n 的数据类型为 nvarchar(260),默认值为 NULL。最多可以指定 16 个文件名。参数名称以 @filename1 开始,递增到 @filename16。文件名列表至少必须包括主文件,主文件包含指向数据库中其它文件的系统表。该列表还必须包括数据库分离后所有被移动的文件。

返回代码值
0(成功)或 1(失败)

结果集

注释
只应对以前使用显式 sp_detach_db 操作从数据库服务器分离的数据库执行 sp_attach_db。如果必须指定多于 16 个文件,请使用带有 FOR ATTACH 子句的 CREATE DATABASE。

如果将数据库附加到的服务器不是该数据库从中分离的服务器,并且启用了分离的数据库以进行复制,则应该运行 sp_removedbreplication 从数据库删除复制。

权限
只有 sysadmin 和 dbcreator 固定服务器角色的成员才能执行本过程。

示例
下面的示例将 pubs 中的两个文件附加到当前服务器。

EXEC sp_attach_db @dbname = N'pubs',
   @filename1 = N'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs.mdf',
   @filename2 = N'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs_log.ldf'


2.sp_detach_db【分离数据库】
从服务器分离数据库,并可以选择在分离前在所有的表上运行 UPDATE STATISTICS。

语法
sp_detach_db [ @dbname = ] 'dbname'
    [ , [ @skipchecks = ] 'skipchecks' ]

参数
[@dbname =] 'dbname'

要分离的数据库名称。dbname 的数据类型为 sysname,默认值为 NULL。

[@skipchecks =] 'skipchecks'

skipchecks 的数据类型为 nvarchar(10),默认值为 NULL。如果为 true,则跳过 UPDATE STATISTICS。如果为 false,则运行 UPDATE STATISTICS。对于要移动到只读媒体上的数据库,此选项很有用。

返回代码值
0(成功)或 1(失败)

结果集

注释
使用 sp_attach_db 或 sp_attach_single_file_db 保留并重新附加分离文件。文件也可以移动并附加到其它服务器上。

权限
只有 sysadmin 固定服务器角色的成员才能执行 sp_detach_db。

示例
下面的示例分离 pubs 数据库,并将 skipchecks 设为 true。

EXEC sp_detach_db 'pubs', 'true'


3.【修改数据库日期】
如何修改数据库服务器的系统时间?
EXEC   master..xp_cmdshell   'date   2003-10-7'
EXEC   master..xp_cmdshell   'time   20:00:00'

 

xp_cmdshell
以操作系统命令行解释器的方式执行给定的命令字符串,并以文本行方式返回任何输出。授予非管理用户执行 xp_cmdshell 的权限。


说明  在 Microsoft? Windows? 95 或 Microsoft Windows 98 操作系统中执行 xp_cmdshell 时,将不把 xp_cmdshell 的返回代码设置为唤醒调用的可执行文件的进程退出代码。返回代码始终为 0。


语法
xp_cmdshell {'command_string'} [, no_output]

参数
'command_string'

是在操作系统命令行解释器上执行的命令字符串。command_string 的数据类型为 varchar(255) 或 nvarchar(4000),没有默认值。command_string 不能包含一对以上的双引号。如果由 command_string 引用的文件路径或程序名称中有空格,则需要使用一对引号。如果使用嵌入空格不方便,可考虑使用 FAT 8.3 文件名作为解决办法。

no_output

是可选参数,表示执行给定的 command_string,但不向客户端返回任何输出。

返回代码值
0(成功)或 1(失败)

结果集
执行下列 xp_cmdshell 语句将返回当前目录的目录列表。

xp_cmdshell 'dir *.exe'

行以 nvarchar(255) 列的形式返回。

执行下列 xp_cmdshell 语句将返回随后的结果集:

xp_cmdshell 'dir *.exe', NO_OUTPUT

下面是结果:

The command(s) completed successfully.

注释
xp_cmdshell 以同步方式操作。在命令行解释器命令执行完毕之前,不会返回控制。

当授予用户执行权限时,用户能在 Microsoft Windows NT? 命令行解释器上执行运行 Microsoft SQL Server? 的帐户有权执行的任何操作系统命令。

默认情况下,只有 sysadmin 固定服务器角色的成员才能执行此扩展存储过程。但是,也可以授予其他用户执行此存储过程的权限。

当作为 sysadmin 固定服务器角色成员的用户唤醒调用 xp_cmdshell 时,将在运行 SQL Server 服务的安全上下文中执行 xp_cmdshell。当用户不是 sysadmin 组的成员时,xp_cmdshell 将模拟使用 xp_sqlagent_proxy_account 指定的 SQL Server 代理程序的代理帐户。如果代理帐户不能用,则 xp_cmdshell 将失败。这只是针对于 Microsoft? Windows NT? 4.0 和 Windows 2000。在 Windows 9.x 上,没有模拟,且 xp_cmdshell 始终在启动 SQL Server 的 Windows 9.x 用户的安全上下文下执行。

 

说明  在早期版本中,获得 xp_cmdshell 执行权限的用户在 MSSQLServer 服务的用户帐户上下文中运行命令。可以通过配置选项配置 SQL Server,以便对 SQL Server 无 sa 访问权限的用户能够在 SQLExecutiveCmdExec Windows NT 帐户的上下文中运行 xp_cmdshell。在 SQL Server 7.0 中,该帐户称为 SQLAgentCmdExec。现在,不是 sysadmin 固定服务器角色成员的用户将在该帐户上下文中运行命令,而无需再进行配置更改。


权限
xp_deletemail 的执行权限默认授予 sysadmin 固定服务器角色的成员,但可以授予其他用户。

 

重要  如果为 MSSQLServer 服务选用的 Windows NT 帐户不是本地管理员组的成员,则非 sysadmin 固定服务器角色成员的用户将无法执行 xp_cmdshell。


示例
A. 返回可执行文件列表
下例显示执行目录命令的 xp_cmdshell 扩展存储过程。

EXEC master..xp_cmdshell 'dir *.exe'

B. 使用 Windows NT net 命令
下例显示 xp_cmdshell 在存储过程中的使用。下例先用 net send 通知用户 SQL Server 即将关闭,然后用 net pause 暂停服务器,最后用 net stop 关闭服务器。

CREATE PROC shutdown10
AS
EXEC xp_cmdshell 'net send /domain:SQL_USERS ''SQL Server shutting down
   in 10 minutes. No more connections allowed.', no_output
EXEC xp_cmdshell 'net pause sqlserver'
WAITFOR DELAY '00:05:00'
EXEC xp_cmdshell 'net send /domain: SQL_USERS ''SQL Server shutting down
   in 5 minutes.', no_output
WAITFOR DELAY '00:04:00'
EXEC xp_cmdshell 'net send /domain:SQL_USERS ''SQL Server shutting down
   in 1 minute. Log off now.', no_output
WAITFOR DELAY '00:01:00'
EXEC xp_cmdshell 'net stop sqlserver', no_output

C. 不返回输出
下例使用 xp_cmdshell 执行命令字符串,且不向客户端返回输出。

USE master
EXEC xp_cmdshell 'copy c:\sqldumps\pubs.dmp http://www.cnblogs.com/jdmei520/admin/file://server2/backups/sqldumps',
   NO_OUTPUT

D. 使用返回状态
在下例中,xp_cmdshell 扩展存储过程也给出了返回状态。返回代码值存储在变量 @result 中。

DECLARE @result int
EXEC @result = xp_cmdshell 'dir *.exe'
IF (@result = 0)
   PRINT 'Success'
ELSE
   PRINT 'Failure'

E. 将变量内容写入文件
下例将当前目录内容写入当前服务器目录下名为 dir_out.txt 的文件中。

DECLARE @cmd sysname, @var sysname
SET @var = 'dir /p'
SET @cmd = 'echo ' + @var + ' > dir_out.txt'
EXEC master..xp_cmdshell @cmd



4.添加字段

ContractedBlock.gif ExpandedBlockStart.gif Code
CREATE PROCEDURE pcd_AddField 
@FieldName varchar(10)
AS
if   exists 
   (
select   *   from   syscolumns   where   [name]=@FieldName   and   OBJECTPROPERTY(id,'IsUserTable')=1   and   object_name(id)='nyy_MCollect')   
    
print   '字段已存在!' 
else   
      
begin   
       
exec spAddColumn 'nyy_MCollect',@FieldName,'varchar'
      
end


GO


CREATE   PROC   spAddColumn   
  (   
      
@TableName   VARCHAR(50),   
      
@ColName   VARCHAR(50),   
      
@Type   VARCHAR(50)   
  )   
  
AS   
  
SET   NOCOUNT   ON   
    
  
DECLARE   @vSql   VARCHAR(8000)   
  
SET   @vSql   =   '   
  ALTER   TABLE   [
'   +   @TableName   +   ']   
  ADD   [
'   +   @ColName   +   ']   '   +   @Type   
    
  
EXEC(@vSql)   
  
GO
 
 
 

 

 

5. DBCC 数据库控制台命令语句

 

收缩指定数据库中的数据文件大小。 DBCC SHRINKDATABASE

DBCC SHRINKDATABASE
    ( database_name [ , target_percent ]
        [ , { NOTRUNCATE | TRUNCATEONLY } ]
    )

DBCC SHRINKDATABASE('kj4n_pcd')

 

 

转载于:https://www.cnblogs.com/jdmei520/archive/2008/08/06/1262178.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用以下Transact-SQL语句来创建一个名为“jobs”的数据库: CREATE DATABASE jobs; 该语句将创建一个名为“jobs”的空数据库。如果需要添加表或其他对象,请使用CREATE TABLE和其他相关语句。 ### 回答2: 用 Transact-SQL 语句创建 Jobs 数据库,需要经过以下几个步骤: 1. 打开 SQL Server Management Studio(SSMS),在 Object Explorer 中连接到 SQL Server 数据库引擎实例。 2. 在 SSMS 中点击新建查询按钮,在查询窗口中输入以下 Transact-SQL 语句: ```sql CREATE DATABASE Jobs; ``` 3. 执行以上语句,等待创建完成。如果创建成功,应该会在消息窗口中看到类似以下的消息: ``` Query OK, 1 row affected. ``` 4. 在 Object Explorer 中,如果没有显示 Jobs 数据库,可以尝试刷新一下。 5. 如果需要对 Jobs 数据库进行更多设置,比如设置文件组、设置文件路径等,可以使用 Transact-SQL 语句进行操作。以下是一些示例语句: ```sql -- 设置文件组 ALTER DATABASE Jobs ADD FILEGROUP JobsData; -- 添加数据文件 ALTER DATABASE Jobs ADD FILE ( NAME = JobsDataFile, FILENAME = 'E:\MSSQL\DATA\JobsData.mdf', SIZE = 512MB, MAXSIZE = UNLIMITED, FILEGROWTH = 256MB ) TO FILEGROUP JobsData; -- 添加日志文件 ALTER DATABASE Jobs ADD LOG FILE ( NAME = JobsLogFile, FILENAME = 'E:\MSSQL\LOG\JobsLog.ldf', SIZE = 256MB, MAXSIZE = 2GB, FILEGROWTH = 64MB ); ``` 6. 创建完 Jobs 数据库后,可以使用 Transact-SQL 语句创建表、视图、存储过程等数据库对象,或者使用 SSMS 提供的可视化界面进行操作。 总的来说,使用 Transact-SQL 语句创建 Jobs 数据库相对简单且灵活,可以满足各种不同的需求。但是需要注意的是,执行操作前应该先了解 Transact-SQL 知识和数据库设计原理,以免操作不当导致数据丢失或者安全问题。 ### 回答3: 在使用transact-sql语句创建jobs数据库之前,需要确保你已经安装了SQL Server Management Studio或SQL Server。下面是创建一个名为jobs的数据库的步骤: 1. 打开SQL Server Management Studio或SQL Server。 2. 在“对象资源管理器”窗口中,右键单击“数据库”并选择“新建数据库”。 3. 在“新建数据库”对话框中,输入“jobs”作为数据库名称。 4. 在“文件”选项卡上,选择要存储数据文件和日志文件的路径。 5. 在“选项”选项卡上,可以选择设置数据库选项,例如恢复模式和默认语言。 6. 点击“确定”按钮创建数据库。 另外,也可以通过T-SQL语句创建数据库。以下是使用T-SQL语句创建jobs数据库的示例代码: CREATE DATABASE jobs ON (NAME = 'jobs_data', FILENAME = 'C:\Program Files\Microsoft SQL Server\MSSQL15.MSSQLSERVER\MSSQL\DATA\jobs_data.mdf', SIZE = 50MB, MAXSIZE = UNLIMITED, FILEGROWTH = 5MB) LOG ON (NAME = 'jobs_log', FILENAME = 'C:\Program Files\Microsoft SQL Server\MSSQL15.MSSQLSERVER\MSSQL\DATA\jobs_log.ldf', SIZE = 25MB, MAXSIZE = UNLIMITED, FILEGROWTH = 5MB); GO 这段T-SQL语句创建了一个名为jobs的数据库,并将数据文件保存在C:\Program Files\Microsoft SQL Server\MSSQL15.MSSQLSERVER\MSSQL\DATA目录下。 数据文件的初始大小为50MB,并且可以无限制地增长5MB,日志文件的初始大小为25MB,并且也可以无限制地增长5MB。注意:此示例中使用的目录和文件名会因环境而异,需要根据实际情况进行修改。 无论使用哪种方法创建jobs数据库,都需要确保该数据库是否存在,并且数据库有具体定义,以确保它可以正常使用和操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值