MySQL学习3-1 高级操作

新增数据 多数据插入 只要写一次 insert 指令,但是可以直接插入多条记录.基本语法: insert into 表名[(字段列表)] values(值列表)(值列表)...; 主键冲突 主键冲突,在有的表中,使用的是业务主键(字段有业务含义),但是往往在进行数据插入的时候,又不确定数据表中是否已经存在对应的主键.主键冲突的解决方案:1.主键冲突更新...
摘要由CSDN通过智能技术生成
  • 新增数据

  • 多数据插入

只要写一次 insert 指令,但是可以直接插入多条记录.

基本语法: insert into 表名[(字段列表)] values(值列表)(值列表)...;


  • 主键冲突

主键冲突,在有的表中,使用的是业务主键(字段有业务含义),但是往往在进行数据插入的时候,又不确定数据表中是否已经存在对应的主键.

主键冲突的解决方案:

1.主键冲突更新

类似插入数据语法,如果插入的过程中主键冲突,那么采用更新方法

insert into 表名 [(字段列表)] values(值列表) on duplicate update 字段 = 新值;

-- 冲突更新
insert into my_student values('stu0004','小婷') on duplicate update name = '小婷';

2.主键冲突替换

当主键冲突之后,干掉原来的数据,重新插入进去

Replace into [(字段列表)] values(值列表);


  • 蠕虫复制

蠕虫复制:一分为二,成倍的增加,从已有数据中获取数据,并且将获取到的数据插入到数据表中

基本语法: insert into 表名 [(字段列表)] select */字段列表 from 表;

create table my_simple(
name char(1) not null
)charset utf8;

insert into my_simple values('a'),('b'),('c'),('d');

-- 蠕虫复制
insert into my_simple(name) select name from my_simple;

注意:

1.蠕虫复制的确通常是重复数据,没有太大的业务意义,可以在短期内快速增加表的数据量,从而可以测试表的压力,还可以通过大量数据来测试表的效率(索引).

2.蠕虫复制虽好,但是要注意主键冲突.

  • 更新数据

1.在更新数据的时候,特别要注意:通常一定是跟随条件更新.

Update 表名 set 字段名 = 新值 where 判断条件;

2.如果没有条件,是全表更新数据,但是可以使用 limit 来显示更新的数量;

Update 表名 set 字段名 = 新值 [where 判断条件] limit 数量;

-- 改变4个a变成e

Update my_simple set name = 'e' where name = 'a' limilt 4;


  • 删除数据

1.删除数据的时候尽量不要全部删除,应该使用 where 进行判定

2.删除数据的时候可以使用 limit 来限制要删除的具体数量

Delete 删除数据的时候无法重置 auto_increment

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值