注册
 找回密码
 注册
江西广告网
查看: 275|回复: 0
打印 上一主题 下一主题

在存储过程中使用use database

[复制链接]

该用户从未签到

1
跳转到指定楼层
发表于 2008-12-24 11:59:05 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?注册

x
  It's well known.Microsoft SQL Server是不允许在存储过程或触发器中使用USE数据库语句来改变当前数据库的。怎么办呢?当然可以直接用[databasename].[user].[tablename]这样来访问,但是某些语句必须在当前数据库下执行,比如sp_adduser等。      这里提供一个解决方案:   使用Exec(ute)语句来改变当前数据库,不过要注意的是,数据库环境的更改只在Execute语句结束前有效,所以你必须把   后面的语句和Execute放到一起。   Example:   create proc test   as   exec('use pubs') exec sp_adduser 'test'   go   --Writte   exec test <
您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表