MySQL——DML数据增、删、改
2024-09-08 09:38:51
插入
方式一(经典)
语法:
insert into 表名(列名,...) values(值,...);
若要一次插入多行
create table if NOT EXISTS user(
name VARCHAR(20),
sex VARCHAR(2),
age INT
)
INSERT INTO `user` VALUES('丸子','male',23),('莉香','female',22)
【说明】
- 要求值的类型和字段的类型一致或兼容
- 字段的个数和顺序可以与原始表中的字段个数和顺序不一致,但必须保证值和字段的类型一一对应
- 假如表中有可以为null的字段,可以通过以下两种方式插入null值
①字段和值都省略
②字段写上,值使用null - 字段和值的个数必须一致
- 字段名可以省略,默认所有列,且顺序与默认顺序相同
- 字符和日期型数据应包含在单引号
方式二
语法:
insert into 表名 set 字段=值,字段=值,...;
两种方式的区别:
- 方式一支持一次插入多行,方式二不支持
- 方式一支持子查询,即从其他表中拷贝数据,方式二不支持
批量插入
批量插入,用的是insert语句的子查询,数据量大的时候提高效率格式:
insert into 表名(字段1,字段2...)
select 字段1,字段2 from 表名
使用insert子查询不仅能够实现简单的将一个表中的数据导出到另外一个表中的功能,还能在插入目标表之前对数据进行处理
修改
修改单表的记录 (重点)
update 表名 set 字段=值,字段=值 where 筛选条件;
修改多表的记录【补充】
update 表1 别名
left|right|inner join 表2 别名
on 连接条件
set 字段=值,字段=值
where 筛选条件;
案例
#修改张无忌的女朋友的手机号为114
UPDATE boys bo
INNER JOIN beauty b ON bo.id=b.boyfriend_id
SET b.phone='119',bo.userCP=1000
WHERE bo.boyName='张无忌';
删除
方式一:delete
删除单表的记录★
语法:
delete from 表名 where 筛选条件 limit 条目数
注意:使用 WHERE 子句 删除指定的记录。如果省略 WHERE 子句,则表中的全部数据将被删除
多表级联删除[补充]
语法:
delete 别名1,别名2 from 表1 别名
inner|left|right join 表2 别名
on 连接条件
where 筛选条件
方式二:truncate
语法:
truncate table 表名
两种方式的区别【面试题】★
- truncate删除后,如果再插入,标识列从1开始; delete删除后,如果再插入,标识列从断点开始
- delete可以添加筛选条件,truncate不可以添加筛选条件
- truncate效率较高
- truncate没有返回值,delete可以返回受影响的行数
- truncate不可以回滚,delete可以回滚
最新文章
- Android 横竖屏切换小结
- 【架构】How To Use HAProxy to Set Up MySQL Load Balancing
- minicom使用
- linux下IPTABLES配置详解
- 20145103《java程序设计》第五周学习总结
- Encapsulating Data
- php-工厂模式(转)
- 查看目标文件是否是以-fPIC编译的, ar 打包命令将多个静态库打包到一个里面
- js/css 检测移动设备方向的变化 判断横竖屏幕
- switch函数——Gevent源码分析
- poj 4044 Score Sequence(暴力)
- IE低版本下实现html5的placeholder(表单提示)功能
- Codevs 4189 字典
- 配置FindBugs和常见FindBugs错误
- Ubuntu|ython3 :ImportError: cannot import name 'main'
- 20172328 2018-2019《Java软件结构与数据结构》第七周学习总结
- MySQL_ALTER命令
- 【转】http的keep-alive和tcp的keepalive区别
- 音响理论基础入门:Gain(增益)
- Python-Django编程问题汇总
热门文章
- javascript 分时函数 分批次添加DOM节点 timeChunk
- contos 7修改root密码
- thinkphp5.0框架运行机制分享小结
- Consul+Ocelot+Polly在.NetCore中使用(.NET5)-Ocelot+Polly缓存、限流、熔断、降级
- iOS实现XMPP通讯(二)XMPP编程
- 解决VM 与 Device/Credential Guard 不兼容
- 市区择房分析(ArcPy实现)
- InstallScript脚本语言基本知识(一)
- ArcPy数据列表遍历
- React实现组件全屏化