科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道轻松接触几个SQL Server数据库的简单示例

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

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

本文将带大家轻松接触几个SQL Server数据库的简单示例。

作者:赛迪网 10611 来源:天新网 2008年3月24日

关键字: SQL Server SQL Mssql 数据库

  • 评论
  • 分享微博
  • 分享邮件

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

sp_helptext insert1000teachers

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

create procedure getProcedureByBodyWords
@patpro varchar(100),--存储过程中的任意内容
@proname varchar(50) --存储过程的部分或者全名,或者为null
as
begin
 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+'%' end
end

如有存储过程名为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_update
on test3
for insert,update
as
 declare @id int
 declare @uname varchar(20)
 declare @uage int
begin
 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') 
 end
end

测试数据:

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=27
delete from test3 where id=20

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

select * from test3
select * from test3_bak
    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章