SQL Server Management Studio总是插入一个GO命令时,我创建一个查询使用右键单击“脚本作为”菜单。为什么?GO到底是做什么的?


当前回答

GO命令不是Transact-SQL语句,而是几个MS实用程序(包括SQL Server Management Studio代码编辑器)可以识别的特殊命令。

GO命令用于将SQL命令分组,并一起发送到服务器。批处理中包含的命令,即自上一个GO命令或会话开始以来的命令集,必须在逻辑上一致。例如,您不能在一个批处理中定义一个变量,然后在另一个批处理中使用它,因为变量的范围仅限于定义它的批处理。

欲了解更多信息,请参见http://msdn.microsoft.com/en-us/library/ms188037.aspx。

其他回答

从Management Studio 2005开始,你似乎可以使用带有int参数的GO,比如:

INSERT INTO mytable DEFAULT VALUES
GO 10

上面将在我的表中插入10行。一般来说,GO会执行n次相关的sql命令。

它是一个批处理终止符,但是你可以将它更改为任何你想要的

我还没有看到的一个用法是错误恢复。 由于一次只运行两个go之间的命令,这意味着一个命令中的编译错误可以与其他命令分开。通常情况下,批处理中的任何编译错误都会导致整个程序无法执行。

exec do.Something
GO
sel from table
print 'here'
GO
print 'there'

在上面的例子中,'here'将不会被打印出来,因为'sel'语句中存在错误。

现在,在中间添加一个GO:

exec do.Something
GO
sel from table
GO
print 'here'
GO
print 'there'

像以前一样,'sel'得到一个错误,但'here'得到输出。

GO不是SQL关键字。

它是客户端工具(如SSMS)使用的批处理分隔符,用于将整个脚本分解为批处理

之前回答过几次…示例1

GO命令不是Transact-SQL语句,而是几个MS实用程序(包括SQL Server Management Studio代码编辑器)可以识别的特殊命令。

GO命令用于将SQL命令分组,并一起发送到服务器。批处理中包含的命令,即自上一个GO命令或会话开始以来的命令集,必须在逻辑上一致。例如,您不能在一个批处理中定义一个变量,然后在另一个批处理中使用它,因为变量的范围仅限于定义它的批处理。

欲了解更多信息,请参见http://msdn.microsoft.com/en-us/library/ms188037.aspx。