如何在存储过程中实现插入更新数据

如何在存储过程中实现插入更新数据,第1张

--先在数据库中创建test表,表中有列名为name,类型为varchar(50)

然后先执行

create procedure proc_insert

@name varchar(50)

as

begin

insert into test values(@name)--插入数据

end

go

create procedure proc_update

@newname varchar(50),@oldname varchar(50)

as

begin

update test set name=@newname where name=@oldname--更新数据

end

go

--其中proc_insert为存储过程名,可自定义 procedure可使用简写proc

上面执行完成后调用存储过程

exec proc_insert '晓华'--将"晓华"添加到test表中

exec proc_update '小明','晓华' --将表中'晓华' 改为'小明',必须与存储过程变量顺序相同

exec proc_update @oldname='小明',@newname='晓华'--与存储过程变量顺序可以不同

drop procedure proc_insert 删除存储过程proc_insert

Oracle增量更新有两种方式:1、日志方式的记录,由RMAN设置增量方式完成更新;2、由SQL语句实现更新。

你的“job+存储过程”的实现应该是SQL语句方式,应该完成:去重-插入两个动作。

一、使用Update 语句Update 语句用于修改表中的数据。语法:UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值 Person: 如:有下表LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilson Champs-Elysees 例:更新某一行中的一个列 我们为 lastname 是 "Wilson" 的人添加 firstname:UPDATE Person SET FirstName = 'Fred' WHERE LastName = 'Wilson' 结果: LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilsonFredChamps-Elysees 更新某一行中的若干列 我们会修改地址(address),并添加城市名称(city):UPDATE Person SET Address = 'Zhongshan 23', City = 'Nanjing' WHERE LastName = 'Wilson' 结果: LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilsonFredZhongshan 23Nanjing 通过以上语句,可以在程序中执行 UPDATE语句即可更新数据库。当然,前提是根据你开发语言环境,使用编程语言连接好数据库,引用相应的对象和定义好相关的变量。 二、通过存储过程如果你的数据库是SQL2000 或者是2005,可以在DBMS中写存储过程,在程序中调用存储过程,传递参数进行更新即可。具体可以BAIDU一下,我就不去找了。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9934798.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存