钦州信息网
时尚
当前位置:首页 > 时尚

轻松接触几个SQL Server数据库的简单示例_0

发布时间:2019-09-13 19:40:17 编辑:笔名

7、查看存储过程的内容:

sp_helptext insert1000teachers

8、采用存储过程实现:根据存储过程中的内容,查找存储过程的名字

create procedure getProcedureByBodyWords@patpro varchar(100),--存储过程中的任意内容@proname varchar(50) --存储过程的部分或者全名,或者为nullasbegin select name from sysobjects where id in (select id from syscomments where text like '%'+@patpro+'%') and name like case when @proname is null then '%' else '%'+@proname+'%' endend

如有存储过程名为insert1000teachers,操作如下可得其全名

exec getProcedureByBodyWords 'insert','insert1000'

9、采用触发器备份数据表中的数据:

建立测试数据表:

一个用于插入数据,test3

另一个作为备份,test3_bak

create table test3(id int primary key not null identity(1,1),uname varchar(20),uage int);create table test3_bak(id int primary key not null identity(1,1),bid int,uname varchar(20),uage int,active char(1));

编写备份用的触发器,只有更新或者是插入的时候才触发

alter trigger test3_bak_insert_updateon test3for insert,updateas declare @id int declare @uname varchar(20) declare @uage intbegin select @id=id,@uname=uname,@uage=uage from inserted if @id<>0 begin update test3_bak set active='0' where bid=@id insert into test3_bak(bid,uname,uage,active) values(@id,@uname,@uage,'1') endend

测试数据:

insert into test3(uname,uage) values('FLB',20)insert into test3(uname,uage) values('FLB1',21)insert into test3(uname,uage) values('FLB2',22)update test3 set uage=100 where id=27delete from test3 where id=20

大家可自己采用下面的查询踪两个表的数据变化:

select * from test3select * from test3_bak

孩子不消化怎么办
孩子消化不良小妙招
尿路结石腹部疼痛怎么办
宝宝消化不良怎么止吐