oracl如果存在记录更新否则插入新纪录

DECLARE
vcount number;
begin
select count(*) into vcount from zhang.test where aname='t' and bname='t';

if vcount=0 then
insert into zhang.test values(3,'t1','t1','t1','t1',50);
else
update zhang.test set abcount= abcount + 80 where aname='t' and bname='t';
end if;
commit;
end;



--创建存储过程
create or replace procedure record_new_order(
rcount in number
)
is
vcount number;
begin
select count(*) into vcount from zhang.test where aname='t' and bname='t';

if vcount=0 then
insert into zhang.test values(3,'t1','t1','t1','t1',rcount);
else
update zhang.test set abcount= abcount + rcount where aname='t' and bname='t';
end if;
end;
--执行存储过程--
begin
record_new_order(10);
end;

	
//调用存储过程
public static void main(String[] args) throws InstantiationException, IllegalAccessException, ClassNotFoundException, SQLException {
Class.forName("oracle.jdbc.driver.OracleDriver");

// DriverManager.registerDriver(new net.sourceforge.jtds.jdbc.Driver());
String dbUrl = "jdbc:oracle:thin:@127.0.0.1:1521:orcl";
Connection conn = java.sql.DriverManager.getConnection(dbUrl, "zhang", "password");

String sql = "{call record_new_order(?)}";
CallableStatement cs = conn.prepareCall(sql);
cs.setInt(1,10);

// cs.registerOutParameter(20, Types.INTEGER);
cs.execute();
// ResultSet rs = cs.executeQuery();
// int k= rs.getMetaData().getColumnCount();
// System.out.println(cs.getObject(2));
// ResultSet rs = (ResultSet)cs.getObject(2);
// while (rs.next()){
// for (int i=1;i<k+1;i++){
// System.out.print(rs.getObject(i)+"|");
// }
// System.out.println();
//
// }
cs.close();
conn.close();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值