mysql根据条件决定是否插入数据
这个问题其实分两个方面:
1.根据表的主键决定数据是否插入。
2.根据表的非主键决定是否插入。
假设有表DOC_INFO(医生表),联合主键HOS_ID(医院代码),DEPT_CODE(科室代码),DOC_NO(医生代码),非主键字段DOC_NAME医生姓名等。
如果根据HOS_ID和DOC_NAME判断是否插入,则写为(DULE为临时表,不需要定义)
INSERT INTO doc_info SELECT 35,12,’3850′,’车楠’,1,”,”,”,null,”,’2017-09-21 00:00:00′,null,”,”,null,null,null,null,null
FROM DUAL WHERE NOT EXISTS(SELECT 1 FROM doc_info where hos_id=35 and doc_name=’车楠’)
如果根据HOS_ID,DEPT_CODE,DOC_NO判断是否插入,则写为
insert into doc_info VALUES
(35,12,’3850′,’车楠’,1,”,”,”,null,”,’2017-09-21 00:00:00′,
null,”,”,null,null,null,null,null)
ON DUPLICATE KEY UPDATE add_time=’2017-09-21 00:00:00′
区别:
1.根据非主键判断是否插入主要用于插入一些不按文档规范来插入的数据,用于临时补救一些缺少的数据。
2.根据主键判断是否插入主要用于更新表的某些字段的最新状态,用于需要频繁更新字段的时候。
感谢一下技术支持:
https://my.oschina.net/jsan/blog/270161/
http://www.jb51.net/article/39255.htm
欢迎大家阅读《mysql根据条件决议是否插入数据_mysql》,跪求各位点评,by 搞代码