首頁 >資料庫 >mysql教程 >MySQL學習之DDL、DML及DQL基礎總結

MySQL學習之DDL、DML及DQL基礎總結

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB轉載
2022-05-19 11:58:512438瀏覽

這篇文章為大家帶來了關於mysql的相關知識,其中主要介紹了關於DDL、DML、DQL的相關內容,包括了操作資料表、操作資料庫、簡單查詢資料等等內容,下面一起來看一下,希望對大家有幫助。

MySQL學習之DDL、DML及DQL基礎總結

推薦學習:mysql影片教學

#資料庫相關概念

什麼是資料庫

儲存資料的倉庫。它體現我們電腦中,就是一個軟體或檔案系統。然後把資料都保存這些特殊的檔案中,並且需要使用固定的語言(SQL語言/語句)去操作檔案中的資料。

  • 儲存資料的倉庫,資料是具有組織的進行儲存
  • 英文名稱:DataBase,簡稱DB

資料庫的優點

資料庫是按照特定的格式將資料儲存在檔案中,透過SQL語句可以方便的對大量資料進行操作,資料庫是對大量的資訊進行管理的高效的解決方案。

常見的資料庫

常見的關係型資料庫管理系統

我們開發應用程式的時候,程式中的所有數據,最後都需要保存到專業軟體中。這些專業的保存資料的軟體我們稱為資料庫。我們學習資料庫,並不是學習如何去開發一個資料庫軟體,我們學習的是如何使用資料庫以及資料庫中的資料記錄的操作。而資料庫軟體是由第三方公司研發。

MySQL學習之DDL、DML及DQL基礎總結

  • Oracle:它是Oracle公司的大型關係型資料庫。系統可移植性佳、使用方便、功能強,適用於各大類、中、小、微機環境。它是一種高效率、安全可靠的。但是它是收費的。
  • MYSQL:早期由瑞典一個叫MySQL AB公司開發的,後期被sun公司收購,再後期被Oracle收購。體積小、速度快、整體擁有成本低,尤其是開放原始碼這項特點,一般中小型網站的開發都選擇 MySQL 作為網站資料庫。 MySQL6.x版本也開始收費。
  • DB2 :IBM公司的資料庫產品,收費的。常應用在銀行系統中.
  • SQLServer:MicroSoft 公司收費的中型的資料庫。 C#、.net等語言常使用。
  • SyBase:Sybase公司的。已經淡出歷史舞台。提供了一個非常專業資料建模的工具PowerDesigner。

常用資料庫:Java開發應用程式主要使用的資料庫:MySQL(5.6)、Oracle、DB2。 (原因:開源,免費,功能夠強大,足以應付web開發)

關係型資料庫

在開發軟體的時候,軟體中的資料之間必然會有一定的關係存在。例如商品和客戶之間的關係,一個客戶是可以買多種商品,而一種商品是可以被多個顧客來購買的。

需要把這些資料保存在資料庫中,同時也要維護資料之間的關係,這時就可以直接使用上述的那些資料庫。而上述的所有資料庫都屬於關係型資料庫。

關聯式資料:設計資料庫的時候,需要使用E-R實體關係圖來描述。

E-R 是兩個單字的首字母,E表示Entity實體 R表示Relationship 關係。

  • 1.資料表中的資料之間必然會有一定的關係存在,例如商品與客戶之間的關係,一個客戶是可以買多種商品,而一種商品是可以被多個客戶來購買的。
  • 2.設計資料庫的時候,可以使用ER實體關係圖來描述表格之間的關係,E表示Entity 實體, R表示Relationship 關係
  • 3.實體:可以理解成我們Java程式中的一個物件。例如商品,客戶等都是一個實體物件。在E-R圖中使用 矩形(長方形) 表示。
  • 4.屬性:實體物件中是含有屬性的,例如商品名、價格等。針對一個實體中的屬性,我們稱為這個實體的數據,在E-R圖中使用橢圓表示。
  • 5.關係:實體和實體之間的關係:在E-R圖中使用菱形表示。

需求: 利用E-R圖描述客戶、商品、訂單之間的關係
MySQL學習之DDL、DML及DQL基礎總結

##MySQL資料庫

SQL簡介

什麼是SQL#

Structured Query Language結構化查詢語言。 SQL語句不依賴任何平台,對所有的資料庫是通用的。學會了SQL語句的使用,可以在任何的資料庫使用,但都有特有內容。 SQL語句功能強大、簡單易學、使用方便。

SQL特點

SQL語句是一個非過程性的語言,每個SQL執行完都會有一個具體的結果出現。多條語句之間沒有影響

SQL作用

#SQL語句主要是操作資料庫,資料表,資料表中的資料記錄

SQL通用語法

  1. #SQL語句可以單行或多行書寫,以分號結尾。
  2. 可使用空格和縮排來增強語句的可讀性。
  3. MySQL資料庫的SQL語句不區分大小寫,關鍵字開發中一般大寫.
  4. 三種註解
    - 單行註解: -- 註解內容
    - 多行註解: /* 註解內容*/
    - # 註解內容:(mysql特有的單行註解)

SQL分類
SQL是用來存取關聯式資料庫的語言,具有定義、操縱、控制和查詢關係型資料庫的四個面向功能。所以針對四方功能,我們將SQL進行了分類。

  1. DDL(Data Definition Language)資料定義語言
    用來定義資料庫物件:資料庫,表,列等。關鍵字:create drop alter truncate(清空資料記錄) show等

  2. DML(Data Manipulation Language)資料操作語言★★★

    #在資料庫表中更新,增加和刪除記錄。如update(更新),insert(插入),delete(刪除) 不包含查詢

  3. DQL(Data Query Language) 資料查詢語言★★★★★★
    資料表記錄的查詢。關鍵字select。

  4. DCL(Data Control Language)資料控制語言(了解)

    是用來設定或變更資料庫使用者或角色權限的語句,如grant(設定權限),revoke(撤銷權限),begin transaction等。這個比較少用到。

MySQL學習之DDL、DML及DQL基礎總結

MySQL 目錄結構

MySQL學習之DDL、DML及DQL基礎總結

MySQL 資料庫連線

MySQL是一個需要帳號名稱密碼登入的資料庫,登陸後使用,它提供了一個預設的root帳號,使用安裝時設定的密碼即可登入。

啟動資料庫服務:在開啟dos視窗中輸入net start MySQL指令
MySQL學習之DDL、DML及DQL基礎總結
關閉資料庫服務:在開啟dos視窗中輸入net stop MySQL命令
MySQL學習之DDL、DML及DQL基礎總結
#連接MySQL:登入格式1:mysql -u用戶名-p密碼

mysql -uroot -p123456

MySQL學習之DDL、DML及DQL基礎總結
登入格式2:mysql[-h連接主機ip位址-P連接埠號碼3306] -u 使用者名稱-p 密碼

mysql -h 127.0.0.1 -P 3306 -u root -p 123456

MySQL學習之DDL、DML及DQL基礎總結
如果連接的是本機:可以省略-h -P 主機IP和連接埠。這樣就可以登入mysql資料庫了

退出exit指令
MySQL學習之DDL、DML及DQL基礎總結
顯示資料庫: show databases;
MySQL學習之DDL、DML及DQL基礎總結

SQL_DDL_操作資料庫

DDL_建立並檢視資料庫

建立資料庫:

1.直接建立資料庫

create database 数据库名;

2.判斷資料庫是否存在並建立(如果不存在,則建立)

create database if not exists 数据库名;

3.建立資料庫並指定字符集(編碼表)

create database 数据库名 character set 字符集;

說明:字元集就是編碼表名,在mysql中utf8

查看資料庫:

1.查看所有資料庫

show databases;

2.查看某個資料庫的定義資訊

show create database 数据库名;

3.查看目前使用的資料庫

select database();

使用與切換資料庫:

use 数据库名;

DDL_修改並刪除資料庫

修改資料庫:

1.修改資料庫字元集

-- alter 表示修改alter database 数据库名 default character set 新字符集;

注意:如果修改資料庫指定的編碼表是utf8,記住不能寫utf-8

#

Java中的常用编码对应mysql数据库中的编码

Java MySQL
UTF-8 utf8
GBK gbk
GB2312 gb2312
ISO-8859-1 latin1

删除数据库:

1.直接删除

-- drop 删除数据库drop database 数据库名;

2.删除数据库时判断是否存在(如果存在,则删除)

drop database if exists 数据库名;

SQL_DDL_操作数据表

DDL_数据库约束

约束的概念:

  • 约束是作用于表中列上的规则,用于限制加入表的数据

  • 约束的存在保证了数据库中数据的正确性、有效性和完整性

约束的分类:

约束名称 关键字 描述
非空约束 NOT NULL 保证列中所有数据不能有null空值
唯一约束 UNIQUE 保证列中所有数据各不相同
主键约束 PRIMARY KEY 主键是一行数据的唯一标识,要求非空且唯一
检查约束 CHECK 保证列中的值满足某一条件
默认约束 DEFAULT 保存数据时,未指定值则采用默认值
外键约束 FOREIGN KEY 外键用来让两个表的数据之间建立链接,保证数据的一致性和完整性

MySQL5.7不支持检查约束,但写入语句不会报错,MySQL8.0版本支持检查约束

非空约束

非空约束用于保证列中所有数据不能有NULL值

1.建表时添加约束

-- 创建表时添加非空约束create table 表名(
    列名 数据类型 not null,
    ...);

2.建完表之后添加约束

-- 建完表之后添加约束alter table 表名 modify 字段名 数据类型 not null;

3.删除约束

alter table 表名 modify 字段名 数据类型;

唯一约束

唯一约束用于保证列中所有数据各不相同

1.创建表时添加唯一约束

-- 方式1create table 表名(
    字段名 数据类型 UNIQUE,
    ...);-- 方式2create table 表名(
    字段名 数据类型,
    ...
    [CONSTRAINT] [约束名称] UNIQUE(列名));

2.建完表之后添加唯一约束

-- 建完表后添加唯一约束alter table 表名 modify 字段名 数据类型 UNIQUE;

3.删除唯一约束

alter table 表名 drop index 字段名;

主键约束

  • 主键是一行数据的唯一标识,要求非空且唯一
  • 一张表只能有一个主键

1.创建表时添加主键约束

create table 表名(
    字段名 数据类型 PRIMARY KEY [AUTO_INCREMENT],
    -- [AUTO_INCREMENT] 当不指定值时自动增长
    ...);create table 表名(
    列名 数据类型,
    [CONSTRAINT] [约束名称] PRIMARY KEY(列名))

2.建完表之后添加主键约束

alter table 表名 add PRIMARY KEY(字段名);

3.删除主键约束

alter table 表名 drop PRIMARY KEY;

默认约束

保存数据时,未指定值则采用默认值

1.创建表时添加默认约束

create table 表名(
    字段名 数据类型 default 默认值,
    ...);

2.建完表后添加默认约束

alter table 表名 alter 列名 set DEFAULT 默认值;

3.删除约束

alter table 表名 alter 列名 drop DEFAULT;

DDL_创建和查看和表

前提 :创建数据库db1并使用这个数据库

-- 创建数据库create database db1;-- 使用数据库use db1;

创建表:

create table 表名(
    字段名1 字段类型 约束条件,
    字段名2 字段类型 约束条件,
    ...
    字段名n 字段类型 约束条件);-- 注意:最后一个字段不加逗号

创建一个表结构和其他表结构相同的表

create table 表名 like 其他表名;

MySQL中常用的数据类型
MySQL學習之DDL、DML及DQL基礎總結
案列需求:

设计一张学生表,要求如下:

  • 学号,要求唯一主键,自增
  • 姓名,不能为空,且唯一
  • 性别,只有男和女,默认值为null
  • 班级,字符串类型
  • 入学时间,取值为年、月、日
  • 数学成绩,double类型,默认为60分
  • 英语成绩,double类型,没有默认值
create table students(
    id int primary key auto_increment,
    name varchar(10) not null unique,
    sex enum('男','女') default null,
    class varchar(10),
    starttime date,
    math int default 60,
    english int);

MySQL學習之DDL、DML及DQL基礎總結
查看表:

1.查看某个数据库中所有的表

show tables;

2.查看表结构

desc 表名;

3.查看创建表的SQL语句

show create table 表名;-- 根据该语句查看上面案列的建表sql语句show create table students;

MySQL學習之DDL、DML及DQL基礎總結

DDL_删除表和修改表的结构

删除表:

1.直接删除

drop table 表名;

2.删除表时判断表是否存在(如果存在,则删除)

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_DML_操作数据库

DML_插入表数据

1.插入全部字段

-- 全部字段写出来insert into 表名(字段1,字段2,...) values(值1,值2,...);
-- 插入全部不写字段名insert into 表名 values(值1,值2,...);
-- 给案例中的表插入数据insert into students(id,name,sex,class,starttime,math,english) values(1,'张三','男','高三1班','2022-03-02',80,69);
insert into students values(2,'李四','女','高三2班','2022-03-01',70,80);

MySQL學習之DDL、DML及DQL基礎總結
2.插入部分数据

-- 插入姓名,班级,入学时间,英语成绩-- id默认增长,性别默认null,数学默认60
insert into students(name,class,starttime,english) values('王五','高三3班','2022-03-02',78);

MySQL學習之DDL、DML及DQL基礎總結
说明:插入部分数据的时候,要求列名一定书写出来。

3.批量插入数据

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

没有添加数据的字段会使用NULL

注意:

  • 值与列一一对应。有多少个列,就需要写多少个值。如果某一个列没有值,可以使用null,表示插入空。

  • 值的数据类型,与列被定义的数据类型要相匹配,并且值的长度,不能够超过定义的列的长度。

  • 字符串:插入字符类型的数据,建议写英文单引号括起来。在mysql中,使用单引号表示字符串

  • date 时间类型的数据也得使用英文单引号括起来: 如yyyy-MM-dd

DML_更新表数据

1.不带条件修改数据

update 表名 set 字段名=新的值,字段名=新的值,...;
-- 注意:不带条件的修改是将数据表中的整列都做修改
-- 修改students表中math的值为90update students set math=90;

MySQL學習之DDL、DML及DQL基礎總結
2.带条件修改数据

update 表名 set 字段名=新的值,字段名=新的值,... where 条件;
-- 修改students表中王五的性别为男,数学成绩设置为70update students set sex='男',math=70 where name='王五';

MySQL學習之DDL、DML及DQL基礎總結
3.关键字说明

UPDATE: 表示修改记录 
SET: 要改哪个字段WHERE: 设置条件

4.注意

  • 不带条件的更新数据库记录:UPDATE 表名 SET 字段名=新的值;是将整个表中修改的列修改
  • 带条件:UPDATE 表名 SET 字段名=新的值 WHERE 条件

DML_删除表记录

1.不带条件删除

DELETE -- 删除记录DELETE FROM 表名;表还在,可以操作,只是删除数据。

2.带条件删除

DELETE FROM 表名 WHERE 条件;-- 删除学生表中的王五的信息DELETE FROM students WHERE name='王五';

MySQL學習之DDL、DML及DQL基礎總結
3.truncate删除表记录(属于DDL)

truncate table 表名;

4.truncate和delete区别

  • delete是将表中的数据一条一条删除
  • truncate是将整个表摧毁,重新创建一个新的表,新的表结构和原来表结构一模一样

SQL_DQL_ 简单查询数据

准备一张学生表,在这张表上进行查询操作
MySQL學習之DDL、DML及DQL基礎總結

DQL_基础查询

1.查询所有数据

select * from 表名;
-- 查询学生表中所有的数据select * from students;

MySQL學習之DDL、DML及DQL基礎總結
2.查询指定列的数据

select 字段名1,字段名2,... from 表名;
-- 查询姓名和班级这两个字段select name,class from students;

MySQL學習之DDL、DML及DQL基礎總結
3.查询到的字段设置别名

select 字段名1 as 别名1,字段名2 as 别名2 from 表名;
-- 查询students表中的字段并设置别名select id as 学号,name as 姓名,sex as 性别,class as 班级 , starttime as 入学时间 from students;

MySQL學習之DDL、DML及DQL基礎總結
4.查询到的数据去重

-- DISTINCT  去重复-- 查询班级字段结果不出现重复的select DISTINCT class from students;

MySQL學習之DDL、DML及DQL基礎總結

DQL_条件查询

1.条件查询语法

select 字段名1,字段名2,... where 条件列表;

2.条件运算符

符号 功能
> 大于
小于
>= 大于等于
小于等于
= 等于
或!= 不等于
BETWEEN…AND… 在某个范围内(都包括)
IN(…) 多选一
LIKE 模糊查询,_单个任意字符,%多个任意字符
IS NULL 为空
IS NOT NULL 不为空
AND 或 && 与,并且
OR 或 || 或,或者
NOT 或 ! 非,不是

3.查询数学成绩大于80并且性别为男的学生

-- 两个条件同时满足select * from students where math > 80 and sex='男';

MySQL學習之DDL、DML及DQL基礎總結
4.查询英语成绩在60-80之间的学生

-- BETWEEN 值1 AND 值2 -- 表示从值1到值2范围,包头又包尾
select * from students where english between 60 and 80;
select * from students where english>=60 && english<p><img src="https://img.php.cn/upload/article/000/000/067/01283e47128a89592860b85cda10b160-24.png" alt="MySQL學習之DDL、DML及DQL基礎總結"><br><strong>5.查询学号为1或者2或者3的学生</strong></p><pre class="brush:php;toolbar:false">-- in里面的每个数据都会作为一次条件,只要满足条件的就会显示select * from students where id in (1,2,3);

MySQL學習之DDL、DML及DQL基礎總結

DQL_模糊查询

LIKE:表示模糊查询

select * from 表名 where 字段名 like '通配字符';

MySQL通配符有两个:

  • %:表示0个或多个字符(任意字符)
  • _:表示一个字符

1.查找名字中以开头的学生

-- '孙%'表示孙后面有任意个字符select * from students where name like '孙%';

MySQL學習之DDL、DML及DQL基礎總結
2.查找名字中以开头的两个字的学习

-- '孙_'表示孙后面只能有一个字符select * from students where name like '孙_';

MySQL學習之DDL、DML及DQL基礎總結

DQL_查询排序

通过ORDER BY子句,可以将查询出的结果进行排序(排序只是显示方式,不会影响数据库中数据的顺序)

-- ASC:升序排序(默认)-- DESC:降序排序select 字段 from 表名 order by 排序字段 [ASC|DESC];

1.单列排序

-- 查询学生的数学成绩按照升序排序select * from students order by math ASC;

MySQL學習之DDL、DML及DQL基礎總結
2.组合排序

-- 查询数学成绩升序的基础上,英语成绩降序-- 组合排序就是先按第一个字段进行排序,如果第一个字段相同,才按第二个字段进行排序,依次类推。
select * from students order by math ASC,english DESC;

MySQL學習之DDL、DML及DQL基礎總結

DQL_ 聚合函数

之前我们做的查询都是横向查询,它们都是根据条件一行一行的进行判断,而使用聚合函数查询是纵向查询,它是对一列的值进行计算,然后返回一个结果值;另外聚合函数会忽略空值,对于null不作为统计。

1.五个聚合函数

函数名 功能
count(列名) 统计数量(一般选用不为null的列)
max(列名) 最大值
min(列名) 最小值
sum(列名) 求和
avg(列名) 平均值

2.聚合函数语法

select 聚合函数名(列名) from 表名;

注意:null 值不参与所有聚合函数运算

3.查询学生总数

select count(id) from students;-- 通常使用select count(*) from students;

MySQL學習之DDL、DML及DQL基礎總結
4.查询最高分和最低分

-- 查询数学最高分和英语最低分select max(math),min(english) from students;

MySQL學習之DDL、DML及DQL基礎總結
5.求和求平均值

-- 求该表数学总分和平均值select sum(math),avg(math) from students;

MySQL學習之DDL、DML及DQL基礎總結
6.ifnull()函数

-- ifnull(列名,默认值)函数表示判断该列是否为空值,如果为null,返回默认值,如果不为空,返回实际值ifnull(math,60); 
-- 如果数学成绩为null时,返回60,如果不为null,就返回实际值

DQL_分组查询

分组: 按照某一列或者某几列。把相同的数据,进行合并输出。

1.注意

  • 按照某一列进行分组,目的为了统计使用。
  • 聚合函数:分组之后进行计算
  • 通常select后面的内容是被分组的列,以及聚合函数
  • sql语句中的where后面不允许添加聚合函数
  • 可以使用having条件,表示分组之后的条件,在having后面可以书写聚合函数

2.查询各个班级的数学成绩总和

-- 查询每个班的数学成绩总和select class,sum(math) from students group by class;

MySQL學習之DDL、DML及DQL基礎總結
3.having用法

having必须和group by 一起使用,having和where的用法一模一样,where怎么使用having就怎么使用,where不能使用的,having也可以使用,比如说where后面不可以使用聚合函数,但是在having后面是可以使用聚合函数的。

-- 查询每个班数学总成绩大于300分的班级并显示总成绩
select class,sum(math) from students group by class having sum(math)>300;

MySQL學習之DDL、DML及DQL基礎總結
4.where和having的区别

  • having 通常与group by 分组结合使用。 where 和分组无关。

  • having 可以书写聚合函数 (聚合函数出现的位置: having 之后),例如having中的 聚合函数(count,sum,avg,max,min),是不可以出现where条件中。

  • where 是在分组之前进行过滤的,having 是在分组之后进行过滤的。

DQL_分页查询

1.应用和概念

比如我们登录京东,淘宝,返回的商品信息可能有几万条,不是一次全部显示出来。是一页显示固定的条数。假设我们一每页显示5条记录的方式来分页。
MySQL學習之DDL、DML及DQL基礎總結

-- 起始索引:从0开始,索引是0表示数据表第一行数据select 字段列表 from 表名 limit 起始索引,查询条目数;

计算公式:起始索引=(当前页码-1)* 每页显示的条数

注意:

  • 分页查询limit是MySQL数据库的方言
  • Oracle分页查询使用rownumber
  • SQLServer分页查询使用top

2.分页查询

<span style="font-family: " microsoft yahei sans gb helvetica neue tahoma arial sans-serif>-- 查询学生表中数据,每四条数据为一页<br>select * from students limit 0,4;<br>select * from students limit 4,4;<br>select * from students limit 8,4;<br>select * from students limit 12,4;<br>...<br>-- 注意:最后一行不够查询条目数,有多少就显示多少</span><br>

3.返回前几条或者中间某几行数据

-- 2表示分页查询的索引,对应数据表是第3行数据,4表示每页显示4条数据
-- 查询从第三行数据开始查询之后的四条数据
select * from students limit 2,4;

MySQL學習之DDL、DML及DQL基礎總結
4.SQL执行顺序

SELECT 字段名(5) FROM 表名(1) WHERE 条件(2) GROUP BY 分组列名(3) HAVING 条件(4) ORDER BY 排序列名(6) LIMIT 跳过行数, 返回行数(7);
执行顺序:1234567

顺序:1234567

推荐学习:mysql视频教程

以上是MySQL學習之DDL、DML及DQL基礎總結的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:csdn.net。如有侵權,請聯絡admin@php.cn刪除