这篇文章主要介绍了SQLServer2008下存储过程实现数据插入与更新,需要的朋友可以参考下

存储过程的功能非常强大,在某种程度上甚至可以替代业务逻辑层,

接下来就一个小例子来说明,用存储过程插入或更新语句。

1、数据库表结构

所用数据库为Sql Server2008。

2、创建存储过程

(1)实现功能:1)有相同的数据,直接返回(返回值:0);

2)有主键相同,但是数据不同的数据,进行更新处理(返回值:2);

3)没有数据,进行插入数据处理(返回值:1)。

根据不同的情况设置存储过程的返回值,调用存储过程的时候,根据不同的返回值,进行相关的处理。

(2)下面编码只是实现的基本的功能,具体的Sql代码如下:

 Create proc sp_Insert_Student
   @No char(10),
   @Name varchar(20),
   @Sex char(2),
   @Age int,
   @rtn int output
 as
 declare
   @tmpName varchar(20),
  @tmpSex char(2),
  @tmpAge int
  
  if exists(select * from Student where [email protected])
    begin
      select @tmpName=Name,@tmpSex=Sex,@tmpAge=Age from Student where [email protected]
      if ((@[email protected]) and (@[email protected]) and (@[email protected]))
        begin
          set @rtn=0  --有相同的数据,直接返回值
        end
      else
        begin
          update Student set [email protected],[email protected],[email protected] where [email protected]
          set @rtn=2  --有主键相同的数据,进行更新处理
        end
    end
  else
    begin
      insert into Student values(@No,@Name,@Sex,@Age)
      set @rtn=1  --没有相同的数据,进行插入处理
    end

3、调用存储过程

这里在Sql Server环境中简单的实现了调用,在程序中调用也很方便。

具体的代码如下:

 declare @rtn int
 exec sp_Insert_Student '1101','张三','男',23,@rtn output
 
 if @rtn=0
   print '已经存在相同的。'
 else if @rtn=1
   print '插入成功。'
 else
   print '更新成功'

一个存储过程就实现了3中情况,而且效率很高,使用灵活。 希望对大家有所帮助。

最新资讯
豆瓣动态恢复正常 此前称“功能正在升级”

豆瓣动态恢复正常 此

豆瓣动态目前恢复正常,用户已经可以正常查看所关注用户
滴滴自动驾驶或将于年底落地上海

滴滴自动驾驶或将于年

目前,滴滴已经在上海取得自动驾驶路测牌照,前期预计将投
FB被指滥用面部识别数据 或将面临350亿美元集体诉讼

FB被指滥用面部识别数

据外媒报道,在伊利诺伊州的一场涉及滥用面部识别数据的
结构性存款大变局:支付宝微信京东App代销或终结?

结构性存款大变局:支

根据央行发布数据测算,结构性存款规模在今年2月达到峰
周鸿祎与齐向东分家后再“同框”:“合影纪念下”

周鸿祎与齐向东分家后

第六届世界互联网大会今日开幕。在开幕式环节,360董事
软银寻求通过新投资规避WeWork的债务

软银寻求通过新投资规

据路透社引述知情人士透露,软银集团正试图拿到WeWork的
最新文章
SQL Server 2008数据库分布式查询知识

SQL Server 2008数据

今天小编就为大家分享一篇关于SQL Server 2008数据库
SQL Server 2008数据库设置定期自动备份的方法

SQL Server 2008数据

这篇文章主要给大家介绍了关于SQL Server 2008数据库
sqlserver2008首次登录失败问题及解决方法

sqlserver2008首次登

这篇文章主要介绍了sqlserver2008首次登录失败问题及
解决SQL Server 2008 不能使用 “.” local本地连接数据库问题

解决SQL Server 2008

这篇文章主要介绍了解决SQL Server 2008 不能使用 “.
SQL SERVER 2008 r2 数据压缩的两种方法

SQL SERVER 2008 r2

这篇文章主要介绍了SQL SERVER 2008 r2 数据压缩的两
SQL Server 2008打开输入sa密码提示无法登陆数据库的解决方法

SQL Server 2008打开

与 SQL Server建立连接时出现与网络相关的或特定于实