mysql delete返回值_Mybatis执行sql(insert、update、delete)返回值问题

数据库:Mysql

在使用mybatis的过程中对执行sql的返回值产生疑问,顺手记录一下。

结论:

insert:   插入n条记录,返回影响行数n。(n>=1,n为0时实际为插入失败)

update:更新n条记录,返回影响行数n。(n>=0)

delete: 删除n条记录,返回影响行数n。(n>=0)

验证:

插入多条数据,mysql中可以使用如下sql:

insert into bill (TX_TYP,REMARK,NO) VALUES (?,?,?) , (?,?,?) , (?,?,?) ;

而对oracle的操作略有不同(两种方式 以及对应的mapper配置):

INSERT INTO BILL(NO,TX_TYP,REMARK) (SELECT ?,?,? FROM dual) UNION ALL (SELECT ?,?,? FROMdual);--或者

INSERT ALL INTO bill(NO,TX_TYP,REMARK) values ( ?,?,? ) INTO bill(NO,TX_TYP,REMARK) values ( ?,?,? ) SELECT 1 FROM dual;

insert into bill (TX_TYP,REMARK,NO)(SELECT #{bill.txTyp},#{bill.remark},#{bill.no} from dual)

insert ALLinto bill (TX_TYP,REMARK,NO) values

(#{bill.txTyp},#{bill.remark},#{bill.no})select 1 from dual

为了更直观的查看sql运行情况,在mybatis-config.xml中配置加一个setting配置,将执行的sql打印到控制台。

定义实体类Bill,属性no,txTyp,remark,其中no为mysql数据库表bill自增主键。

Mapper接口

//单条插入

intadd(Bill bill);//多条插入

intmulAdd(List list);//更新

intupt(Bill bill);//删除

int del(Bill bill);

Mapper.xml

insert into bill(TX_TYP,REMARK) values(#{txTyp},#{remark})

insert into bill (TX_TYP,REMARK,NO) VALUES(#{bill.txTyp},#{bill.remark},#{bill.no})

update bill set REMARK=#{remark} where NO=#{no}

delete from bill where TX_TYP=#{txTyp}

开始测试:

①插入单条记录:

@Testpublic voidadd(){

Bill bill=newBill();

bill.setTxTyp("1");

bill.setRemark("试试影响行数");

System.out.println(billMapper.add(bill));

}

sql执行结果与返回值:成功插入一条数据,返回影响行数:1。

8c1d354a49c96a180f63a07cd18c6d9f.png

②插入多条记录

@Test //测试一次性插入多条记录

public voidmulAdd(){

List list=new ArrayList();

Bill bill1=newBill();

bill1.setTxTyp("1");

bill1.setRemark("bill1");

Bill bill2=newBill();

bill2.setTxTyp("1");

bill2.setRemark("bill2");

Bill bill3=newBill();

bill3.setTxTyp("1");

bill3.setRemark("bill3");

list.add(bill1);

list.add(bill2);

list.add(bill3);

System.out.println(billMapper.mulAdd(list));

}

sql执行结果与返回值:成功插入三条数据,返回影响行数:3。

28da5deca46ed3b99d1f3deaf1c02794.png

插入多条记录时,如果有记录主键冲突,则sql执行出错,抛出异常,此时未成功插入记录。

0ab0a9012a9128cec9a6ab276377214a.png

③更新语句

@Test //根据no进行更新

public voidupt(){

Bill bill=newBill();

bill.setTxTyp("1");

bill.setRemark("修改一下");

bill.setNo(1);

System.out.println(billMapper.upt(bill));

}

sql执行结果与返回值:根据NO字段进行更新,数据库表中没有NO=1的行,返回影响行数:0。修改成表中有的值后,成功返回影响行数。

719d09d34741ea7f5754d6c6709f7beb.png

④删除语句

@Test //根据txTyp进行删除

public voiddel(){

Bill bill=newBill();

bill.setTxTyp("1");

System.out.println(billMapper.del(bill));

}

sql执行结果与返回值:先将txTyp设置成数据库中没有的值txTyp=a,执行后返回影响行数为0;设置为有4条记录的txTyp=1,执行后返回影响结果为4,成功删除4条记录。

e2b59352f172577b71c243c8f4761482.png

797f80991fd96b6e02dfc20b4a100e6e.png

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值