MYSQL的几种插入方式

MYSQL的几种插入方式

先创建insert_table表
在这里插入图片描述

1.普通插入语句

insert into insert_table((operation,game_id,date,total_amount) VALUES("强化阿波菲斯魔剑",10086,NOW(),114514))

这个就不多说了应该是大家最常用的插入语句

2.插入或更新

INSERT INTO insert_table(operation,game_id,DATE,total_amount) VALUES("强化阿波菲斯魔剑",10086,NOW(),114514)
ON DUPLICATE KEY UPDATE total_amount = total_amount + 114514,DATE = NOW()

连续执行两次过后
mysql> select * from insert_table;
+------------------+---------+---------------------+--------------+
| operation        | game_id | date                | total_amount |
+------------------+---------+---------------------+--------------+
| 强化阿波菲斯魔剑    |   10086 | 2021-09-09 12:17:57 |       229028 |
+------------------+---------+---------------------+--------------+
1 row in set (0.00 sec)

发现total_amount 添加了两次但是数据列只有一行

注意,“...ON DUPLICATE KEY UPDATE”语句是基于唯一索引或主键来判断唯一的

因为我们已经设置了game_id为唯一主键 如果我们更改主键就会普通插入一条新的数据而不是更新已有的game_id行的数据

3.插入或者替换

REPLACE INTO insert_table(operation,game_id,DATE,total_amount) VALUES("强化阿波菲斯魔剑第二次",10087,NOW(),1919810)

第一次强化成功后我们换条语句并更换game_id 10087来继续强化,执行第一次的结果是
mysql> select * from insert_table;
+------------------------+---------+---------------------+--------------+
| operation              | game_id | date                | total_amount |
+------------------------+---------+---------------------+--------------+
| 强化阿波菲斯魔剑          |   10086 | 2021-09-09 12:17:57 |       229028 |
| 强化阿波菲斯魔剑第二次     |   10087 | 2021-09-09 12:32:00 |      1919810 |
+------------------------+---------+---------------------+--------------+
2 rows in set (0.03 sec)
我们在第二次的基础上进行强化肯定要加钱啊,不加钱谁干啊

输入
REPLACE INTO insert_table(operation,game_id,DATE,total_amount) VALUES("强化阿波菲斯魔剑第三次",10087,NOW(),2000000)
得出结果
mysql> select * from insert_table;
+------------------------+---------+---------------------+--------------+
| operation              | game_id | date                | total_amount |
+------------------------+---------+---------------------+--------------+
| 强化阿波菲斯魔剑          |   10086 | 2021-09-09 12:17:57 |       229028 |
| 强化阿波菲斯魔剑第三次     |   10087 | 2021-09-09 12:36:11 |      2000000 |
+------------------------+---------+---------------------+--------------+

第三次的强化把二次的强化覆盖掉了 钱也变成了2000000

可见REPLACE INTO 在主键唯一ID不存在的时候(基于唯一索引或主键来判断唯一的)会插入新的语句 否则就在原有的语句进行更新(实际上也是删除旧的语句再添加新的语句)

4.插入或者忽略

INSERT IGNORE INTO insert_table(operation,game_id,DATE,total_amount) VALUES("强化阿波菲斯魔剑第四次",10087,NOW(),3000000)

接下换个语句强化第四次,用的依然是已存在的10087id

mysql> select * from insert_table;
+------------------------+---------+---------------------+--------------+
| operation              | game_id | date                | total_amount |
+------------------------+---------+---------------------+--------------+
| 强化阿波菲斯魔剑          |   10086 | 2021-09-09 12:17:57 |       229028 |
| 强化阿波菲斯魔剑第三次     |   10087 | 2021-09-09 12:36:11 |      2000000 |
+------------------------+---------+---------------------+--------------+

第四次的强化竟然没显示出来 ,很明显就是强化失败了,那我们换个唯一主键索引id———》10088来强化吧

INSERT IGNORE INTO insert_table(operation,game_id,DATE,total_amount) VALUES("强化阿波菲斯魔剑第四次",10088,NOW(),3000000)

mysql> select * from insert_table;
+------------------------+---------+---------------------+--------------+
| operation              | game_id | date                | total_amount |
+------------------------+---------+---------------------+--------------+
| 强化阿波菲斯魔剑          |   10086 | 2021-09-09 12:17:57 |       229028 |
| 强化阿波菲斯魔剑第三次     |   10087 | 2021-09-09 12:36:11 |      2000000 |
| 强化阿波菲斯魔剑第四次     |   10088 | 2021-09-09 12:47:08 |      3000000 |
+------------------------+---------+---------------------+--------------+
3 rows in set (0.03 sec)

喔 谢谢凯莉奶奶 强化成功了 
“INSERT IGNORE INTO” 语句 对已存在的唯一索引或主键会失效即不执行,如果唯一索引或主键不存在就会插入一条信息

(0.03 sec)

喔 谢谢凯莉奶奶 强化成功了 
“INSERT IGNORE INTO” 语句 对已存在的唯一索引或主键会失效即不执行,如果唯一索引或主键不存在就会插入一条信息

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值