mysql的DDL语言和DML语言

**DDL语言:

操作数据库,表等(创建,删除,修改);**

操作数据库

1:查询

show databases

2:创建

创建数据库

create database 数据库名称

创建数据库,如果不存在就创建

create database if not exists 数据库名称

sql 复制代码
/*创建db1数据库*/
create database db1;
/*创建数据库db2,如果不存在的话*/
create database if not exists db2;m

可以发现已经创建了两个数据库;

3:删除

删除数据库

drop database 数据库名称

删除数据库,如果存在的话

drop database if exists 数据库名称

sql 复制代码
/*删除数据库*/
drop database db1;
/*删除数据库,如果存在的话*/
drop database if exists db2;

可见这两个数据已经被删除

4:使用数据库

查看当前使用的数据库

select database()

sql 复制代码
/*查看当前使用的数据库名称*/
select database();

使用某个数据库

use 数据库名称

sql 复制代码
use db1;

结果可见上图;

操作数据表

查询表

查询当前数据库下所有表的名称

show tables;

查询表结构

desc 表名称

create table 表名(

创建表

字段名1 数据类型1,

字段名2 数据类型2,

字段名n 数据类型n(最后一行不用加,)

) ;
数据类型

|---------|--------------------------------|
| 类型 | 描述 |
| int | 整形 |
| double | 浮点型 |
| varchar | 字符串型 |
| data | 日期类型,格式为yyyy-MM-dd,只有年月日,没有时分秒 |

例子:创建一张学生表,用于存储学生的信息:

sql 复制代码
# 创建表
create table student
(
    id int,#学生id
    name varchar(10),#学生名字#varchar属于可变字符串长度,最大为10
    gender char(1),#学生性别,#char类型是固定长度的字符串 例如 char(2)  存储:'男 ' 会自动补充空格
    birthday date,#学生生日
    score double,#学生分数
    email varchar(64),#学生邮箱
    tel varchar(20),#学生电话
    state int #使用数字来表示,0是正常,1是病假
);

展示表的结构:

sql 复制代码
desc student;

删除表:

删除表

drop table 表名;

删除表,如果存在的话

drop table if exists 表名;

修改表

1修改表名

alter table 表名 rename to 新的表名

2添加一列

alter table 表名 add 列名 数据类型

3修改数据类型

alter table 表名 modify 列名 新数据类型

4修改列名和数据类型

alter table 表名 change 列名 新列名 新数据类型

5删除列

alter table 表名 drop 列名

sql 复制代码
#修改表的名字为stu
alter table student rename to stu;
show tables;
#向表中添加新的一列
alter table stu add marks varchar(100);
desc stu;
#修改表中某一列的类型
alter table stu modify marks char(50);
desc stu;
#修改表中某列的列名和列的类型
alter table stu change marks mymark int;
desc stu;
#删除某个列
alter table stu drop mymark;
desc stu;

**DML语言:

针对数据表中的记录进行增删改操作**

添加

1 向数据表指定列添加数据

insert into 表名(列名1,列名2...) values(值1,值2)

2给全部列添加数据

insert into 表名 values(值1,值2...)

3批量添加数据

insert into 表名(列名1,列名2...) values(值1,值2...),values(值1,值2...)...;

sql 复制代码
#1向表中的指定列添加数据
insert into stu(id,name) values (3,'hhh');#SQL中字符串使用单引号
insert into stu(id,name,gender,birthday,score) values (3,'小何','男','2005-2-1',100.0);
desc stu;
#2向表中的所有列中添加数据
insert into stu values (6,'cc','女','2009-3-1',90.0,'qq@.com','182',1);
#3向表批量添加数据
insert into stu (name,score) values ('ddd',89),('kkk',70);
相关推荐
这个DBA有点耶14 小时前
NULL不是空——数据库里最反直觉的设计,90%新人踩过的坑
数据库·mysql·代码规范
这个DBA有点耶16 小时前
AI写的SQL跑崩了生产库,这锅谁背?
数据库·人工智能·程序员
镜舟科技17 小时前
Databricks 再提 LTAP,AI 时代的数据底座为何重回大一统叙事?
数据库·架构·agent
Databend18 小时前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence21 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
先吃饱再说2 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils2 天前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend2 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶2 天前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung2 天前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql