3 typora-copy-images-to: img

day18-MySql基础

今日内容

  • 数据库概述
  • 数据库安装和卸载
  • SQL语句

    • DDL——-操作数据库,操作表
    • DML——-操作记录(增删改)
    • DQL———操作记录(查)

学习目标

  • 能够理解数据库的概念
  • 能够安装MySql数据库
  • 能够使用SQL语句操作数据库
  • 能够使用SQL语句操作表结构
  • 能够使用SQL语句进行数据的添加修改和删除的操作
  • 能够使用SQL语句进行条件查询数据
  • 能够使用SQL语句进行排序
  • 能够使用聚合函数
  • 能够使用SQL语句进行分组查询
  • 能够使用SQL语句进行分页查询

第一章-数据库概述

知识点-数据库的介绍

1.目标

  • 知道什么是数据库

2.分析

目前来说如果我们要进行数据存储,有几种方式:

  1. 我们可以使用集合等方式将数据保存在内存中,但是数据不能持久化保存,断电/程序退出,数据就清除了

  2. 我们还可以将数据保存在普通文件中,可以持久化保存,但是查找,增加,修改,删除数据比较麻烦,效率低

所以我们需要一个既可以持久化保存数据又可以方便操作的地方来存储数据,这就是我们接下来要给大家介绍的数据库

3.讲解

3.1什么是数据库

  1. 数据库(DataBaseDB):指长期保存在计算机的存储设备(硬盘)上,按照一定规则组织起来,可以被各种用户或应用共享的数据集合. 还是以文件的方式存在服务器的电脑上的。
  2. **说白了就是数据的仓库, 用来持久化保存数据的.**

3.2常见的关系型数据库

  • MySql :开源免费的数据库,中小型的数据库,已经被Oracle收购了。MySql6.x版本也开始收费。后来Sun公司收购了MySql,而Sun公司又被Oracle收购
  • Oracle:收费的大型数据库.Oracle公司的产品.Oracle收购SUN公司,收购MySql.
  • DB2:IBM公司的数据库产品,收费的.银行系统中.
  • SQLServer:MS公司.收费的中型的数据库.
  • SyBase:已经淡出历史舞台.提供了一个非常专业数据建模的工具PowerDesigner.
  • SQLite: 嵌入式的小型数据库,应用在手机端.

day18-MySQL基础 - 图1

4.小结

  1. 为什么要学习数据库?
    把数据保存到文件, 内存里面 ,都要一些缺点. 保存到数据库里面解决这些缺点.

  2. 什么数据库?
    数据的仓库, 用来持久化保存数据的

  3. 常见的关系型数据库?
    MySQL
    Oracle

知识点-数据库结构【重点】

1.目标

  • 掌握数据库结构

2.分析

  1. 数据库是用来存储数据的,那么到底通过什么样的方式来存的. 结构是怎么样的呢?

3.讲解

  1. 数据库管理程序(DBMS)可以管理多个数据库,一般开发人员会针对每一个应用创建一个数据库。为保存应用中实体的数据,一般会在数据库创建多个表,以保存程序中实体的数据。
  2. 数据库管理系统、数据库和表的关系如图所示:

day18-MySQL基础 - 图2

4.小结

1.一般情况下,一个系统(软件,项目) 就设计一个数据库; eg: jd项目, 设计一个jd的数据库

2.一个数据库里面有多(>=1)张表. 一个实体(java类)对应一张表

3.一张表里面有多条(>=1)记录, 一个对象对应一条记录

第二章-数据库的安装,卸载,启动,登录

实操-MySql的安装,卸载

1.目标

  • 掌握MySql的安装和卸载

2.路径

  1. 我们要使用MySql数据库,就需要先安装. 如果第一次安装失败了,就需要卸载,再安装.
  1. MySql的安装
  2. MySql的卸载

3.讲解

3.1MySql的安装

具体参考文档: 资料\01_MySql安装与卸载\MySql安装图解.docx

day18-MySQL基础 - 图3

3.2MySql的卸载

具体参考文档: 资料\01_MySql安装与卸载\MySql卸载手册.doc

day18-MySQL基础 - 图4

4.小结

  • 安装需要注意的地方: 安装路径不要有空格和中文,对着文档装

  • 卸载需要注意的地方

    • 去360/软件管家或者控制面板卸载(删除之前先找到两个文件夹)
    • 一定要删除两个文件夹(数据库安装路径和数据存放路径,这两个文件夹在配置文件里面my.ini)

day18-MySQL基础 - 图5

实操-数据库服务的启动和连接,退出

1.目标

  1. 我们刚刚把数据库安装成功了,下面就需要进行数据库的启动,登录和退出

2.步骤

  1. 数据库服务的启动
  2. MySql的登录(命令行和客户端方式)
  3. MySql的退出

3.讲解

3.1数据库服务的启动

3.1.1 方式一通过界面启动

day18-MySQL基础 - 图6

day18-MySQL基础 - 图7

3.1.2方式二通过DOS命令方式启动

day18-MySQL基础 - 图8

day18-MySQL基础 - 图9

  1. MySql是一个需要账户名密码登录的数据库,登陆后使用,它提供了一个默认的root账号,使用安装时设置的密码即可登录.

3.2连接

3.2.1命令行
  1. mysql -u 用户名 -p #然后再输入密码.

3.2.2图形化工具
  • 安装

day18-MySQL基础 - 图10

day18-MySQL基础 - 图11

  • 连接
    day18-MySQL基础 - 图12
    day18-MySQL基础 - 图13

2.3退出

2.3.1命令行
  1. 输入: quitexit

2.3.2图形化工具
  • 右键关闭

4.小结

  1. MySql启动: 建议大家开机就启动
  2. dos连接
  1. mysql -u root -p
  2. 再输入密码
  3. mysql -uroot -p密码
  1. navicat图形化工具, 会连接就OK
  2. SQLyog图形工具.会连接就ok

第三章-SQL概述

知识点-Sql介绍

1.目标

  • 掌握什么是SQL

2.路径

  1. 介绍Sql的概念
  2. sql的语法的注意事项
  3. 介绍sql的类别

3.讲解

3.1.什么是sql?

  • SQL:Structure Query Language。(结构化查询语言),通过sql操作数据库(操作数据库,操作表,操作数据)
  • SQL被美国国家标准局(ANSI)确定为关系型数据库语言的美国标准,后来被国际化标准组织(ISO)采纳为关系数据库语言的国际标准
  • 各数据库厂商(MySql,oracle,sql server)都支持ISO的SQL标准。
  • 各数据库厂商在标准的基础上做了自己的扩展。 各个数据库自己特定的语法

day18-MySQL基础 - 图14

3.2sql的语法

  • 每条语句以分号结尾(命令行里面需要),如果在navicat,sqlyog,java代码中不是必须加的。
  • SQL在window中不区分大小写,关键字中认为大写和小写是一样的

3.3sql的分类

  • Data Definition Language (DDL数据定义语言) 如:操作数据库,操作表
  • Data Manipulation Language(DML数据操纵语言),如:对表中的记录操作增删改
  • Data Query Language(DQL 数据查询语言),如:对表中的数据查询操作
  • Data Control Language(DCL 数据控制语言),如:对用户权限的设置

4.小结

  1. 我们工作里面用的最多的是 DML和DQL , 对数据的增删改查
  2. SQL 结构化查询语言, 用SQL来操作数据库

第四章-DDL操作数据库

知识点-DDL操作数据库

1.目标

  1. 我们把Sql介绍完成了, 那下面就通过DDL操作数据库

2.步骤

  • 创建数据库(掌握)
  • 查看数据库
  • 删除数据库(掌握)
  • 修改数据库
  • 数据库的其它操作(掌握)

3.讲解

3.1创建数据库

  • 语法
  1. create database 数据库名 [character set 字符集][collate 校对规则] 注: []意思是可选的意思

字符集(charset):是一套符号和编码。

  • 练习

创建一个day18_1的数据库(默认字符集)

  1. create database day18_1;

创建一个day18_2的数据库,指定字符集为gbk(了解)

  1. create database day18_2 character set gbk;

3.2查看所有的数据库

3.2.1查看所有的数据库
  • 语法
  1. show databases;

3.2.2查看数据库的定义结构【了解】
  • 语法
  1. show create database 数据库名;
  1. -- 查看数据库
  2. -- 语法: show databases; 查询所有的数据库
  3. show databases
  4. -- 语法: show create database 数据库名; 查看数据库的定义结构【了解】
  5. show create database day18_1
  6. show create database day18_2

3.3删除数据库

  • 语法
  1. drop database 数据库名;
  1. -- 需求: 删除day18_2数据库
  2. drop database day18_2

3.4修改数据库【了解】

  • 语法
  1. alter database 数据库名 character set 字符集;
  1. -- 需求: day18_2数据库的字符集修改为utf8
  2. alter database day18_2 character set utf8

注意:

  • 是utf8,不是utf-8
  • 不是修改数据库名

3.5其他操作

  • 切换数据库, 选定哪一个数据库
  1. use 数据库名; //注意: 在创建表之前一定要指定数据库. use 数据库名
  1. -- 语法: use 数据库名; 选中数据库
  2. use day18_1
  3. -- 语法: select database(); 查看当前选中(正在使用)的数据库
  4. select database();

4.小结

  1. 创建数据库
  1. create database 数据库的名字;
  1. 删除数据库
  1. drop database 数据库的名字;
  1. 其它操作
  1. use 数据库的名字; -- 切换到某个数据库
  2. select database(); -- 查看正在使用哪个数据库

第五章-DDL操作表

知识点-创建表【重点】

1.目标

  1. 我们第四章已经把数据库的CRUD讲解完了,下面我们就学习创建表

2.步骤

  • 创建表的语法介绍
  • MySql常见的类型
  • MySql约束

3.讲解

3.1语法

  1. create table 表名(
  2. 列名 类型 [约束],
  3. 列名 类型 [约束],
  4. ...
  5. 列名 类型 [约束]
  6. );
  7. 列: 字段
  8. 行: 记录

3.2 类型

day18-MySQL基础 - 图15

  1. 整型 一般使用int 或者bigint

  2. 浮点/双精度型

    • 默认的范围 float或者double
    • 指定范围 float(M,D) eg: float(4,2) 表达的范围: -99.99~99.99
  3. 字符串

    • 固定长度 char(n) eg: char(20), 最大能存放20个字符. ‘aaa’, 还是占20个字符的空间
    • 可变长度 varchar(n) eg:varchar(20), 最大能存放20个字符. ‘aaa’, 占3个字符的空间

      一般使用varchar(n) 节省空间; 如果长度(eg:身份证)是固定的话 可以使用char(n) 性能高一点

  4. 关于大文件

    • 一般在数据库里面很少存文件的内容, 一般存文件的路径
    • 一般不使用二进制存, 使用varchar(n)存文件的路径
  5. 日期

    • DATE 只有日期
    • DATETIME 日期和时间
  6. 类型小结

    1. 整数: int bigint
    2. 小数: double
    3. 字符串: varchar(长度)
    4. 日期: date \ datetime

3.3 约束

  • 即规则,规矩 限制;
  • 作用:保证用户插入的数据保存到数据库中是符合规范的 | 约束 | 约束关键字 | | —- | —- | | 主键 | primary key | | 唯一 | unique | | 非空 | not null |

约束种类:

  • not null: 非空 ; eg: username varchar(40) not null username这个列不能有null值

  • unique:唯一约束, 后面的数据不能和前面重复; eg: cardNo char(18) unique; cardNo 列里面不可以有重复数据

  • primary key;主键约束(非空+唯一); 一般用在表的id列上面. 一张表基本上都有id列的, id列作为唯一标识的

    • auto_increment: 自动增长,必须是设置了primary key之后,才可以使用auto_increment
  • id int primary key auto_increment; id不需要我们自己维护了, 插入数据的时候直接插入null, 自动的增长进行填充进去, 避免重复了.

注意:

  1. 先设置了primary key 才能设置auto_increment
  2. 只有当设置了auto_increment 才可以插入null 自己维护 否则插入null会报错

id列:

  1. 给id设置为int类型, 添加主键约束, 自动增长
  2. 或者给id设置为字符串类型,添加主键约束, 不能设置自动增长

3.4练习

  • 创建一张学生表(含有id字段,姓名字段,性别字段. id为主键自动增长)
  1. -- 需求: 创建一张学生表(含有id字段,姓名字段,性别字段. id为主键自动增长)
  2. -- 创建表之前需要选中数据库
  3. use day18_1
  4. create table student(
  5. id int primary key auto_increment,
  6. name varchar(40) ,
  7. sex varchar(13) not null
  8. );

4.小结

  1. 语法
  1. create table 表名(
  2. 类型 【约束】,
  3. 类型 【约束】
  4. );
  1. 类型

    • int
    • double
    • char(n) 固定长度
    • varchar(n) 可变长度
    • date
  2. 约束

    • not null 非空
    • unique 唯一
    • primary key 主键(非空+唯一)

      • auto_increment 自动增长
  3. id

    • 可以设置成int类型, 设置成primary key, 添加auto_increment
    • 作为记录唯一标识

知识点-查看表【了解】

1.目标

我们把表创建好了, 下面就来介绍查看表

2.步骤

  • 查看当前数据库所有的表
  • 查看表的定义结构

3.讲解

3.1查看所有的表

  1. show tables;

3.2查看表的定义结构

  • 语法
    desc 表名;

  • 练习: ```mysql — 语法: show tables; 查看所有的表 show tables

— 语法: desc 表名; 查看表的定义结构 desc student

  1. <a name="dd631cbe-7"></a>
  2. ### 4.小结
  3. <a name="6f260579"></a>
  4. ## 知识点-修改表【掌握】
  5. <a name="1098f420-8"></a>
  6. ### 1.目标
  7. 我们表创建好了, 如果要增加一列,要删除一列呢? 那下面就来讲解修改表
  8. <a name="e14fed03-4"></a>
  9. ### 2.步骤
  10. - 增加列
  11. - 修改列的类型约束
  12. - 修改列的名称,类型,约束
  13. - 删除列
  14. - 修改表名
  15. <a name="d90792e1-8"></a>
  16. ### 3.讲解
  17. <a name="701216b7-1"></a>
  18. #### 3.1语法
  19. - 增加一列;alter table 表 add 字段 类型 约束;
  20. - 修改列的类型约束; alter table 表 modify 字段 类型 约束 ;
  21. - 修改列的名称,类型,约束;alter table 表 change 旧列 新列 类型 约束;
  22. - 删除一列; alter table 表名 drop 列名;
  23. - 修改表名 ; rename table 旧表名 to 新表名;
  24. <a name="22a0c71c"></a>
  25. #### 3.2练习
  26. ```mysql
  27. -- 修改表
  28. -- 语法: alter table 表名 add 列名 类型 约束; 增加列
  29. -- 需求:为学生表增加一个成绩列
  30. alter table student add score double;
  31. -- 语法: alter table 表名 modify 列名 新类型 新约束; 修改列的类型约束
  32. -- 需求: 修改name的类型和约束
  33. alter table student modify name varchar(40) not null;
  34. -- 语法: alter table 表名 change 旧列名 新列名 类型 约束; 修改列的名称,类型,约束
  35. -- 需求: 修改sex列名为gender
  36. alter table student change sex gender varchar(13) not null;
  37. -- 语法: alter table 表名 drop 列名; 删除列
  38. -- 需求: 删除score
  39. alter table student drop score;
  40. -- 语法: rename table 旧表名 to 新表名; 修改表名
  41. rename table student to stu;

4.小结

  1. 都是以alter table 表名打头
  • 增加列 add
  • 修改列的类型 约束 modify
  • 修改列的名字 类型 约束 change
  • 删除列 drop
  1. 敲一遍就行了

知识点-删除表【掌握】

1.目标

  1. 表创建好了, 我们还可以删除。 掌握表的删除

2.步骤

  • 删除表

3.讲解

  • 语法
    drop table 表名;

  • 练习

    1. -- 删除表
    2. -- drop table 表名;
    3. -- 需求: 删除stu
    4. drop table stu;

4.小结

  1. 删除表语法
  1. drop table 表名;

第六章-DML操作表记录-增删改【重点】

  • 准备工作: 创建一张商品表(商品id,商品名称,商品价格,商品数量.)
  1. create table product(
  2. pid int primary key auto_increment, //只有设置了auto_increment id列才可以赋值为null
  3. pname varchar(40),
  4. price double,
  5. num int
  6. );

知识点-插入记录

1.目标

  • 掌握插入记录

2.步骤

  • 两种方式插入数据
  • 使用命令行操作时候乱码的解决

3.讲解

  • 准备一张表
    1. -- 创建一张商品表(商品id,商品名称,商品价格,商品数量)
    2. create table product(
    3. id int primary key auto_increment,
    4. pname varchar(100),
    5. price double,
    6. num int
    7. )
  • 方式一: 插入指定列, 如果没有把这个列进行列出来, 以null进行自动赋值了.
    eg: 只想插入pname, price , insert into t_product(pname, price) values(‘mac’,18000);
  1. insert into 表(列,列..) values(值,值..);
  2. insert into product(pname,price) values('Mac',18888);

注意: 如果没有插入了列设置了非空约束, 会报错的

  • 方式二: 插入所有的列
  1. insert into values(值,值....);
  2. eg:
  3. insert into product values(null,'苹果电脑',18000.0,10);
  4. insert into product values(null,'华为5G手机',30000,20);
  5. insert into product values(null,'小米手机',1800,30);
  6. insert into product values(null,'iPhonex',8000,10);
  7. insert into product values(null,'苹果电脑',8000,100);
  8. insert into product values(null,'iPhone7',6000,200);
  9. insert into product values(null,'iPhone6s',4000,1000);
  10. insert into product values(null,'iPhone6',3500,100);
  11. insert into product values(null,'iPhone5s',3000,100);
  12. insert into product values(null,'方便面',4.5,1000);
  13. insert into product values(null,'咖啡',11,200);
  14. insert into product values(null,'矿泉水',3,500);

命令行插入中文数据报错:

day18-MySQL基础 - 图16

  • 关闭服务, net stop MySql
  • 在数据库软件的安装目录下面, 修改配置文件 my.ini中客户端的编码为gbk

day18-MySQL基础 - 图17

  • 重新打开命令行,开启服务, net start MySql

4.小结

  1. 语法

    • 插入特定的列

      1. insert into 表名(列,列) value(值,值)
    • 插入所有的列

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

    • 插入特定的列没有赋值的列,系统自动赋为null(前提是当前列没有设置not null 约束)
    • 列名与列值的类型、个数、顺序要一一对应。
    • 值不要超出列定义的长度。
    • 插入的日期和字符串,使用引号括起来。

知识点-更新记录

1.目标

我们数据插入成功了, 还可以对已有的数据进行更新。

2.步骤

  • 更新数据

3.讲解

3.1语法

  1. update 表名 set =值, =值 [where 条件]

3.2练习

  1. -- 更新记录
  2. -- 语法: update 表名 set =值, =值 [where 条件]
  3. -- 需求:修改商品所有的价格为5000
  4. update product set price = 5000;
  5. -- 需求: 修改id2的商品数量和价格
  6. update product set price = 8000,num = 20 where id = 2;
  7. -- 将商品名是Mac的价格修改为18000
  8. update product set price = 18000 where pname = 'Mac'
  9. -- 将商品名是Mac的价格修改为17000,数量修改为5
  10. update product set price = 17000,num = 5 where pname = 'Mac'
  11. -- 将商品名是方便面的商品的价格在原有基础上增加2
  12. update product set price = price + 2 where pname = '方便面'

4.小结

  1. 语法
  1. update 表名 set = 值, 列=值, 列=值 [where 条件]
  1. 注意

    • 如果没有加where 更新整个的
    • 工作里面一般是加where

知识点-删除记录

1.目标

  • 掌握记录的删除

2.步骤

  • 使用delete删除
  • 使用truncate删除

3.讲解

3.1delete

  • 语法
  1. delete from [where 条件]

3.2truncate

  1. truncate table 表;

3.3 练习

  1. -- 删除记录
  2. -- 语法一: delete from 表名 [where 条件]
  3. -- 删除表中名称为’Mac’的记录
  4. delete from product where pname = 'Mac'
  5. -- 删除价格小于5001的商品记录
  6. delete from product where price < 5001
  7. -- 删除表中的所有记录
  8. delete from product
  9. -- 语法二: truncate table 表名;
  10. truncate table product

4.小结

  1. 删除记录
  1. delete from where 条件】
  1. delete 和truncate区别【面试题】

    • DELETE 删除表中的数据,表结构还在; 删除后的数据可以找回,一条一条的删除.
    • TRUNCATE 删除是把表直接DROP掉,然后再创建一个同样的新表。删除的数据不能找回。执行速度比DELETE快。
  2. 工作里面的删除

    • 物理删除: 真正的删除了, 数据不在, 使用delete就属于物理删除
    • 逻辑删除: 没有真正的删除, 数据还在. 搞一个标记, 其实逻辑删除是更新 eg: state 1 启用 0禁用

      工作里面一般使用逻辑删除用的多

第七章-DQL操作表记录-查询【重点】

知识点-单表查询

1.目标

  1. 我们上面讲解了对数据的增删改, 下面就来重点讲解数据的简单查询.

2.路径

  • 基本查询语法
  • 查询所有的列
  • 查询某张表特定列
  • 去重查询
  • 别名查询
  • 运算查询(+,-,*,/等)
  • 基本条件查询

3.讲解

3.1基本查询语法

  1. select [*] [列名 ,列名] [列名 as 别名 ...] [distinct 字段] from 表名 [where 条件]

3.2简单查询

3.2.1 查询所有的列的记录

3.2.2查询某张表特定列的记录

3.2.3 去重查询

注意点: 去重针对某列, distinct前面不能先出现列名

3.2.4 别名查询

3.2.5运算查询(+,-,*,/等)

注意

  • 运算查询字段,字段之间是可以运算的
  • 字符串等类型可以做运算查询,但结果没有意义
  1. -- 基本查询语法: select [*][列名,列名][distinct 列名] from 表名 [where 条件]
  2. -- 查询所有的列语法 : select * from 表名
  3. -- 需求: 查询product表中的所有数据
  4. select * from product;
  5. -- 查询某张表特定列 : select 列名,类名,... from 表名
  6. -- 需求: 查询product表中的pname,price字段的值
  7. select pname,price from product
  8. -- 去重查询 : select distinct 列名 from 表名
  9. -- 需求: 查询price字段,去重 单个字段去重
  10. select distinct price from product
  11. -- 需求: 查询pname,price字段,同时去重 多个字段去重
  12. select distinct pname,price from product
  13. -- 注意: distinct前面不能有字段名
  14. select id,distinct price from product -- 报错
  15. -- 别名查询
  16. -- 对字段取别名: select 字段 as 别名,字段 as 别名,... from 表名 注意: as可以省略 一般都会省略
  17. select pname as 商品名称,num as 商品数量 from product
  18. select pname 商品名称,num 商品数量 from product
  19. -- 对表取别名:select 1别名.字段名,... from 1 as 1别名 明天讲解,今天先感受 注意: as可以省略 一般都会省略
  20. select p.pname,p.num from product as p;
  21. select p.pname,p.num from product p;
  22. -- 运算查询(+,-,*,/等) null和其他数据进行运算得到是null
  23. -- 需求: 计算每个商品的总价(单价*数量)
  24. select price ,num from product
  25. select price * num from product
  26. select price * num 总价 from product
  27. select price * ifnull(num,0) 总价 from product

3.3条件查询

3.3.1语法
  1. select ... from where 条件
  2. //取出表中的每条数据,满足条件的记录就返回,不满足条件的记录不返回

day18-MySQL基础 - 图18

  1. between…and… 区间查询
  1. eg: where price between 1000 and 3000 相当于 1000<=price<=3000
  1. in(值,值..)
  1. -- 查询id1,3,5,7
  2. select * from t_product where id = 1
  3. select * from t_product where id = 3
  4. select * from t_product where id = 5
  5. select * from t_product where id = 7
  6. select * from t_product where id in(1,3,5,7)
  1. like 模糊查询 一般和_或者%一起使用

    • _ 占一位
    • % 占0或者n位
  1. name like '张%' --查询姓张的用户, 名字的字数没有限制
  2. name like '张_' --查询姓张的用户 并且名字是两个字的
  1. and 多条件同时满足
  1. where 条件1 and 条件2 and 条件3
  1. or 任意条件满足
  1. where 条件1 or 条件2 or 条件3

3.3.2练习
  • 查询商品价格>3000的商品

  • 查询id=1的商品

  • 查询id<>1的商品

  • 查询价格在3000到6000之间的商品

  • 查询id在1,5,7,15范围内的商品

  • 查询商品名以iPho开头的商品(iPhone系列)

  • 查询商品价格大于3000并且数量大于20的商品 (条件 and 条件 and…)

  • 查询id=1或者价格小于3000的商品

  1. -- 查询商品价格>3000的商品
  2. select * from product where price > 3000
  3. -- 查询id=1的商品
  4. select * from product where id = 1
  5. -- 查询id<>1的商品
  6. select * from product where id <> 1
  7. select * from product where id != 1
  8. -- 查询价格在30006000之间的商品
  9. select * from product where price between 3000 and 6000
  10. select * from product where price >= 3000 and price <= 6000
  11. -- 查询id15715范围内的商品
  12. select * from product where id in(1,5,7,15)
  13. -- 查询商品名以iPho开头的商品(iPhone系列)
  14. select * from product where pname like 'iPho%'
  15. -- 查询商品价格大于3000并且数量大于20的商品 (条件 and 条件 and...)
  16. select * from product where price > 3000 and num > 20
  17. -- 查询id=1或者价格小于3000的商品
  18. select * from product where id = 1 or price < 3000

4.小结

  • 语法
  1. select [*],[列名,列名],[列名 as 别名],[distinct 列名],[列(+,-..)] from 表名 [where 条件]
  • 条件

    • where price > 2000
    • where id = 1
    • where id <> 1
    • where name like ‘张%’
    • where price between 3000 and 5000
    • where id in(1,3,5,7,10)
    • where name like ‘张%’ and age > 10
    • where name like ‘张%’ or age <60

知识点-排序查询

1.目标

  • 能够使用SQL语句进行排序

2.分析

  1. 有时候我们需要对查询出来的结果排序显示,那么就可以通过`ORDER BY`子句将查询出的结果进行排序。排序可以根据一个字段排,也可以根据多个字段排序,排序只是对查询的结果集排序,并不会影响表中数据的顺序。

3.讲解

3.0环境的准备

  1. # 创建学生表(有sid,学生姓名,学生性别,学生年龄,分数列,其中sid为主键自动增长)
  2. CREATE TABLE student(
  3. sid INT PRIMARY KEY auto_increment,
  4. sname VARCHAR(40),
  5. sex VARCHAR(10),
  6. age INT,
  7. score DOUBLE
  8. );
  9. INSERT INTO student VALUES(null,'zs','男',18,98.5);
  10. INSERT INTO student VALUES(null,'ls','女',18,96.5);
  11. INSERT INTO student VALUES(null,'ww','男',15,50.5);
  12. INSERT INTO student VALUES(null,'zl','女',20,98.5);
  13. INSERT INTO student VALUES(null,'tq','男',18,60.5);
  14. INSERT INTO student VALUES(null,'wb','男',38,98.5);
  15. INSERT INTO student VALUES(null,'小丽','男',18,100);
  16. INSERT INTO student VALUES(null,'小红','女',28,28);
  17. INSERT INTO student VALUES(null,'小强','男',21,95);

3.1单列排序

  1. 语法: 只按某一个字段进行排序,单列排序
  1. SELECT 字段名 FROM 表名 [WHERE 条件] ORDER BY 字段名 [ASC|DESC]; //ASC: 升序,默认值; DESC: 降序
  1. 练习: 以分数降序查询所有的学生
  1. select * from student order by score desc;

3.2组合排序

  1. 语法: 同时对多个字段进行排序,如果第1个字段相等,则按第2个字段排序,依次类推
  1. SELECT 字段名 FROM 表名 WHERE 字段=值 ORDER BY 字段名1 [ASC|DESC], 字段名2 [ASC|DESC];
  1. 练习: 以分数降序查询所有的学生, 如果分数一致,再以age降序
  1. select * from student order by score desc ,age desc;

4.小结

  1. 排序的语法
  1. order by asc/desc, asc/desc;
  2. asc: 升序【默认值】 order by 列;
  3. desc: 降序
  1. 应用场景
    商城里面 根据价格, 销量, 上架时间, 评论数…
    社交里面 根据距离排序

知识点-聚合函数

1.目标

  • 能够使用聚合函数

2.分析

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

3.讲解

聚合函数 作用
max(列名) 求这一列的最大值
min(列名) 求这一列的最小值
avg(列名) 求这一列的平均值
count(列名) 统计这一列有多少条记录
sum(列名) 对这一列求总和
  1. 语法
  1. SELECT 聚合函数(列名) FROM 表名 [where 条件];
  1. 练习

    • 求出学生表里面的最高分数
    • 求出学生表里面的最低分数
    • 求出学生表里面的分数的总和(忽略null值)
    • 求出学生表里面的平均分
    • 统计学生的总人数 (忽略null)
  1. -- 求出学生表里面的最高分数
  2. SELECT MAX(score) FROM student
  3. -- 求出学生表里面的最低分数
  4. SELECT MIN(score) FROM student
  5. -- 求出学生表里面的分数的总和(忽略null值)
  6. SELECT SUM(score) FROM student
  7. -- 求出学生表里面的平均分
  8. SELECT AVG(score) FROM student
  9. -- 统计学生的总人数 (忽略null)
  10. SELECT COUNT(sid) FROM student
  11. SELECT COUNT(*) FROM student

注意: 聚合函数会忽略空值NULL

  1. 我们发现对于NULL的记录不会统计,建议如果统计个数则不要使用有可能为null的列,但如果需要把NULL也统计进去呢?我们可以通过 IFNULL(列名,默认值) 函数来解决这个问题. 如果列不为空,返回这列的值。如果为NULL,则返回默认值。
  1. -- 注意: 聚合函数会忽略null
  2. -- 准备添加2条数据
  3. INSERT INTO student VALUES(null,'小明','男',21,null);
  4. INSERT INTO student VALUES(null,'小黑','男',22,98);
  5. -- 需求: 统计所有学生的总分数
  6. select sum(score) from student -- 结果: 824 忽略null
  7. -- 需求:统计学生的总人数 (忽略null)
  8. select count(score) from student -- 结果: 10 忽略null
  9. -- 求出学生表里面的平均分
  10. select avg(score) from student -- 结果: 82.4 忽略null 问题:实际开发不能忽略null
  11. select avg(ifnull(score,0)) from student -- 结果: 74.9090909090909
  12. -- 扩展:
  13. -- 假设: 统计所有同学的age+score
  14. select sum(age+score) from student -- 结果: 1040
  15. select sum(age) + sum(score) from student -- 结果: 1061

4.小结

  1. 语法
  1. select 聚合函数(列) from 表名;
  1. 聚合函数

    • max() 最大值
    • min() 最小值
    • sum() 求和
    • avg() 平均值
    • count() 统计数量
  2. 注意事项

    • 聚合函数会忽略null值的
  • 一般需要使用ifnull函数进行判断

知识点-分组查询

1.目标

  • 能够使用SQL语句进行分组查询

2.分析

  1. 分组查询是指使用 GROUP BY语句对查询信息进行分组
  2. GROUP BY怎么分组的? 将分组字段结果中相同内容作为一组,如按性别将学生分成两组
  3. GROUP BY将分组字段结果中相同内容作为一组,并且返回每组的第一条数据,所以单独分组没什么用处。分组的目的就是为了统计,一般分组会跟聚合函数一起使用

3.讲解

3.1分组

  1. 语法
  1. SELECT 字段1,字段2... FROM 表名 [where 条件] GROUP BY [HAVING 条件];
  1. 练习:根据性别分组, 统计每一组学生的总人数
  1. -- 根据性别分组, 统计每一组学生的总人数
  2. SELECT sex, count(*) FROM student GROUP BY sex

3.2 分组后筛选 having

  • 练习根据性别分组, 统计每一组学生的总人数> 5的(分组后筛选)
  1. SELECT sex, count(*) FROM student GROUP BY sex HAVING count(*) > 5
  2. -- 练习复杂: 统计sid8之前的的, 根据性别分组, 每一组学生的总人数 > 2的(分组后筛选)
  3. select sex,count(*) from student where sid < 8 group by sex having count(*) > 2

4.小结

  1. 分组语法
  1. where 条件 group by [having 条件]
  1. 注意事项
    根据某一列进行分组, 将分组字段结果中相同内容作为一组; 有几组 返回的记录就有几条
    单独分组 没有意义, 返回每一组的第一条记录
    分组的目的一般为了做统计使用, 所以经常和聚合函数一起使用
    在分组里面, 如果select后面的列没有出现在group by后面 展示这个组的这个列的第一个数据

  2. where和having的区别【面试】

子名 作用
where 子句 1) 对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据,即先过滤再分组。2) where后面不可以使用聚合函数
having字句 1) having 子句的作用是筛选满足条件的组,即在分组之后过滤数据,即先分组再过滤。2) having后面可以使用聚合函数

知识点-分页查询

1.目标

  • 掌握分页查询

2.分析

  1. LIMIT是限制的意思,所以LIMIT的作用就是限制查询记录的条数. 经常用来做分页查询

3.讲解

  1. 语法
  1. select ... from .... limit a ,b.
LIMIT a,b;
a起始行数,从0开始计数,如果省略,默认就是0; a=(当前页码-1)*b;
b: 返回的行数
  1. 练习
  1. eg: 分页查询学生, 每一页查询4
  2. b=4; a=(当前页码-1)*b;
  3. -- 需求: 分页查询学生, 每一页查询4
  4. select * from student limit 0,4; -- 1
  5. select * from student limit 4,4; -- 2
  6. select * from student limit 8,4; -- 3
  7. -- a=(当前页码-1)*b,b

4.小结

  1. 语法
  1. limit a,b;
  2. a:从哪里开始查询, 0开始计数 a=(当前页码-1)*b
  3. b: 一页查询的数量【固定的,自定义的】
  1. 应用场景
    如果数据库里面的数据量特别大, 我们不建议一次查询出来. 为了提升性能和用户体验, 使用分页

查询的语法小结

  1. select...from...
  2. select...from...where...
  3. select...from...where...order by...
  4. select...from...where...group by...
  5. select...from...where...limit a,b
  6. select...from...where...group by...having....order by...limit

总结

  1. - 能够理解数据库的概念
  2. 存储数据的仓库,特点:可以持久化保存,并且可以通过sql语句进行方便的增删查改
  3. - 能够安装MySql数据库
  4. - 能够使用SQL语句操作数据库
  5. 创建: create database 数据库名;
  6. 删除: drop database 数据库名;
  7. 查看: show databases; show create database 数据库名;
  8. 修改: alter database 数据库名 character set 字符集;
  9. 其他: use 数据库名;
  10. - 能够使用SQL语句操作表结构
  11. 创建:
  12. create table 表名(
  13. 字段名 类型 约束,
  14. ...
  15. 字段名 类型 约束
  16. );
  17. 类型: int,double,varchar(长度),date\datetime
  18. 约束:
  19. 主键: primary key auto_increment
  20. 非空: not null
  21. 唯一: unique
  22. 删除: drop table 表名;
  23. 查询: show tables; desc 表名;
  24. 修改:
  25. alter table 表名 add 列名 类型 约束;
  26. alter table 表名 modify 列名 类型 约束;
  27. alter table 表名 change 旧列名 新列名 类型 约束;
  28. rename table 旧表名 to 新表名;
  29. - 能够使用SQL语句进行数据的添加修改和删除的操作
  30. 添加: insert into 表名(字段,字段) values(值,值);
  31. insert into 表名 values(值,值,...);
  32. 删除:
  33. delete from 表名 where 条件;
  34. truncate table 表名;
  35. 修改:
  36. update 表名 set 字段=值,... where 条件
  37. - 能够使用SQL语句进行条件查询数据
  38. select ... from 表名 where 条件
  39. - 能够使用SQL语句进行排序
  40. select ... from 表名 order by 字段 [asc,desc]
  41. - 能够使用聚合函数
  42. max(),min(),sum(),avg(),count() ifnull()
  43. - 能够使用SQL语句进行分组查询
  44. select ... from 表名 group by 字段 having 条件
  45. - 能够使用SQL语句进行分页查询
  46. select ... from 表名 limit a ,b
  47. 查询总结: select...from...where...group by...having....order by...limit