江西广告网

标题: 在存储过程中使用use database [打印本页]

作者: 蓝信子    时间: 2008-12-24 11:59
标题: 在存储过程中使用use database
  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 <




欢迎光临 江西广告网 (http://bbs.jxadw.com/) Powered by Discuz! X3.2