SQL Server Management Studio总是插入一个GO命令时,我创建一个查询使用右键单击“脚本作为”菜单。为什么?GO到底是做什么的?
当前回答
它是一个分离查询的命令。如果你在做多次选择,它没有太大的区别,以我为例,主要用途是当我创建脚本时,你需要创建存储过程,然后授予访问或执行它们。例如:
CREATE OR ALTER PROCEDURE dbo.select1
AS
BEGIN
SET NOCOUNT ON
SELECT 1
END
EXEC dbo.select1
它将创建包含所有内容的存储过程,包括EXEC,它将在循环中结束。 GO语句会说,在结束后创建存储过程,然后执行。
CREATE OR ALTER PROCEDURE dbo.select1
AS
BEGIN
SET NOCOUNT ON
SELECT 1
END
GO
EXEC dbo.select1
其他回答
Go的意思是,无论SQL语句写在它之前和任何更早的Go之后,都将去SQL服务器进行处理。
Select * from employees;
GO -- GO 1
update employees set empID=21 where empCode=123;
GO -- GO 2
在上面的例子中,在GO 1之前的语句将在一个批处理中进入sql server,然后在GO 2之前的任何其他语句将在另一个批处理中进入sql server。我们可以看到它是分开的批次。
GO意思是让SQL重复这个你在它后面加上的数字。就像用英语说;“嘿,去那里3次。”尝试下面的SQL和结果将呈现表3次。
SELECT * FROM Table
GO 3
只是为了添加到现有的答案,当你创建视图时,你必须使用go将这些命令分成批量,否则你会得到错误'CREATE VIEW'必须是批处理中唯一的语句。例如,如果没有go,您将无法执行下面的sql脚本
create view MyView1 as
select Id,Name from table1
go
create view MyView2 as
select Id,Name from table1
go
select * from MyView1
select * from MyView2
我还没有看到的一个用法是错误恢复。 由于一次只运行两个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关键字。
我可以补充的一点是,当你在GO命令之前声明了一些变量时,你将无法在GO命令之后访问这些变量。即
DECLARE @dt DateTime = GETDATE();
UPDATE MyTable SET UpdatedOn = @dt where mycondition = 'myvalue';
GO
-- Below query will raise an error saying the @dt is not declared.
UPDATE MySecondTable SET UpdatedOn = @dt where mycondition = 'myvalue'; -- Must declare the scalar variable "@dt".
GO
更新
我知道,人们询问什么时候使用Go命令,所以我想,我应该在我的查询中添加为什么我使用Go命令。
当我在表中有大量更新时,我通常在下班时运行这些更新(这意味着,我不会监视查询),因为第二天很方便,可以发现表已经为其他操作做好了准备。
当我需要运行长时间的操作,并希望分离查询和完成部分事务时,我使用Go命令,例如:
-- First Query
Update MyBigTable1 SET somecol1='someval1' where somecol2='someval2'
GO
-- Second Query
Update MyBigTable2 SET somecol1='someval1' where somecol2='someval2'
GO
-- Third Query
Update MyBigTable3 SET somecol1='someval1' where somecol2='someval2'
执行上述查询将单独提交修改,而不会导致生成大量的回滚日志。另外,如果第三个查询失败,您知道前两个查询是正确执行的,并且不会回滚任何东西。因此,您不需要花费更多的时间为以前执行的查询再次更新/删除记录。
用一句话来总结,“我使用GO命令作为电子游戏中的检查点。”如果你在检查点(GO命令)后失败,你不需要重新开始,而是让你的游戏从最后一个检查点开始。
推荐文章
- 确定记录是否存在的最快方法
- 从现有模式生成表关系图(SQL Server)
- 我如何循环通过一组记录在SQL Server?
- 数据库和模式的区别
- 如何在SQL Server中一次更改多个列
- 如何从SQL Server Management Studio的历史记录中删除“服务器名称”项
- 外键约束可能导致循环或多条级联路径?
- 如何选择每一行的列值不是独特的
- nvarchar(max)非文本
- 在SQL Server 2008 R2中重命名数据库时出错
- 将数据复制到另一个表中
- 如何在SQL中选择表的最后一条记录?
- 修改列,添加默认约束
- 在存储过程中使用“SET XACT_ABORT ON”有什么好处?
- 如何检查SQL Server文本列是否为空?