Mysql Insert Or Update灵活使用

Oracle的计划任务job,每次看job的消息,能看到上次执行时间,下次执行时间,执行了多少次,,,等等信息

可是MySQL的看不到这些信息,通过Navicat只能看到最初的定义信息,看着实在难受,都不知道是否执行了任务.


实际使用中,计划任务执行存储过程,存储过程更新数据

这样来定义存储过程

DELIMITER //
DROP PROCEDURE IF EXISTS p_vehicle_alarm_creator//
CREATE PROCEDURE p_vehicle_alarm_creator() 
BEGIN
INSERT INTO aaa(alarm_id,text) VALUES (-2,'最新执行时间') ON DUPLICATE KEY UPDATE text=VALUES(text);

INSERT INTO aaa(..)
select ... from v_aaa;


INSERT INTO aaa(...)
select ... from v_bbb;

INSERT INTO aaa(alarm_id,text) VALUES (-1,'最新执行完成时间') ON DUPLICATE KEY UPDATE text=VALUES(text);

END//

这样每次执行存储过程,都会记录最新执行时间


-----------------------------------------------------------------------------

下面是参考文章

https://www.cnblogs.com/xing901022/p/6837604.html

有的时候会需要写一段insert的sql,如果主键存在,则update;如果主键不存在,则insert。Mysql中提供了这样的用法:ON DUPLICATE KEY UPDATE。下面就看看它是如何使用的吧!

首先数据库的原始数据如下:

a   b   c
1   b1  c1
2   b2  c2
3   b3  c3

此时如果执行下面的sql就会报错

INSERT INTO test VALUES(1,'b4','c4');

报错信息如下,提示无法重复插入:

1 queries executed, 0 success, 1 errors, 0 warnings

查询:insert into test values(1,'b4','c4')

错误代码: 1062
Duplicate entry '1' for key 'PRIMARY'

执行耗时   : 0 sec
传送时间   : 0 sec
总耗时      : 0.008 sec

这时,就可以使用ON DUPLICATE KEY UPDATE,它的意思是先执行前面的Insert,如果主键重复,则执行后面的UPDATE

INSERT INTO test VALUES (1,'b4','c4') ON DUPLICATE KEY UPDATE b=VALUES(b),c=VALUES(c);

可以把上面的SQL简单的理解为:

select count(1) from test where a=1;

if count(1) > 0

UPDATE test SET b='xxx',c='xxx' WHERE a=1;

执行完,可以看到有两行收到影响(至于为什么两行收到影响,就得研究底层的实现了,可以参考官方文档):

1 queries executed, 1 success, 0 errors, 0 warnings

查询:INSERT INTO test VALUES (1,'b4','c4') ON DUPLICATE KEY UPDATE b=VALUES(b),c=VALUES(c)

共 2 行受到影响

执行耗时   : 0.023 sec
传送时间   : 0 sec
总耗时      : 0.023 sec

执行完,数据就变成下面的样子了:

a   b   c
1   b4  c4
2   b2  c2
3   b3  c3
作者:xingoo 
Github: https://github.com/xinghalo
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

你可能感兴趣的:(mysql)