当前位置:网站首页>SQL: DDL, DML, DQL, DCL corresponding introduction and demonstration
SQL: DDL, DML, DQL, DCL corresponding introduction and demonstration
2022-08-02 03:53:00 【cierxiao】
#博学谷IT学习技术支持#
文章目录
SQL分类
DDL:数据定义语言
DDL:操作数据库
DDL(Data Definition Language) : 数据定义语言,用来定义数据库对象:数据库,表,列等
查询
- 查询所有的数据库
SHOW DATABASES;
上述查询到的是的这些数据库是mysql安装好自带的数据库,我们以后不要操作这些数据库.
创建数据库
- 创建数据库:
CREATE DATABASE 数据库名称;
而在创建数据库的时候,我并不知道db1数据库有没有创建,直接再次创建名为db1的数据库就会出现错误.
为了避免上面的错误,在创建数据库的时候先做判断,如果不存在再创建.
- 创建数据库(判断,如果不存在则创建)
CREATE DATABASE IF NOT EXISTS 数据库名称;
- Create a database and set it uputf8编码
格式:
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:The data query language part contains more content,I've written a more detailed article to introduce and demonstrate the case,点击DQL即可查看
DCL:数据控制语言
DCL(Data Control Language) 数据控制语言,用来定义数据库的访问权限和安全级别,及创建用户
DCL简单理解就是对数据库进行权限控制.比如我让某一个数据库表只能让某一个用户进行操作等.
总结
本篇文章内容主要介绍了 SQL语句,通过SQL语句对数据库、表、数据进行增删改查操作,attached the relevantSQLThe case statement of the statement,可以极大程度地帮助我们掌握SQL语句的用法,并根据用法逻辑判断出相应的应用情景,更有效率地帮助我们进行开发.
好啦!本篇文章到这里就结束啦!大家好好练习便能运用自如,每一天都要加油呀!!!
🥰 🥰 🥰你的点赞是对我最大的鼓励.🥰 🥰 🥰
🥰 🥰 🥰你的收藏是对我文章的认可.️🥰 🥰 🥰
🥰 🥰 🥰你的关注是对我前进的动力.🥰 🥰 🥰
边栏推荐
猜你喜欢
随机推荐
URL module
js预编译 GO 和AO
js basics
项目中遇到的问题
6.27面试集
4.PHP数组与数组排序
js eventLoop 事件循环机制
宝塔邮局邮箱设置成功后能发送不能接收问题处理
批量替换文件字体,简体->繁体
骨架效果 之高级渐变,适用图片等待时
docker中配置mysql 5.7
PHP图片压缩到指定的大小
Common methods of js array deduplication
2.PHP变量、输出、EOF、条件语句
PHP8.2的版本发布管理员和发布计划
[league/climate]一个功能健全的命令行功能操作库
PHP8.2将会有哪些新东西?
每日五道面试题总结 22/7/21
面试总结 22/7/25 面试中的重点
阿里云服务器如何使用admin账户登录