美文网首页
超详细的mysql总结(基本概念、DDL、DML)

超详细的mysql总结(基本概念、DDL、DML)

作者: 一颗冰淇淋 | 来源:发表于2021-08-15 22:28 被阅读0次

开发中存在着各种数据,比如用户的个人信息、商品详情、购买记录,这些数据都要以一定的方式储存,如果以文本的形式储存,每一次获取都要读取文件,如果信息有修改则需要直接修改文本,大量的数据会需要保存大量的文件,这样不仅不便于操作、维护,还给服务器带来巨大的负担,什么样的方式能够储存大量的数据并且便于修改?答案就是数据库。

关系型数据库以二维数组组成的表结构来储存数据,各表之间可以设置一对一,一对多,多对多的关系,比如用户个人信息的表中id为1的用户,她在xx商品购买记录的表中存在着一条购买商品的数据,通过各种对应关系,能够从不同的维度保存数据,当需要使用的时候,直接根据某些条件下操作数据。

而非关系型数据库,它的存储更为自由,使用 key-value 这样的形式去保存数据,比如在登陆状态后,保存某个用户的姓名、手机号、身份等信息,获取和写入都比较的简单。

image.png

关系型数据库包括mysql、oracle、sql server 等,非关系型数据库包括 MongoDB、Redis等,这里来聊聊mysql。

mysql的语句大致可以分为四类,分别是
DDL(Data Definition Language):数据定义语言,用来对数据库或者表进行:创建、删除、修改等操作,
DML(Data Manipulation Language):数据操作语言,用来对表进行:添加、删除、修改等操作,
DQL(Data Query Language):数据查询语言,用来从数据库中查询记录,
DCL(Data Control Language):数据控制语言 对数据库、表格的权限进行相关访问控制操作。

首先来看对数据库操作,这里有一个编写习惯,通常把sql语句部分大写,数据库名、表名、字段名小写

// 1、展示所有的数据库,即使没有创建任何一个数据库,系统默认也会有四个数据库
SHOW DATABASES;
// 2、选择数据库 mysql
USE mysql;
// 3、显示当前所选择的数据库
SELECT DATABASE();
// 4、如果不存在数据库 studySql 则创建
CREATE DATABASE IF NOT EXISTS `studySql`;
// 5、如果存在数据库 studySql 则删除
DROP DATABASE IF EXISTS `studySql`;
image.png

再来看看对表的操作,比如在项目里,我们需要保存用户的个人资料,那么此时要创建一个用户表,表里面存储着用户的姓名、手机号码、出生年月,以上的这三种字段对应的是不同的类型,姓名需要字符串类型,手机号码需要数字类型,而出生年月需要使用日期类型,通过数据类型来对保存的数据进行限制,那么常见的数据类型有以下几种。

1、字符串类型
char定义固定长度的字符串,长度在0-255之间,varchar定义可变长的字符串,长度在0到65535之间的值,text可存储更大的字符串
2、数字类型
数字分为整数、浮点数、精确到小数点的数
整数类型:INT,
浮点类型:FLOAT,DOUBLE,
精确数字:DECIMAL,NUMERIC
3、日期类型
(1) YEAR,格式如YYYY,只有年份,范围从 1901到2155,和 0000
(2) DATE,格式如YYYY-MM-DD,有年月日,范围从 '1000-01-01' 到 '9999-12-31'
(3) DATATIME,格式如 YYYY-MM-DD hh:mm:ss,有年月日时分秒,范围从 '1970-01-01 00:00:01' 到'2038-01-19 03:14:07'
(4) DATASTAMP / TIMESTAMP,比DATATIME还要精确6位,格式如 YYYY-MM-DD hh:mm:ss.xxxxxx,范围从'1000-01-01 00:00:00.000000'到'9999-12-31 23:59:59.999999'

以上的数据类型用于创建表时对字段进行补充,除了补充之外,还应该对字段有限制,比如用户的手机号码不可重复,用户要添加一个唯一的id值来表示其“身份”,这些限制就是表约束,我们通常有以下几种方式来对表进行约束

1、主键
主键代表唯一的值,如id,主键不可重复,也不可以为空,用字段 PRIMARY KEY 来表示
2、唯一键
不可重复,但允许为空,比如手机号码,用字段UNIQUE来表示
3、AUTO_INCREMENT
当我们没有给某一字段设置值的时候,希望它自动增长,需要数据类型为数字类型
4、NOT NULL
不允许为空
5、DEFAULT
设置默认值
6、外键在下一篇关于DQL的总结中具体说明~

有了以上的概念,我们就可以在数据库中创建一张“用户表”了

CREATE TABLE IF NOT EXISTS `person` (
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(20) ,
    telephone VARCHAR(20) UNIQUE NOT NULL,
    birth TIMESTAMP
)

在这张表里插入、删除、修改一些数据

// 给每一个字段一一对应设置值
INSERT INTO `person` VALUES (9, 'judy', '18877776666', '1998-08-08');
INSERT INTO `person` VALUES (10, 'kiki', '18012345678', '2000-08-10');

// id 可自增、birth设置默认参数
INSERT INTO `person` (name, telephone) VALUES ('alice', '15600000000');

// 修改数据
UPDATE `person` SET NAME = 'xiaoming'  WHERE id = 10;

// 删除元素
DELETE FROM `person` WHERE id = 9;

// 清空表所有内容
DELETE FROM  `person`

// 查询表里所有数据
SELECT * FROM `person`

// 删除表
DROP TABLE IF EXISTS `person`

部分sql语句执行的结果如下图所示

image.png

以上sql语句操作的是表中的数据,如果对于表字段要进行操作,那么可以使用以下方式

// 修改表名(将表名person改为users)
ALTER TABLE `person` RENAME TO `users`;

// 修改表字段(将telephone修改为phone,数据类型为varchar)
ALTER TABLE `users` CHANGE telephone phone VARCHAR(20);

// 修改表数据类型(将birth的类型修改为Data,默认值为当前时间)
ALTER TABLE `users` MODIFY DATATIME DEFAULT CURRENT_TIMESTAMP;

// 增加列 gender
ALTER TABLE `users` ADD gender varchar(10);
ALTER TABLE `user` ADD updateTime TIMESTAMP;

// 删除列
ALTER TABLE `user` DELETE updateTime;

// 查看表结构
DESC `users`
image.png

还有一些sql有可能也会被用到

//  根据表结构创建另外一个表(复制)
CREATE TABLE `user1` LIKE `users`

// 根据另外一个表中的所有内容(不包括表结构), 创建新的表 
CREATE TABLE `user3` AS (SELECT * FROM `user`)

// 查看创建表的sql语句
SHOW CREATE TABLE `users`

以上就是mysql的基本概念以及基本操作,关于 DQL( Data Query Language),数据查询的部分总结在下一篇文章中~

相关文章

  • 超详细的mysql总结(基本概念、DDL、DML)

    开发中存在着各种数据,比如用户的个人信息、商品详情、购买记录,这些数据都要以一定的方式储存,如果以文本的形式储存,...

  • MYSQL学习整理|高级SQL语句

    MYSQL的三种语言: DDL DML DCL DML(data manipulation language): ...

  • MySQL基础——DML语句

    上篇文章我们学习了MySQL基础——DDL语句,这篇文章学习MySQL基础——DML语句。 DML语句 DML英文...

  • MySQL 基础操作

    · MySQL中不分大小写· MySQL中分为DML(数据操作语言) 和 DDL(数据定义语音) DML(数据操作...

  • mysql初涉

    mysql中语句分类 mysql中sql语句分为四种类型,DDL,DQL,DML和DCL。 DDL(数据定义语言)...

  • MySQL中简单的数据操纵语言(DML),数据定义语言(DDL)

    MySQL中简单的数据操纵语言(DML),数据定义语言(DDL)数据操纵语言(DML-Data Manipulat...

  • 数据库(一)

    数据库的基本概念 MySQL数据库软件 SQL DDL:操作数据库、表 客户端图形化工具:SQLYog DML:增...

  • Day02--数据库

    数据库的基本概念: MySQL数据库软件 SQL DDL:操作数据库、表 DML:增删改表中数据 DQL:查询表中的记录

  • MySQL札记10_MySQL四种语言汇总

    本文主要对前面讲到的MySQL四种语言的总结 数据定义语言DDL 数据操作语言DML 数据操作语言DCL 数据查询...

  • Mysql--DDL&DML

    SQL 对大小写不敏感! 可以把 SQL 分为两个部分:数据操作语言 (DML) 和 数据定义语言 (DDL)。 ...

网友评论

      本文标题:超详细的mysql总结(基本概念、DDL、DML)

      本文链接:https://www.haomeiwen.com/subject/tedpbltx.html