当前位置:网站首页>SQL:DDL、DML、DQL、DCL相应介绍以及演示
SQL:DDL、DML、DQL、DCL相应介绍以及演示
2022-08-02 03:24:00 【cierxiao】
#博学谷IT学习技术支持#
文章目录
SQL分类
DDL:数据定义语言
DDL:操作数据库
DDL(Data Definition Language) : 数据定义语言,用来定义数据库对象:数据库,表,列等
查询
- 查询所有的数据库
SHOW DATABASES;
上述查询到的是的这些数据库是mysql安装好自带的数据库,我们以后不要操作这些数据库。
创建数据库
- 创建数据库:
CREATE DATABASE 数据库名称;
而在创建数据库的时候,我并不知道db1数据库有没有创建,直接再次创建名为db1的数据库就会出现错误。
为了避免上面的错误,在创建数据库的时候先做判断,如果不存在再创建。
- 创建数据库(判断,如果不存在则创建)
CREATE DATABASE IF NOT EXISTS 数据库名称;
- 创建数据库并设置utf8编码
格式:
create database 数据库名;
create database 数据库名 character set 字符集;
例如:
#创建数据库 数据库中数据的编码采用的是安装数据库时指定的默认编码 utf-8
CREATE DATABASE webdb_1;
#创建数据库 并指定数据库中数据的编码
CREATE DATABASE webdb_2 CHARACTER SET utf-8;
删除数据库
- 删除数据库
DROP DATABASE 数据库名称;
- 删除数据库(判断,如果存在则删除)
DROP DATABASE IF EXISTS 数据库名称;
使用数据库
数据库创建好了,要在数据库中创建表,得先明确在哪儿个数据库中操作,此时就需要使用数据库。
- 使用数据库
USE 数据库名称;
- 查看当前使用的数据库
SELECT DATABASE();
DDL:操作表
操作表也就是对表进行增(Create)删(Retrieve)改(Update)查(Delete)。
查询表
- 查询当前数据库下所有表名称
SHOW TABLES;
- 查询表结构
DESC 表名称;
创建表
- 创建表
CREATE TABLE 表名 (
字段名1 数据类型1,
字段名2 数据类型2,
…
字段名n 数据类型n
);
注意:最后一行末尾,不能加逗号
数据类型
MySQL 支持多种类型,可以分为三类:
数值
tinyint : 小整数型,占一个字节 int : 大整数类型,占四个字节 eg : age int double : 浮点类型 使用格式: 字段名 double(总长度,小数点后保留的位数) eg : score double(5,2)
日期
date : 日期值。只包含年月日 eg :birthday date : datetime : 混合日期和时间值。包含年月日时分秒
字符串
char : 定长字符串。 优点:存储性能高 缺点:浪费空间 eg : name char(10) 如果存储的数据字符个数不足10个,也会占10个的空间 varchar : 变长字符串。 优点:节约空间 缺点:存储性能底 eg : name varchar(10) 如果存储的数据字符个数不足10个,那就数据字符个数是几就占几个的空间
注意:其他类型参考资料中的《MySQL数据类型].xlsx》
删除表
- 删除表
DROP TABLE 表名;
- 删除表时判断表是否存在
DROP TABLE IF EXISTS 表名;
修改表
- 修改表名
ALTER TABLE 表名 RENAME TO 新的表名;
-- 将表名student修改为stu
alter table student rename to stu;
- 添加一列
ALTER TABLE 表名 ADD 列名 数据类型;
-- 给stu表添加一列address,该字段类型是varchar(50)
alter table stu add address varchar(50);
- 修改数据类型
ALTER TABLE 表名 MODIFY 列名 新数据类型;
-- 将stu表中的address字段的类型改为 char(50)
alter table stu modify address char(50);
- 修改列名和数据类型
ALTER TABLE 表名 CHANGE 列名 新列名 新数据类型;
-- 将stu表中的address字段名改为 addr,类型改为varchar(50)
alter table stu change address addr varchar(50);
- 删除列
ALTER TABLE 表名 DROP 列名;
-- 将stu表中的addr字段 删除
alter table stu drop addr;
DML:数据操作语言
DML(Data Manipulation Language) 数据操作语言,用来对数据库中表的数据进行增删改
DML主要是对数据进行增(insert)删(delete)改(update)操作。
添加数据
- 给指定列添加数据
INSERT INTO 表名(列名1,列名2,…) VALUES(值1,值2,…);
- 给全部列添加数据
INSERT INTO 表名 VALUES(值1,值2,…);
- 批量添加数据
INSERT INTO 表名(列名1,列名2,…) VALUES(值1,值2,…),(值1,值2,…),(值1,值2,…)…;
INSERT INTO 表名 VALUES(值1,值2,…),(值1,值2,…),(值1,值2,…)…;
- 案例
-- 给指定列添加数据
INSERT INTO stu (id, NAME) VALUES (1, '张三');
-- 给所有列添加数据,列名的列表可以省略的
INSERT INTO stu (id,NAME,sex,birthday,score,email,tel,STATUS) VALUES (2,'李四','男','1999-11-11',88.88,'[email protected]','13888888888',1);
INSERT INTO stu VALUES (2,'李四','男','1999-11-11',88.88,'[email protected]','13888888888',1);
-- 批量添加数据
INSERT INTO stu VALUES
(2,'李四','男','1999-11-11',88.88,'[email protected]','13888888888',1),
(2,'李四','男','1999-11-11',88.88,'[email protected]','13888888888',1),
(2,'李四','男','1999-11-11',88.88,'[email protected]','13888888888',1);
修改数据
- 修改表数据
UPDATE 表名 SET 列名1=值1,列名2=值2,… [WHERE 条件] ;
注意:
- 修改语句中如果不加条件,则将所有数据都修改!
- 像上面的语句中的中括号,表示在写sql语句中可以省略这部分
案例
将张三的性别改为女
update stu set sex = '女' where name = '张三';
将张三的生日改为 1999-12-12 分数改为99.99
update stu set birthday = '1999-12-12', score = 99.99 where name = '张三';
注意:如果update语句没有加where条件,则会将表中所有数据全部修改!
update stu set sex = '女';
删除数据
- 删除数据
DELETE FROM 表名 [WHERE 条件] ;
- 案例
-- 删除张三记录
delete from stu where name = '张三';
-- 删除stu表中所有的数据
delete from stu;
DQL:数据查询语言
DQL(Data Query Language) 数据查询语言,用来查询数据库中表的记录(数据)
DQL简单理解就是对数据进行查询操作。从数据库表中查询到我们想要的数据。
DQL
DQL:数据查询语言部分内容比较多,我已经另起一篇更加详细的文章介绍并演示案例,点击DQL即可查看
DCL:数据控制语言
DCL(Data Control Language) 数据控制语言,用来定义数据库的访问权限和安全级别,及创建用户
DCL简单理解就是对数据库进行权限控制。比如我让某一个数据库表只能让某一个用户进行操作等。
总结
本篇文章内容主要介绍了 SQL语句,通过SQL语句对数据库、表、数据进行增删改查操作,附加了相关的SQL语句的案例语句,可以极大程度地帮助我们掌握SQL语句的用法,并根据用法逻辑判断出相应的应用情景,更有效率地帮助我们进行开发。
好啦!本篇文章到这里就结束啦!大家好好练习便能运用自如,每一天都要加油呀!!!
🥰 🥰 🥰你的点赞是对我最大的鼓励。🥰 🥰 🥰
🥰 🥰 🥰你的收藏是对我文章的认可。️🥰 🥰 🥰
🥰 🥰 🥰你的关注是对我前进的动力。🥰 🥰 🥰
边栏推荐
猜你喜欢
随机推荐
5.20今日学习
---static page---
URL模块
1.10今日学习
项目中遇到的问题
6.24今日学习
枚举法方法:(leetcode1300)转变数组后最接近目标值的数组和
Scientific research reagent DMPE-PEG-Mal dimyristoylphosphatidylethanolamine-polyethylene glycol-maleimide
C语言 0长度数组/柔性数组
相对路径和绝对路径
1.8今日学习
如何根据地图上的两个坐标点来确定方向
正则笔记(1)- 正则表达式字符匹配攻略
第一次手撕代码,如何解出全排列问题
Circular linked list---------Joseph problem
C语言 内联函数
canvas--pie chart
Relative and absolute paths
--fs模块--
小程序 van-cell 换行能左对齐问题