MySQL设置独写分离,在代码中按照如下写法,可能会出现问题

// 先录入this.insert(obj); // 再查询Object res = this.selectById(obj.getId());res: null;

补充知识:MySQL INSERT插入条件判断:如果不存在则插入

我们经常需要进行sql的批量插入,要求:该条记录不存在则插入,存在则不插入。如果使用一条INSERT语句实现呢?

对于普通的 INSERT 插入,如果想要保证不插入重复记录,我们只有对某个字段创建唯一约束实现;

那有没有不创建唯一约束,仅通过 INSERT INTO 一条语句实现的方案呢?

答:使用 INSERT INTO IF EXISTS, 具体语法如下

INSERT INTO table(field1, field2, fieldn) SELECT 'field1', 'field2', 'fieldn' FROM DUALWHERE NOT EXISTS(SELECT field FROM table WHERE field = ?)
INSERT INTO a (order_id, operator, oper_date, memo) SELECT '3', 'onion3', '2017-11-28', '测试3' from DUAL where not exists(select order_id from a where operator='onion3' and memo = '测试3'); 

更多相关文章

  1. Linux下MYSQL 5.7 找回root密码的问题(亲测可用)
  2. Android(安卓)10 定位问题,获取NMEA(支持5.0~10.0)
  3. mybatisplus的坑 insert标签insert into select无参数问题的解决
  4. python起点网月票榜字体反爬案例
  5. 《Android开发从零开始》——25.数据存储(4)
  6. Android系统配置数据库注释(settings.db)
  7. Android中不同应用间实现SharedPreferences数据共享
  8. 关于Android(安卓)Studio3.2新建项目Android(安卓)resource link
  9. Android软键盘适配问题

随机推荐

  1. Android之Android的数据存储--File
  2. android IPC及原理简介
  3. Android 中的WiFi学习笔记
  4. GridLayout 网格布局
  5. Android7.0 MTK方案 静默安装和卸载
  6. android 焦点问题
  7. android用DroidDraw实现可视化UI编程
  8. Android 如何保持横竖屏切换不变以及Frag
  9. Android自适应拉伸图片
  10. Android(安卓): 控制图片如何resized/mov