SQL Server 中的 GO 及其与其他数据库的对比

SQL Server 中,GO 不是 SQL 语言的一部分,而是一个批处理分隔符,用于分隔脚本中的多个 SQL 语句或执行块。它由 SQL Server Management Studio (SSMS) 等工具处理,用来指示执行一个批次的 SQL 语句。

1、SQL Server 中的 GO 作用

  1. 分隔批次( 处理多批次脚本**)** :将 SQL 脚本中的语句分成多个批次执行。每个 GO 表示一个独立的执行块。例如,在某些操作中,创建表的语句可能依赖于先前的数据库和表创建,这时就可以利用 GO 来分隔不同的操作步骤。

  2. 事务控制GO 也常用于事务控制,尽管它本身并不是事务的一部分。通过在事务块的前后使用 GO,可以确保每个批次内的事务被独立处理。

sql 复制代码
例如:
CREATE DATABASE TestDB;
GO

USE TestDB;
GO

CREATE TABLE Customers (
    ID INT PRIMARY KEY,
    Name NVARCHAR(100)
);
GO

2、与其他数据库的对比

2.1 Oracle :不使用 GO,语句通过分号(;)分隔,支持使用 BEGIN ... END; 块来组织事务。

sql 复制代码
示例:
CREATE TABLE Employees (ID INT PRIMARY KEY, Name VARCHAR2(100));

BEGIN
  INSERT INTO Employees VALUES (1, 'John');
  COMMIT;
END;

2.2 MySQL :也不使用 GO,语句通过分号(;)分隔,直接执行。

sql 复制代码
示例:
CREATE DATABASE TestDB;

USE TestDB;

CREATE TABLE Customers (ID INT PRIMARY KEY, Name VARCHAR(100));

3、总结

  • SQL Server 使用 GO 来分隔批次,帮助执行多个 SQL 语句。

  • OracleMySQL 通过分号(;)分隔语句,不需要 GO

相关推荐
HackTwoHub1 小时前
AI大模型网关存在SQL注入、附 POC 复现、影响版本LiteLLM 1.81.16~1.83.7(CVE-2026-42208)
数据库·人工智能·sql·网络安全·系统安全·网络攻击模型·安全架构
l1t1 小时前
DeepSeek总结的DuckLake构建基于 SQL 原生表格式的下一代数据湖仓
数据库·sql
KmSH8umpK1 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第八篇
数据库·redis·分布式
TDengine (老段)2 小时前
从施工监测到运营预警,桥科院用 TDengine 提升桥梁数据管理能力
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
S1998_1997111609•X3 小时前
论mysql国盾shell-sfa犯罪行为集团下的分项工程及反向注入原理尐深度纳米算法下的鐌檵鄐鉎行为
网络·数据库·网络协议·百度·开闭原则
KmSH8umpK4 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第七篇
数据库·redis·分布式
yaodong5185 小时前
不会Python也能数据分析:Gemini 3.1 Pro解决办公问题的SQL自动生成
python·sql·数据分析
BU摆烂会噶5 小时前
【LangGraph】持久化实现的三大能力——时间旅行
数据库·人工智能·python·postgresql·langchain
l1t6 小时前
DeepSeek总结的DuckLake 入门
数据库
Joseph Cooper6 小时前
RAG 与 AI Agent:智能体真的需要检索增强生成吗?
数据库·人工智能·ai·agent·rag·上下文工程