一天一点T-SQL:关于GO

做Microsoft SQL Server的人都应该对GO这个关键字很熟悉吧,但是昨天我遇到一个跟GO有关但无关的问题,纠结了... ...今天来分享一下

微软解释GO不是SQL的标准语法的一部分,而是提供给工具例如sqlcmd 之类的一个划分SQL段的标志

具体的如下

  
  
  
  
  1. CREATE TABLE TableName  
  2. (  
  3.   ColumnName1 DataType,  
  4.   ColumnName2 DataType  
  5. )  
  6. GO  
  7.  
  8. INSERT INTO TableName(ColumnName1,ColumnName2)  
  9. VALUES (Value1,Value2)  
  10. GO 

在解析和执行的时候这一篇T-SQL脚本其实是被认为是两个独立的部分,只不过他们使用同一个Session

举一个最有说服力的例子

  
  
  
  
  1. DECLARE @Parameter1 INT 
  2. DECLARE @Parameter2 INT 
  3.  
  4. -- If insert "GO" to there...   
  5. -- "GO"  
  6. -- Result:  
  7. -- Msg 137, Level 15, State 1, Line 1  
  8. -- Must declare the scalar variable "@Parameter1".  
  9. -- Msg 137, Level 15, State 1, Line 2  
  10. -- Must declare the scalar variable "@Parameter2".  
  11. -- Msg 137, Level 15, State 2, Line 4  
  12. -- Must declare the scalar variable "@Parameter1".  
  13. SET @Parameter1 = 1  
  14. SET @Parameter2 = 2  
  15.  
  16. PRINT @Parameter1 + @Parameter2  
  17. GO  
  18. -- Result: 3 

当你在使用的变量以前插入了一个GO,这个GO之前脚本会作为一个提交部分,而这个GO以后的部分会作为第二个部分进行提交

P.S. 这里说的提交仅是提交SQL代码,不会提交"GO"这个关键字

我们还需要留意以下特殊注意事项:

1与GO同一行,GO前边不能包含任何SQL

2与GO同一行,GO后边可以跟 -- 注释,但是不能跟 /**/ 注释!

这个问题情况大家都不会这样写,所以遇到的几率很小,但是有一个原因引发第1个问题的情况值得大家注意×SQL脚本的文本格式,最好编码完成后检查一下文本格式选择UTF,否则可能你看到自己是换行了,但是在SQL解析的时候会认为他们在同一行,这样的情况当你越检查越会觉得SQL写得很对,但是... ... 但是它始终告诉你语法错误... ... 一定小心... ... 昨天我就傻傻的在那里调了一天... ... 彻底的郁闷了... ... 呵呵

下边再说一个GO的特性,但是我们大家都不常用,或者说我们由于GO太常见而忽略掉了它的这个重要的特性,就是 -- GO是可以代替我们做重复操作的!!

  
  
  
  
  1. -- INSERT TABLE TableName(Column1, Column2)  
  2. -- VALUES (Value1, Value2)  
  3. -- GO [Number] 这里的Number必须是正整数!  
  4.  
  5. INSERT TABLE TableName(Column1, Column2)  
  6. VALUES (Value1, Value2)  
  7. GO 100  
  8. -- 在这里我们会看到GO加了100次重复操作,  
  9. -- 同时在SSMS窗口智能感知的时候会用红线告诉我们语法不对  
  10. -- 但是请放心执行,他100%能通过,同时必定为你运行100次 

呵呵,GO介绍完了,突然再次感悟到,有些东西看上去很平凡,但那是因为我还不够级别... ... 研究不够深啊... ... 天啊... ...

本文出自 “Fast” 博客,谢绝转载!

你可能感兴趣的:(数据库,注意事项,解释,休闲,关键字GO)