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” 语句 对已存在的唯一索引或主键会失效即不执行,如果唯一索引或主键不存在就会插入一条信息
|