一、定义变量
--简单赋值
declare @a int
set @a=5
print @a --使用select语句赋值
declare @user1 nvarchar(50)
select @user1='张三'
print @user1
declare @user2 nvarchar(50)
select @user2 = Name from ST_User where ID=1
print @user2 --使用update语句赋值
declare @user3 nvarchar(50)
update ST_User set @user3 = Name where ID=1
print @user3二、表、临时表、表变量--创建临时表1
create table #DU_User1
( [ID] [int]  NOT NULL, [Oid] [int] NOT NULL, [Login] [nvarchar](50) NOT NULL, [Rtx] [nvarchar](4) NOT NULL, [Name] [nvarchar](5) NOT NULL, [Password] [nvarchar](max) NULL, [State] [nvarchar](8) NOT NULL
);
--向临时表1插入一条记录
insert into #DU_User1 (ID,Oid,[Login],Rtx,Name,[Password],State) values (100,2,'LS','0000','临时','321','特殊'); --从ST_User查询数据,填充至新生成的临时表
select * into #DU_User2 from ST_User where ID<8 --查询并联合两临时表
select * from #DU_User2 where ID<3 union select * from #DU_User1 --删除两临时表
drop table #DU_User1
drop table #DU_User2--创建临时表
CREATE TABLE #t
( [ID] [int] NOT NULL, [Oid] [int] NOT NULL, [Login] [nvarchar](50) NOT NULL, [Rtx] [nvarchar](4) NOT NULL, [Name] [nvarchar](5) NOT NULL, [Password] [nvarchar](max) NULL, [State] [nvarchar](8) NOT NULL,
) --将查询结果集(多条数据)插入临时表
insert into #t select * from ST_User
--不能这样插入
--select * into #t from dbo.ST_User --添加一列,为int型自增长子段
alter table #t add [myid] int NOT NULL IDENTITY(1,1)
--添加一列,默认填充全球唯一标识
alter table #t add [myid1] uniqueidentifier NOT NULL default(newid()) select * from #t
drop table #t
--给查询结果集增加自增长列 --无主键时:
select IDENTITY(int,1,1)as ID, Name,[Login],[Password] into #t from ST_User
select * from #t --有主键时:
select (select SUM(1) from ST_User where ID<= a.ID) as myID,* from ST_User a order by myID
--定义表变量
declare @t table
( id int not null, msg nvarchar(50) null
)
insert into @t values(1,'1')
insert into @t values(2,'2')
select * from @t三、循环--while循环计算1到100的和
declare @a int
declare @sum int
set @a=1
set @sum=0
while @a<=100
beginset @sum+=@a set @a+=1
end
print @sum
四、条件语句--if,else条件分支
if(1+1=2)
beginprint '对'
end
else
beginprint '错'
end--when then条件分支
declare @today int
declare @week nvarchar(3)
set @today=3
set @week=casewhen @today=1 then '星期一'when @today=2 then '星期二'when @today=3 then '星期三'when @today=4 then '星期四'when @today=5 then '星期五'when @today=6 then '星期六'when @today=7 then '星期日'else '值错误'
end
print @week五、游标declare @ID int
declare @Oid int
declare @Login varchar(50) --定义一个游标
declare user_cur cursor for select ID,Oid,[Login] from ST_User
--打开游标
open user_cur
while @@fetch_status=0
begin
--读取游标 fetch next from user_cur into @ID,@Oid,@Login print @ID --print @Login
end
close user_cur
--摧毁游标
deallocate user_cur
六、触发器触发器中的临时表:Inserted 存放进行insert和update 操作后的数据 Deleted 存放进行delete 和update操作前的数据--创建触发器
Create trigger User_OnUpdate  On ST_User  for Update
As declare @msg nvarchar(50) --@msg记录修改情况 select @msg = N'姓名从“' + Deleted.Name + N'”修改为“' + Inserted.Name + '”' from Inserted,Deleted --插入日志表 insert into [LOG](MSG)values(@msg) --删除触发器
drop trigger User_OnUpdate
七、存储过程--创建带output参数的存储过程
CREATE PROCEDURE PR_Sum @a int, @b int, @sum int output
AS
BEGINset @sum=@a+@b
END--创建Return返回值存储过程
CREATE PROCEDURE PR_Sum2 @a int, @b int
AS
BEGINReturn @a+@b
END--执行存储过程获取output型返回值
declare @mysum int
execute PR_Sum 1,2,@mysum output
print @mysum --执行存储过程获取Return型返回值
declare @mysum2 int
execute @mysum2= PR_Sum2 1,2
print @mysum2八、自定义函数函数的分类:1)标量值函数2)表值函数a:内联表值函数b:多语句表值函数3)系统函数--新建标量值函数
create function FUNC_Sum1
( @a int, @b int
)
returns int
as
beginreturn @a+@b
end--新建内联表值函数
create function FUNC_UserTab_1
( @myId int
)
returns table
as
return (select * from ST_User where ID<@myId) --新建多语句表值函数
create function FUNC_UserTab_2
( @myId int
)
returns @t table
( [ID] [int] NOT NULL, [Oid] [int] NOT NULL, [Login] [nvarchar](50) NOT NULL, [Rtx] [nvarchar](4) NOT NULL, [Name] [nvarchar](5) NOT NULL, [Password] [nvarchar](max) NULL, [State] [nvarchar](8) NOT NULL
)
as
begininsert into @t select * from ST_User where ID<@myId return
end--调用表值函数
select * from dbo.FUNC_UserTab_1(15)
--调用标量值函数
declare @s int
set @s=dbo.FUNC_Sum1(100,50)
print @s --删除标量值函数
drop function FUNC_Sum1
谈谈自定义函数与存储过程的区别:一、自定义函数:1. 可以返回表变量2. 限制颇多,包括不能使用output参数;不能用临时表;函数内部的操作不能影响到外部环境;不能通过select返回结果集;不能update,delete,数据库表;3. 必须return 一个标量值或表变量自定义函数一般用在复用度高,功能简单单一,争对性强的地方。二、存储过程1. 不能返回表变量2. 限制少,可以执行对数据库表的操作,可以返回数据集3. 可以return一个标量值,也可以省略return存储过程一般用在实现复杂的功能,数据操纵方面。

转载于:https://www.cnblogs.com/heshouhui/p/9922528.html

SQLSERVER存储过程基本语法使用相关推荐

  1. SQLSERVER存储过程基本语法

    一.定义变量 --简单赋值 declare @a int set @a=5 print @a   --使用select语句赋值 declare @user1 nvarchar(50) select @ ...

  2. sqlserver 存储过程 转oracle存储过程,SqlServer存储过程转换成Oracle储存过程语法常见问题...

    1. top order by 转换成 rownum order by 的问题 (子查询实现) 同级情况下的优先处理顺序: sqlserver: 先order by 再top oracle: 先row ...

  3. oracle 存储过程基本语法

    oracle 存储过程基本语法 分类: Oracle 存储过程如同一门程序设计语言,同样包含了数据类型.流程控制.输入和输出和它自己的函数库. --------------------基本语法---- ...

  4. 如何调试oracle,sqlserver存储过程

    调试oracle存储过程 环境: win2003 server + oracle9i + pl/sql developer 7 调试方法: 1 在pl/sql developer 里右击要调试的存储过 ...

  5. SQLServer:存储过程

    SQLSERVER存储过程使用说明书 Ø 引言 首先介绍一下什么是存储过程: 存储过程就是将常用的或很复杂的工作,预先用SQL语句写好并用一个指定的名称存储起来,并且这样的语句是放在数据库中的,还可以 ...

  6. 网络工作室暑假后第二次培训资料(SQLServer存储过程和ADO.NET访问存储过程)整理(一)...

    因为昨天我的SQL Server 2008数据库在使用的时候突然就打不开了.而起前天还用它来写T-SQL语句来着.所以很是郁闷啊,到网上查询以后,不能解决,就干脆重新安装了一边,所以昨天整理的内容不能 ...

  7. PHP写sqlserver事务,php调用sqlserver存储过程使用事务处理

    第一次编写 sqlserver存储过程并在php里调用,把脑瓜都整大了,奋战了一天多最后还是搞定了. 实现功能:在 sqlserver里面实现事务处理,保证数据库操作安全: 接收sqlserver存储 ...

  8. python获取数据库的存储过程_python远程调用sqlserver存储过程记录

    开发中需要python远程调用sqlserver存储过程.搜索了网上有两种方式,pymssql和pyodbc.开始采用第一种方式开发,不过无法拿到存储过程中的返回数据,后采用pyodbc开发,当然存储 ...

  9. java调用存储过程sqlserver_Java调用SqlServer存储过程怎么实现 | 学步园

    在使用Java开发时,经常会遇到调用SqlServer存储过程的问题.下面学步园小编来讲解下Java调用SqlServer存储过程怎么实现? Java调用SqlServer存储过程怎么实现 1.数据库 ...

最新文章

  1. beautiful loss function
  2. 深入理解kestrel的应用
  3. java开发第一天上班_从第一天开始,如何成为一名优秀的团队合作伙伴,成为初级开发人员
  4. 显卡,不能显示问题解决
  5. java 回收器_Java虚拟机-经典垃圾回收器
  6. NEC电影服务器型号,NEC数字电影放映一体机NC2300S-A+详细信息_产品参数_价格_联系方式_DAV数字音视工程网...
  7. 武汉区块链软件技术公司区块链将如何应用于会员生态系统?
  8. 极虎病毒:虎年第一猛毒详解
  9. WebMvcConfigurerAdapter已被废弃的解决方法
  10. 高一数学试题-2022年秋期末试卷
  11. epoll为什么这么快,epoll的实现原理
  12. 【数据处理】格式化数据
  13. Javaweb入职第二天
  14. java调用飞信接口免费短信发送到对方手机
  15. 基于JAVA的医院门诊信息管理系统
  16. android saf写sd卡,使用SAF(存储访问框架)的Android SD卡写权限
  17. 磁场强度和磁感应强度区别
  18. 区块链将是下一个风口,想飞的“猪”都在排队等候
  19. 20200110(已解决)powerdesigner 的一些操作
  20. 3.设计模式之分层思维:为什么要做代码分层架构?

热门文章

  1. 搜索引擎广告过滤Chrome插件
  2. DataBase 之 拉链表结构设计
  3. vb inet 一些方法
  4. VS2010正式版MSDN下载
  5. Swift快速入门之getter 和 setter
  6. 展望2018:WebRTC大规模商用元年
  7. 「hadoop」hadoop启动需要相关的命令(仅供本人使用)
  8. 游标、事务并发和锁三者之间的那点事
  9. GO 语言圣经 -在线阅读
  10. elasticsearch分布式搜索配置文件详解