在检查web上的一些代码和SQL Server Management Studio生成的脚本时,我注意到一些语句以分号结束。

那么什么时候用呢?


当前回答

分号似乎不应该与游标操作一起使用:OPEN, FETCH, CLOSE和DEALLOCATE。我在这上面浪费了几个小时。我仔细查看了BOL,并注意到[;]没有显示在这些游标语句的语法中!!

所以我有:

OPEN mycursor;

这给了我错误16916。

But:

OPEN mycursor

工作。

其他回答

注意:这回答了书面的问题,但不是陈述的问题。把它添加到这里,因为人们会搜索它

在递归CTE语句中,分号也用在WITH之前:

;WITH Numbers AS
(
    SELECT n = 1
    UNION ALL
    SELECT n + 1
    FROM Numbers
    WHERE n+1 <= 10
)
SELECT n
FROM Numbers

这个查询将生成一个名为Numbers的CTE,由整数[1..10]组成。它是通过创建一个值为1的表来完成的,然后递归直到达到10。

如果我没有看错的话,需要使用分号来结束TSQL语句。 http://msdn.microsoft.com/en-us/library/ms143729%28v=sql.120%29.aspx

编辑: 我找到了SSMS 2008R2的一个插件,它将格式化脚本并添加分号。我想它还在测试阶段…

http://www.tsqltidy.com/tsqltidySSMSAddin.aspx

编辑: 我发现了一个更好的免费工具/插件叫ApexSQL… http://www.apexsql.com/

个人意见:只在需要的地方使用它们。(请参阅TheTXI的回答,以获得所需的列表。)

因为编译器不需要它们,你可以把它们放在所有地方,但是为什么呢?编译器不会告诉你在哪里忘记了一个,所以你最终会使用不一致。

[此意见是针对SQL Server的。其他数据库可能有更严格的要求。如果您正在编写运行在多个数据库上的SQL,您的需求可能会有所不同。

Tpdi上面说过,“在脚本中,当您发送多个语句时,就需要它。”这其实是不对的。你不需要他们。

PRINT 'Semicolons are optional'
PRINT 'Semicolons are optional'
PRINT 'Semicolons are optional';
PRINT 'Semicolons are optional';

输出:

Semicolons are optional
Semicolons are optional
Semicolons are optional
Semicolons are optional

分号似乎不应该与游标操作一起使用:OPEN, FETCH, CLOSE和DEALLOCATE。我在这上面浪费了几个小时。我仔细查看了BOL,并注意到[;]没有显示在这些游标语句的语法中!!

所以我有:

OPEN mycursor;

这给了我错误16916。

But:

OPEN mycursor

工作。

我仍然有很多关于T-SQL的知识要学习,但在为事务编写一些代码(并基于来自stackoverflow和其他站点的示例代码)时,我发现了一个情况,其中似乎需要分号,如果缺少分号,语句似乎根本不执行,也没有引发错误。以上的答案似乎都没有涉及到这一点。(本文使用的是MS SQL Server 2012。)

一旦我让事务以我想要的方式工作,我决定在它周围放一个try-catch,这样如果有任何错误,它就会回滚。只有在这样做之后,事务才没有提交(SSMS在试图关闭窗口时确认这一点,并发出一条漂亮的消息,提醒您有一个未提交的事务。

所以这

COMMIT TRANSACTION 

在BEGIN TRY/END TRY块外可以很好地提交事务,但在块内必须如此

COMMIT TRANSACTION;

注意,没有提供错误或警告,也没有指示在尝试关闭查询选项卡之前事务仍然未提交。

幸运的是,这导致了一个巨大的问题,立即就可以明显地看出有问题。不幸的是,由于没有报告错误(语法或其他),所以问题并不明显。

相反,ROLLBACK TRANSACTION在BEGIN CATCH块中使用分号或不使用分号似乎都同样有效。

这可能有一定的逻辑,但它给人的感觉是武断的,像爱丽丝梦游仙境一样。