在T—Sql中使用变量 一)局部变量 二)全局变量
来源:互联网 发布:pa数据 编辑:程序博客网 时间:2024/05/16 05:01
一、在T—Sql中使用变量
(一)局部变量
1声明变量 @age和@name
declare @name varchar(20)
declare @age int
2赋值
--(1)方法1
set @age=18
set @name='yqq'
--(2)方法2
select @age=27
select @name='ydx'
3分别使用set和select 为行号变量@rcount赋值
declare @rcount int
set @rcount=(select COUNT(*) from Student)
select @rcount=COUNT(*) from Student
计算score表中english平均成绩,如果〉=60,查询正数前三名,否则找出倒数前三名。
declare @count int
select @count=COUNT(*) from Score
declare @sum float
select @sum=SUM(ENGLISH) FROM Score
declare @avg float
set @avg=(@sum/@count)
if @avg>=60
begin
select top 3 * from Score order by english desc
end
else
begin
select top 3 * from Score order by english asc
end
4通过while 计算1---100之间奇数的和。
declare @sum2 int =0
declare @i int =1
while @i<=100
begin
if @i%2<>0
begin
set @sum2=@sum2+@i
end
set @i=@i+1
end
print @sum2
--5通过while 计算1---100之间偶数的和。
declare @sum3 int =0
declare @j int =1
while @j<=100
begin
if @j%2=0
begin
set @sum3=@sum3+@j
end
set @j=@j+1
end
print @sum3
--6使用while实现如果english不及格的人超过半数,则给每个人增加2分,循环加,直到不及格的人数少于一半。
declare @count2 int =(select COUNT(*)from T_Score)
declare @loster int =(select COUNT(*) from T_Score where FEnglish<60)
declare @harfcount int=floor(@count2/2)
while @harfcount<@loster
begin
update T_Score set FEnglish=FEnglish+2 where FEnglish<60
set @loster=(select COUNT(*)from T_Score where FEnglish<60)
end
--7使用事务实现--转账问题:从0001账户转1000块到0002账户。
create table Bank
(
Cid char(4) primary key,
balance money
)
alter table Bank
add constraint CH_balance check (balance>=10)
insert into Bank values('0001',1000)
insert into Bank values('0002',10)
begin tran
begin try
declare @errorSum int =0
update Bank set balance=balance-1000 where Cid='0001'
set @errorSum=@errorSum+@@error
update Bank set balance=balance+1000 where Cid='0002'
set @errorSum=@errorSum+@@error
commit
print '提交!!'
end try
begin catch
rollback
print '回滚!'
end catch
--8打开"隐式事务":设置为开,删除表中数据,回滚!(默认情况为关,如果打开了则不自动提交,学要手动提交)
set implicit_Transactions on --打开
delete from Bank
rollback
--9关闭“隐式事务”。
----如果隐式事务打开,然后删除某个表,在事务没有结束前,其它查询不能访问该表。
set implicit_Transactions off --关闭
--10使用系统存储过程
-- 给数据'Test'重命名为:'Test123'
exec sp_renamedb 'Test','Test123'
-- 查询当前数据库中有多少个表
exec sp_tables
-- 查询当前数据库中student表中的列信息
exec sp_columns 'Student'
--11自定义存储过程 “usp_Helloworld”并使用。实现输出hello world!
create proc usp_Helloworld
as
begin
print 'hello world!'
end
exec usp_Helloworld
- 在T—Sql中使用变量 一)局部变量 二)全局变量
- SQL中的全局变量和局部变量(@@/@)
- C语言中定义变量的技巧(全局变量、局部变量、静态全局变量、静态局部变量)
- IOS中 Block用法进阶二 局部变量和全局变量在Block中的使用
- T-SQL 之局部变量(1)
- 关于在多线程中,局部变量和全局变量的使用。
- SQL中全局变量和局部变量
- 局部变量和全局变量(成员变量)
- 在T-sql中使用变量
- SQL中的全局变量(@@)和局部变量(@)
- SQL中的全局变量 局部变量
- 全局变量、局部变量(auto局部变量)、静态全局变量、静态局部变量的区别
- 全局变量、局部变量(auto局部变量)、静态全局变量、静态局部变量的区别
- lua2.1 全局变量和局部变量(完善中)
- C++中局部变量、全局变量、静态局部变量、静态全局变量
- c/c++中静态局部变量以及全局变量的使用(转)
- static--修饰(局部变量、全局变量、函数)
- C++(二)全局变量、局部变量及静态变量(static)的区别
- java--第十周--任务一 封装一类对象,功能是随机产生一个2000年后的年份,并输出该年2月的日历页,需处理闰年的问题
- Blocks与Dispatch Queue的使用
- 打通两台机器
- sql server (数据库加强4)
- 修改profile文件后进入不了系统的解决办法
- 在T—Sql中使用变量 一)局部变量 二)全局变量
- jsp指令
- Introduction to Algorithm(chapter 3 and 4)
- JSP元素
- 一周一总结(10)
- IE老是提示js有错误(缺少标识符或者字符串)
- JSP元素总结
- z301摄像头的驱动移植
- Oracle存储过程返回带参数游标方法汇总