首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在“使用[Database_Name]”之后使用Go?

在“使用[Database_Name]”之后使用Go?
EN

Stack Overflow用户
提问于 2017-10-24 18:15:43
回答 2查看 1.1K关注 0票数 1

我看到的一个常见模式是:

代码语言:javascript
运行
复制
USE Name_Of_My_Database
GO

据我所知,这是没有意义的,是吗?我试着在下面列出的地方寻找答案,但没有找到答案:

What is the use of GO in SQL Server Management Studio & Transact SQL?

In SQL Server, when should you use GO and when should you use semi-colon ;?

https://learn.microsoft.com/en-us/sql/t-sql/language-elements/sql-server-utilities-statements-go

编辑:不,这不是一个复制,这个问题更具体-我没有找到我需要的信息在链接的问题,虽然我看了它之前,张贴这个。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-10-24 18:22:37

GO;有两个很大的区别

  1. GO将脚本分成不同的批。
  2. ;是语句终止符。

当下面的语句要求GO是批处理中的第一个语句时,在USE DatabaseName之后使用它是必要的。例如,以下代码将失败:

代码语言:javascript
运行
复制
Use SomeDatabase

Create Procedure spSomeProcedure
As Begin
    Select 1
End

Msg 111,15级,状态1,过程spSomeProcedure,第4行 “'CREATE/ALTER过程”必须是查询批处理中的第一个语句。

但是在它们之间添加一个GO将允许运行该语句:

代码语言:javascript
运行
复制
Use SomeDatabase
Go

Create Procedure spSomeProcedure
As Begin
    Select 1
End

命令已成功完成。

票数 4
EN

Stack Overflow用户

发布于 2017-10-24 18:23:25

我将我的SSMS脚本选项设置为非脚本USE语句。总的来说,我觉得它们也是毫无意义的。

"GO“不是SQL命令,它只是一个批处理分隔符.它是SSMS特性(或ISQL/OSQL特性),而不是Server特性。这是一种让一个文本文件包含要发送到Server的多批SQL的方法。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46917381

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档