T-SQL编程
(1)声明变量
declare @age int
(2)为变量赋值
set @age=26
(3)while循环
declare @i int=1
while @i<=100
begin
print @i
@i=@i+1
end
(4)if else
if @i>10
begin
print '大于10'
end
else if @i>5
begin
print '大于5'
end
else
begin
print '小于等于5'
end
(5)系统变量
@@version: 返回 SQL Server的当前安装的系统和生成信息。
@@error: 上一条sql语句出错,会有错误号;上一条sql执行没出错,则为0。
@@lanuage: 返回当前所用语言的名称。
@@max_connections: 返回 SQL Server实例允许同时进行的最大用户连接数。(实际允许的用户连接数还依赖于所安装的 SQL Server的版本以及应用程序和硬件的限制)
@@Rowcount: 上一条sql语句影响的行数。
@@servername: 返回正在运行 SQL Server的本地服务器的名称。
@@connections: 此函数返回 SQL Server自上次启动以来尝试的连接数,无论连接是成功还是失败。
(6)事务
一个事务中,不能一个sql语句执行成功,一个执行失败。只要有一个sql语句执行失败,就是失败。
自动提高事务:当执行一条sql语句,数据库自动打开一个事务,执行成功->自动提交,执行失败->自动回滚。
隐式事务:当执行一条sql语句,数据库自动打开一个事务,需要手动提交,手动回滚。(打开隐式事务:set implicit_Transactions ON)
显式事务:需要手动打开事务,手动提交,手动回滚。
打开一个事务:
begin transaction
declare @sum int=0
update tableA set Name='大胡子' where id=2
set @sum=@sum+@@error
update tableB set Name='大胡子' where id=2
set @sum=@sum+@@error
if @sum<>0
begin
rollback --回滚,也可写rollback transaction
end
else
begin
commit --提交,也可写commit transaction
end 继续阅读与本文标签相同的文章
-
9GB一个估值10亿的区块链云存储项目
2026-05-18栏目: 教程
-
尘埃落定!美盟友明确表示不排除华为5G:特朗普颜面尽失!
2026-05-18栏目: 教程
-
“中本聪”一词被收入牛津英语词典
2026-05-18栏目: 教程
-
中山5G建设传重磅消息!市民何时能用?时间定了!
2026-05-18栏目: 教程
-
调查显示中国88%员工信任机器人超过经理
2026-05-18栏目: 教程
