MySQL学习(二) dml语言和ddl语言

DML 语言

DML语言 即 (data manager language) 管理数据

插入

insert into xxx()
value()
or
set xx=xx

一、方式一
语法:
insert into 表名(字段名,…) values(值,…);
特点:
1、要求值的类型和字段的类型要一致或兼容
2、字段的个数和顺序不一定与原始表中的字段个数和顺序一致
但必须保证值和字段一一对应
3、假如表中有可以为null的字段,注意可以通过以下两种方式插入null值
①字段和值都省略
②字段写上,值使用null
4、字段和值的个数必须一致
5、字段名可以省略,默认所有列

二、方式二
语法:
insert into 表名 set 字段=值,字段=值,…;

两种方式 的区别:
1.方式一支持一次插入多行,语法如下:
insert into 表名【(字段名,…)】 values(值,…),(值,…),…;
2.方式一支持子查询,语法如下:
insert into 表名
查询语句;

修改

一、修改单表的记录 ★
语法:update 表名 set 字段=值,字段=值 【where 筛选条件】;

二、修改多表的记录【补充】
语法:
update 表1 别名
left|right|inner join 表2 别名
on 连接条件
set 字段=值,字段=值
【where 筛选条件】;

删除

方式一:使用delete
一、删除单表的记录★
语法:delete from 表名 【where 筛选条件】【limit 条目数】
二、级联删除[补充]
语法:
delete 别名1,别名2 from 表1 别名
inner|left|right join 表2 别名
on 连接条件
【where 筛选条件】

方式二:使用truncate
语法:truncate table 表名

两种方式的区别【面试题】★

1.truncate删除后,如果再插入,标识列从1开始
delete删除后,如果再插入,标识列从断点开始
2.delete可以添加筛选条件
truncate不可以添加筛选条件
3.truncate效率较高
4.truncate没有返回值
delete可以返回受影响的行数
5.truncate不可以回滚
delete可以回滚

DDL 语言

ddl 即数据定义语言 (data define language)

库的管理

  1. 创建库
create database (if not exists)XXX(库名)  (character set 【字符集名】);

2.修改库

alter database xxx(库名) character set 【字符集名】;

3.删除库

drop database (if exists)xxx(库名);

表的管理

1.创建表

create table xxx(表名)(
			列名1  类型(约束),
			列名2  类型(约束),
			列名3  类型(约束),
);

2.修改表

增加列
alter table xxx(表名) add column xxx(字段名) xxx(字段类型);
修改列名
alter table xxx(表名) change column xxx(字段名)xxx(修改后字段名) xxx(字段类型);
修改类型
alter table 表名 modify column xxx列名  字段类型(约束)
删除列
alter table 表名 drop  column xxx列名 ;

修改表名
alter table 表名 rename to (新表名)

3.删除表

drop table (if exists) (表名)
  1. 复制表
    复制表的结构:
create table xxx like xxx(旧表);

复制内容+结构

create table xxx(表名)
select xxx(字段)
from (旧表)
where (筛选条件)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值