sql server中的go

來源:互聯網
上載者:User

標籤:mil   令行   引用   輸出   sans   t-sql   執行計畫   組成   代碼編輯   

1. 作用:
向 SQL Server 公用程式發出一批 Transact-SQL 陳述式結束的訊號.
2. 文法:
一批 Transact-SQL 陳述式
GO

Select 1
Select 2
Select 3
GO
3. 說明:
1) GO 不是 Transact-SQL 陳述式;
2) 它是 sqlcmd 和 osql 工具 + 生產力以及 SQL Server Management Studio 代碼編輯器識別的命令.
3) SQL Server 應用程式可以將多個 Transact-SQL 陳述式作為一個批發送到 SQL Server 的執行個體來執行.然後,該批中的語句被編譯成一個執行計畫.程式員在 SQL Server 公用程式中執行特殊語句,或產生 Transact-SQL 陳述式的指令碼在 SQL Server 公用程式中運行時,使用 GO 作為批結束的訊號.
4) 如果基於 ODBC 或 OLE DB API 的應用程式試圖執行 GO 命令,會收到語法錯誤.SQL Server 公用程式從不向伺服器發送 GO 命令.
4. 許可權:
GO 是一個不需任何許可權的工具 + 生產力命令.它可以由任何使用者執行.
5. 用法:
1) SQL Server 公用程式將 GO 解釋為應該向 SQL Server 執行個體發送當前批 Transact-SQL 陳述式的訊號.當前批語句由上一 GO 命令後輸入的所有語句組成,如果是第一條 GO 命令,則由即席會話或指令碼開始後輸入的所有語句組成.

SQL Server中go語句使用注意事項

1、GO 命令和 Transact-SQL 陳述式不能在同一行中.但在 GO 命令列中可包含注釋


Select 1
GO
--會正確輸出結果,列名為”無列名”

Select 1 GO

--會正確輸出結果,列名為”GO”
--由此可知此處的GO並未起到應有的作用;


2、使用者必須遵照使用批處理的規則.例如,在同一批處理中,建立資料庫之後不能直接使用其建立的資料庫


create database [Roc]
use [Roc]
GO
--運行此批處理後,系統會報錯
--把此批處理分成兩個批即可正確運行


create database [Roc]
GO
use [Roc]
GO

 

3、局部(使用者定義)變數的範圍限制在一個批處理中,不可在 GO 命令後引用

 

declare @Roc varchar(max)
Select @Roc = ‘aking‘
GO
print @Roc
GO

--此為兩個批處理,由於局部變數的範圍要限制在一個批處理中,所以此語句錯誤
--把這兩個批合并為一個批即可正確運行

declare @Roc varchar(max)
Select @Roc = ‘aking‘
print @Roc
GO

 

4、每個被GO分隔的語句都是一個單獨的事務,一個語句執行失敗不會影響其它語句執行

 

select * from sysobjects where id=a
select getdate()

--你會發現會報錯,並且不會顯示任何結果集


select * from sysobjects where id=a
go
select getdate()
go

--你會發現儘管同樣會報錯,但結果集中包含select getdate()的結果。


5、GO [count] count 為正整數.指定GO 之前的批處理執行指定的次數

 

insert [Roc] Select ‘aking‘
GO
--批處理執行1次,向表Roc中插入一行記錄

aking Insert [Roc] Select ‘aking‘
GO 10
--批處理執行10次,向表Roc中插入10行記錄aking

 

sql server中的go

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.