Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

  官网:https://www.mysql.com/

MySQL概述

MySQL是一个关系型数据库管理系统由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。

应用环境

与其他的大型数据库例如 Oracle、DB2、SQL Server等相比,MySQL 自有它的不足之处,但是这丝毫也没有减少它受欢迎的程度。对于一般的个人使用者和中小型企业来说,MySQL提供的功能已经绰绰有余,而且由于 MySQL是开放源码软件,因此可以大大降低总体拥有成本。

Linux作为操作系统,Apache 或Nginx作为 Web 服务器,MySQL 作为数据库,PHP/Perl/Python作为服务器端脚本解释器。由于这四个软件都是免费或开放源码软件(FLOSS),因此使用这种方式不用花一分钱(除开人工成本)就可以建立起一个稳定、免费的网站系统,被业界称为“LAMP“或“LNMP”组合。

一、为什么要学习数据库

 数据库的优点:

  1. 持久化数据到本地
  2. 可以实现结构化查询,方便管理

定位:

  1. 重点在SQL语句 ,需要能够在没有任何提示下,手写SQL。
  2. 在工作或面试中90%的概率需写SQL语句。
  3. 通过SQL语句去操作数据库
  4. 掌握MySQL、Oracle、SQLserver、PostgreSQL等数据库的区别

二、数据库的相关概念 (DBMS、DB、SQL)     

  1. DB:数据库,保存一组有组织的数据的容器
  2. DBMS:数据库管理系统,又称为数据库软件(产品),用于管理DB中的数据
  3. SQL:结构化查询语言,用于和DBMS通信的语言

三、数据库存储数据的特点

  1. 将数据放到表中,表再放到库中
  2. 一个数据库中可以有多个表,每个表都有一个的名字,用来标识自己。表名具有唯一性。
  3. 表具有一些特性,这些特性定义了数据在表中如何存储,类似java中 “类”的设计。
  4. 表由列组成,我们也称为字段。所有表都是由一个或多个列组成的,每一列类似java 中的”属性”
  5. 表中的数据是按行存储的,每一行类似于java中的“对象”。

四、MySQL产品的介绍

4.1 什么是数据库?

作用:存储数据的,能够长期(断电或关机在开机数据还有)保存数据。
数据存储在哪里:硬盘和内存
我们平时说的数据库:数据管理系统(软件)(Databases Manage System: DBMS)
数据库软件–>多个数据库(databases)–>多个表(tables)–>多条数据(row,col)(一条一行,一行多列)

4.2 数据库的分类

4.2.1 关系型数据库(RDBMS:relative database man)

特点:

  1. 表与表之间有关系
  2. 是通过SQL语句去操作数据库。
  3. 有行有列(和Excel类似)

比较常用:

  • MySQL、PostgreSQL:免费、开源。
  • Oracle:甲骨文,收费,大型公司,一年费用9位数。
  • SQL Server:微软公司,可以安装Windows
  • DB2

4.2.2 非关系型数据库(No-SQL) 

特点:

  1. 表与表之间没有关系
  2. 通过API(java、PHP、Python代码)去操作
  3. 充分使用内存,同步到磁盘

比较常用:
Redis:一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。(网址:http://www.redis.cn/)
HBase:HBase – Hadoop Database,是一个高可靠性、高性能、面向列、可伸缩的分布式存储系统,利用HBase技术可在廉价PC Server上搭建起大规模结构化存储集群。(网址:https://hbase.apache.org/)
mangoDB:由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。(网址:https://www.mongodb.org.cn/)
neo4j:

4.3 什么是SQL

结构化查询语言(Structured Query Language)简称SQL,用于存取数据以及查询、更新(数据的操作)和管理(数据库、表的创建、修改、删除)关系数据库系统;
通过SQL语句去操作关系型数据库,不同的数据库对SQL语句的支持不完全一样,85%的SQL语句,关系型数据库都支持。
各个数据库在SQL语句上都有自己的扩展(方言)。
结构化:有行列的数据
非结构化:视频、音乐

4.4 软件的服务架构

4.4.1 应用场景

刷抖音
抖音APP;短视频通过网络获取,后台有服务器为你提供服务
微信聊天
打开APP,通过网络和别人聊天,在网络之外有服务器提供服务
上淘宝购物
打开浏览器,输入淘宝的网址,后台有服务器为你提供服务

4.4.2 架构模式

C:Client,客户端
S:Server,服务器
B:Browser:浏览器
C/S:客户端/服务器端
抖音APP/微信APP/手淘APP
B/S:浏览器/服务器端
淘宝网站
注意:B/S是特殊的C/S架构。
总结:一个项目,肯定不单单只有一个APP那么简单。

4.4.3 MySQL的架构

MySQL其实就一个B/S架构。
使用MySQL步骤:

  • 先启动MySQL的服务
  • 通过客户端连接MySQL的服务(客户端有很多)
  • 客户端有很多:图形化界面、命令行、代码等(SQLyog、Navicat、DBeaver、DataGrip)

五、MySQL产品的安装

5.1 windows系统MySQL的安装

5.1.1 下载及安装

下载地址:https://dev.mysql.com/downloads/mysql/

本人百度网盘:

链接:https://bianchenghao.cn/s/1VPGwI09Uy0DhZHR1pmh5bQ 
提取码:asdf

.msi文件mysql-5.5.15-win32.msi

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

接受安装协议

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

在出现选择安装类型的窗口中,有“typical(默认)”、“Complete(完全)”、“Custom(用户自定义)”三个选项,我们选择“Custom”,因为通过自定义可以选择安装目录,单击“next”继续安装,如图所示:

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

自定义

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

install

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

finish

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

连续默认next,输入root密码

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

初始化配置finish即可

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

5.1.2 MySQL 环境变量设置

在桌面选择“此电脑”的图标,右键–>属性–>“高级系统设置”–>“环境变量”。

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

新建MYSQL_HOME变量,并将值设置为D:developer_toolsMySQL。

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)编辑Path系统变量:在系统变量里,找到Path变量,“编辑”按钮,将;%MYSQL_HOME%bin添加到path变量(一般放在最后面),注意如果前面有还有其他的配置,一定要在前面加上英文的分号(半角)。

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

5.1.3 启动、关闭服务

方式一:计算机——右击管理——服务Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

方式二:通过管理员身份运行
    net start 服务名(启动服务)
    net stop 服务名(停止服务)
启动命令终端: Win + R–>输入cmd–>回车
启动MySQL服务:net start mysql
关闭MySQL服务:net stop mysql

5.1.4 MySQL服务的登录和退出

方式一:通过mysql自带的客户端
    只限于root用户

方式二:通过windows自带的客户端
    登录:
    mysql 【-h主机名 -P端口号 】-u用户名 -p密码

命令行 mysql -u root -p
-u:user:用户名 root(超级管理员)
-p:password:密码
-h:hostname主机名(ip)
-P:Port端口

在服务中将mysql数据库启动,并在命令窗口中输入“mysql –h localhost –u root -p”,接着在出现的提示中输入用户的密码

cmd:(password为安装时root的密码)

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

    退出:
    exit或ctrl+C

5.2 Linux系统MySQL的安装

下载地址:https://dev.mysql.com/downloads/mysql/

本人百度网盘:

链接:https://bianchenghao.cn/s/1VPGwI09Uy0DhZHR1pmh5bQ 
提取码:asdf

检测是否安装MySQL


卸载自带的MySQL


将安装包上传服务器installPkg目录下。

安装MySQL服务。我们需要将MySQL做成系统服务,开机启动。需要root


PLEASE REMEMBER TO SET A PASSWORD FOR
THE MySQL root USER ! To do so, start the server,
then issue the following commands:
/usr/bin/mysqladmin -u root password ‘new-
password’ /usr/bin/mysqladmin -u root -h
hadoop10 password ‘new-password’
Alternatively you can run:
/usr/bin/mysql_secure_installation
which will also give you the option of removing
the test databases and anonymous user created
by default. This is strongly recommended for
production servers.
See the manual for more instructions.
Please report any problems with the
/usr/bin/mysqlbug script!

安装MySQL客户端


启动MySQL服务


运行脚本


Set root password? [Y/n] y New password: Re-
enter new password: Password updated
successfully! Reloading privilege tables.. …
Success!
Remove anonymous users? [Y/n] y … Success!

Disallow root login remotely? [Y/n] n … skipping.
Remove test database and access to it? [Y/n] y
Dropping test database… … Success!
Removing privileges on test database… …
Success!
Reload privilege tables now? [Y/n] y … Success!
………
Thanks for using MySQL!

无主机登录(远程登录的授权)

方式一:

在命令窗口中输入“mysql –h localhost –u root -p”


方式二:


5.3 数据库连接工具的安装

navicat premium、SQLyog

navicat premium官网:https://www.navicat.com.cn/

SQLyog下载地址:https://sqlyog.en.softonic.com/download

本人网盘:

5.3.1 SQLyog 安装

运行SQLyog-13.1.6-0.x64Community.exe

选择语言

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

单击“下一步”

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

接受“许可证协议”

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

单击“下一步”

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

选择安装位置

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

“下一步”

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

完成

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

选择语言

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

运行应用

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

创建连接

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

连接

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

5.3.2 Navicat安装

navicat下载地址:https://www.navicat.com.cn/download/navicat-premium

或https://www.navicat.com/en/download/navicat-premium

运行navicat150_premium_cs_x64.exe

“下一步”

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

同意许可证

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

选择安装目录

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

选择创建快捷方式的目录

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

“下一步”

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

安装

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

等待安装

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

完成

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

进入应用

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

创建连接

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

测试连接

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

连接

Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)

六、SQL语句

6.1 MySQL的常见命令 

1.查看当前所有的数据库
    show databases;
2.打开指定的库
    use 库名;
3.查看当前库的所有表
    show tables;
4.查看其它库的所有表
    show tables from 库名;
5.创建表
    create table 表名(

        列名 列类型,
        列名 列类型,
        。。。
    );
6. 查看指定表的结构
    desc 表名;

7.  显示表中的所有数据
    select * from 表名;

8.查看服务器的版本
    方式一:登录到mysql服务端
    select version();
    方式二:没有登录到mysql服务端
    mysql –version
    或
    mysql –V

6.2 MySQL的语法规范

  1. 不区分大小写,但建议关键字大写,表名、列名小写
  2. 每条命令最好用分号结尾
  3. 每条命令根据需要,可以进行缩进或换行
  4. 注释:

                单行注释:#注释文字
                单行注释:– 注释文字
                多行注释:/* 注释文字  */

6.3 SQL的语言分类

DQL(Data Query Language):数据查询语言 如:select 
DML(Data Manipulate Language):数据操作语言 如:insert、update、delete
DDL(Data Define Languge):数据定义语言 如:create、drop、alter
TCL(Transaction Control Language):事务控制语言 如:commit、rollback

6.4 SQL关键字

Database:数据库
Table:表格
Row:行;多少行
Field:字段;列
Type:类型
Key:钥匙;键
Show:展示;查看
Query:查询
Create:创建
Modify:修改
Update:更新
Alter:修改
Remove:移除,删除
Drop:删除
Where:在条件;条件
Date:日期
Data:数据

6.5 记事本推荐 

在写sql语句时必不可少的是记事本,这对于写语句,校验,存储sql,都有很大有用处,直接在命令行中打一连串的命令有些不现实。
这里推荐用 Nodepad++
使用:

  1. 在桌面 创建一个文本文件。
  2. 把文件的后缀名改成.sql。
  3. 用nodepad++打开这个文件。
  4. SQL语句的关键字会有提示。

七、数据定义语言 DDL

直接上SQL:myemployees.sql

创建库:myemployees;创建表:departments、employees、jobs、locations。


直接上SQL:girls.sql

创建库:girls;创建表:admin、beauty、boys。


八、数据查询语言 DQL

8.1 基础查询

语法:

select 查询列表 from 表名;

特点:

  1. 查询列表可以是:表中的字段、常量值、表达式、函数
  2. 查询的结果是一个虚拟的表格

选择库:


查询表中的单个字段


查询表中的多个字段


查询表中的所有字段


查询常量值


查询表达式


查询函数


起别名

①便于理解
②如果要查询的字段有重名的情况,使用别名可以区分开来


去重


+号的作用

java中的+号:
①运算符,两个操作数都为数值型
②连接符,只要有一个操作数为字符串

mysql中的+号:
仅仅只有一个功能:运算符

select 100+90; 两个操作数都为数值型,则做加法运算
select ‘123’+90;只要其中一方为字符型,试图将字符型数值转换成数值型
            如果转换成功,则继续做加法运算
select ‘john’+90;    如果转换失败,则将字符型数值转换成0

select null+10; 只要其中一方为null,则结果肯定为null


8.2 条件查询

8.2.1 语法:

    select 
        查询列表
    from
        表名
    where
        筛选条件;

8.2.2 分类:

    1)按条件表达式筛选
    
    简单条件运算符:> < = != <> >= <=
    
    2)按逻辑表达式筛选
    逻辑运算符:
    作用:用于连接条件表达式
        && || !
        and or not
        
    &&和and:两个条件都为true,结果为true,反之为false
    ||或or: 只要有一个条件为true,结果为true,反之为false
    !或not: 如果连接的条件本身为false,结果为true,反之为false
    
    3)模糊查询
        like
        between and
        in
        is null

8.2.3 案例:

按条件表达式筛选

案例1:查询工资>12000的员工信息


案例2:查询部门编号不等于90号的员工名和部门编号


按逻辑表达式筛选
案例1:查询工资z在10000到20000之间的员工名、工资以及奖金   


案例2:查询部门编号不是在90到110之间,或者工资高于15000的员工信息


模糊查询

like

between and

in

is null|is not null

1.like

特点:
①一般和通配符搭配使用
    通配符:
    % 任意多个字符,包含0个字符
    _ 任意单个字符

案例1:查询员工名中包含字符a的员工信息


案例2:查询员工名中第三个字符为n,第五个字符为l的员工名和工资


案例3:查询员工名中第二个字符为_的员工名


2.between and
①使用between and 可以提高语句的简洁度
②包含临界值
③两个临界值不要调换顺序

案例:查询员工编号在100到120之间的员工信息


3.in
含义:判断某字段的值是否属于in列表中的某一项
特点:
    ①使用in提高语句简洁度
    ②in列表的值类型必须一致或兼容
    ③in列表中不支持通配符

案例:查询员工的工种编号是 IT_PROG、AD_VP、AD_PRES中的一个员工名和工种编号


4.is null
=或<>不能用于判断null值
is null或is not null 可以判断null值

案例1:查询没有奖金的员工名和奖金率


案例2:查询有奖金的员工名和奖金率


安全等于  <=>

案例1:查询没有奖金的员工名和奖金率


案例2:查询工资为12000的员工信息


is null VS <=>

IS NULL:仅仅可以判断NULL值,可读性较高,建议使用
<=>    :既可以判断NULL值,又可以判断普通的数值,可读性较低

8.3 排序查询

8.3.1 语法:

select 查询列表
from 表名
【where  筛选条件】
order by 排序的字段或表达式;

8.3.2 特点:

  1. asc代表的是升序,可以省略        desc代表的是降序
  2. order by子句可以支持单个字段、别名、表达式、函数、多个字段
  3. order by子句在查询语句的最后面,除了limit子句

8.3.3 案例:

1、按单个字段排序


2、添加筛选条件再排序

案例1:查询部门编号>=90的员工信息,并按员工编号降序


案例2:选择工资不在8000到17000的员工的姓名和工资,按工资降序


案例3:查询邮箱中包含e的员工信息,并先按邮箱的字节数降序,再按部门号升序


3、按表达式排序

案例:查询员工信息 按年薪降序


4、按别名排序

案例:查询员工信息 按年薪升序


5、按函数排序

案例:查询员工名,并且按名字的长度降序


6、按多个字段排序

案例:查询员工信息,要求先按工资降序,再按employee_id升序


8.4 分组查询

8.4.1 语法:

select 查询列表
from 表
【where 筛选条件】
group by 分组的字段
【order by 排序的字段】;

8.4.2 特点:

1、和分组函数一同查询的字段必须是group by后出现的字段
2、筛选分为两类:分组前筛选和分组后筛选

分组筛选针对的表 位置 连接的关键字分组前筛选原始表 group by前 where分组后筛选group by后的结果集group by后having

问题1:分组函数做筛选能不能放在where后面
答:不能

问题2:where——group by——having

一般来讲,能用分组前筛选的,尽量使用分组前筛选,提高效率

3、分组可以按单个字段也可以按多个字段
4、可以搭配着排序使用
5、having后可以支持别名

8.4.3 案例:

注:用到分组函数的见8.6节

引入:查询某个部门的员工个数


1、简单的分组

案例1:查询每个工种的员工平均工资


案例2:查询每个位置的部门个数


2、可以实现分组前的筛选

案例1:查询邮箱中包含a字符的 每个部门的最高工资


案例2:查询有奖金的每个领导手下员工的平均工资


3、分组后筛选

案例1:查询哪个部门的员工个数>5

①查询每个部门的员工个数


② 筛选刚才①结果(使用HAVING)


案例2:每个工种有奖金的员工的最高工资>12000的工种编号和最高工资


案例3:领导编号>102的每个领导手下的最低工资大于5000的领导编号和最低工资


4.添加排序

案例:每个工种有奖金的员工的最高工资>6000的工种编号和最高工资,按最高工资升序


5.按多个字段分组

案例:查询每个工种每个部门的最低工资,并按最低工资降序


6.额外练习


8.5 常见函数

概念:类似于java的方法,将一组逻辑语句封装在方法体中,对外暴露方法名
好处:1、隐藏了实现细节  2、提高代码的重用性
调用:select 函数名(实参列表) 【from 表】;
特点:
    ①叫什么(函数名)
    ②干什么(函数功能)

分类:
    1、单行函数
    如 concat、length、ifnull等
    2、分组函数
    功能:做统计使用,又称为统计函数、聚合函数、组函数

8.5.1 单行函数

    字符函数:
        concat拼接
        substr截取子串
        upper转换成大写
        lower转换成小写
        trim去前后指定的空格和字符
        ltrim去左边空格
        rtrim去右边空格
        replace替换
        lpad左填充
        rpad右填充
        instr返回子串第一次出现的索引
        length 获取字节个数
    
    数学函数:
        round 四舍五入
        rand 随机数
        floor向下取整
        ceil向上取整
        mod取余
        truncate截断
    
    日期函数:
        now当前系统日期+时间
        curdate当前系统日期
        curtime当前系统时间
        str_to_date 将字符转换成日期
        date_format将日期转换成字符
        year
        month
        monthname
        day
        hour
        minute
        second

    其他函数:
        version版本
        database当前库
        user当前连接用户
    流程控制函数
        if 处理双分支
        case语句 处理多分支
            情况1:处理等值判断
            情况2:处理条件判断if

一、字符函数


二、数学函数


三、日期函数


四、其他函数


五、流程控制函数
1.if函数: if else 的效果


2.case函数的使用一: switch case 的效果

java中
switch(变量或表达式){
    case 常量1:语句1;break;
    …
    default:语句n;break;
}

mysql中

case 要判断的字段或表达式
when 常量1 then 要显示的值1或语句1;
when 常量2 then 要显示的值2或语句2;

else 要显示的值n或语句n;
end

案例:查询员工的工资,要求

部门号=30,显示的工资为1.1倍
部门号=40,显示的工资为1.2倍
部门号=50,显示的工资为1.3倍
其他部门,显示的工资为原工资


3.case 函数的使用二:类似于 多重if

java中:
if(条件1){
    语句1;
}else if(条件2){
    语句2;
}

else{
    语句n;
}

mysql中:

case 
when 条件1 then 要显示的值1或语句1
when 条件2 then 要显示的值2或语句2
。。。
else 要显示的值n或语句n
end

案例:查询员工的工资的情况
如果工资>20000,显示A级别
如果工资>15000,显示B级别
如果工资>10000,显示C级别
否则,显示D级别


额外练习:


8.6 分组函数

8.6.1 功能:

用作统计使用,又称为聚合函数或统计函数或组函数

8.6.2 分类:

sum 求和、avg 平均值、max 最大值 、min 最小值 、count 计算个数

8.6.3 特点:

  1. sum、avg一般用于处理数值型,max、min、count可以处理任何类型
  2. 以上五个分组函数都忽略null值,除了count(*)
  3. 可以和distinct搭配实现去重的运算
  4. count函数的单独介绍,count的参数可以支持:字段、*、常量值、1,建议使用 count(*)
  5. 和分组函数一同查询的字段要求是group by后的字段

1、简单 的使用


2、参数支持哪些类型


3、是否忽略null


4、和distinct搭配


5、count函数的详细介绍


效率:
MYISAM存储引擎下  ,COUNT(*)的效率高
INNODB存储引擎下,COUNT(*)和COUNT(1)的效率差不多,比COUNT(字段)要高一些

6、和分组函数一同查询的字段有限制


额外练习:


8.7 连接查询

含义:又称多表查询,当查询的字段来自于多个表时,就会用到连接查询

笛卡尔乘积现象:表1 有m行,表2有n行,结果=m*n行

发生原因:没有有效的连接条件
如何避免:添加有效的连接条件

分类:

    按年代分类:
    sql92标准:仅仅支持内连接
    sql99标准【推荐】:支持内连接+外连接(左外和右外)+交叉连接
    sql99语法:通过join关键字实现连接;含义:1999年推出的sql语法

    按功能分类:
        内连接:
            等值连接
            非等值连接
            自连接
        外连接:
            左外连接
            右外连接
            全外连接
        
        交叉连接

8.7.1 sql92标准

1)等值连接

① 多表等值连接的结果为多表的交集部分
②n表连接,至少需要n-1个连接条件
③ 多表的顺序没有要求
④一般需要为表起别名
⑤可以搭配前面介绍的所有子句使用,比如排序、分组、筛选

1、基本案例

案例1:查询女神名和对应的男神名


案例2:查询员工名和对应的部门名


2、为表起别名
①提高语句的简洁度
②区分多个重名的字段

注意:如果为表起了别名,则查询的字段就不能使用原来的表名去限定

#查询员工名、工种号、工种名


3、两个表的顺序是否可以调换

#查询员工名、工种号、工种名


4、可以加筛选

案例1:查询有奖金的员工名、部门名


案例2:查询城市名中第二个字符为o的部门名和城市名


5、可以加分组

案例1:查询每个城市的部门个数


案例2:查询有奖金的每个部门的部门名和部门的领导编号和该部门的最低工资


6、可以加排序

#案例:查询每个工种的工种名和员工的个数,并且按员工个数降序


7、可以实现三表连接?

#案例:查询员工名、部门名和所在的城市


2)非等值连接

案例1:查询员工的工资和工资级别



创建工资等级表:


3)自连接

案例:查询 员工名和上级的名称


8.7.2 sql99语法

语法:
    select 字段,…
    from 表1
    【inner|left outer|right outer|cross】join 表2 on  连接条件
    【inner|left outer|right outer|cross】join 表3 on  连接条件
    【where 筛选条件】
    【group by 分组字段】
    【having 分组后的筛选条件】
    【order by 排序的字段或表达式】
    
    好处:语句上,连接条件和筛选条件实现了分离,简洁明了!

分类:
内连接(★):inner
外连接
    左外(★):left 【outer】
    右外(★):right 【outer】
    全外:full【outer】
交叉连接:cross 

Ⅰ、内连接
语法:

select 查询列表
from 表1 别名
inner join 表2 别名
on 连接条件;

分类:
等值
非等值
自连接

特点:
①添加排序、分组、筛选
②inner可以省略
③ 筛选条件放在where后面,连接条件放在on后面,提高分离性,便于阅读
④inner join连接和sql92语法中的等值连接效果是一样的,都是查询多表的交集

1)等值连接

案例1.查询员工名、部门名


案例2.查询名字中包含e的员工名和工种名(添加筛选)


案例3. 查询部门个数>3的城市名和部门个数,(添加分组+筛选)

#①查询每个城市的部门个数
#②在①结果上筛选满足条件的


案例4.查询哪个部门的员工个数>3的部门名和员工个数,并按个数降序(添加排序)

#①查询每个部门的员工个数


#② 在①结果上筛选员工个数>3的记录,并排序


案例5.查询员工名、部门名、工种名,并按部门名降序(添加三表连接)


2)非等值连接

#查询员工的工资级别


#查询工资级别的个数>20的个数,并且按工资级别降序


 3)自连接

#查询员工的名字、上级的名字


#查询姓名中包含字符k的员工的名字、上级的名字


Ⅱ、外连接

应用场景:用于查询一个表中有,另一个表没有的记录

特点:
 1、外连接的查询结果为主表中的所有记录
    如果从表中有和它匹配的,则显示匹配的值
    如果从表中没有和它匹配的,则显示null
    外连接查询结果=内连接结果+主表中有而从表没有的记录
 2、左外连接,left join左边的是主表
    右外连接,right join右边的是主表
 3、左外和右外交换两个表的顺序,可以实现同样的效果 
 4、全外连接=内连接的结果+表1中有但表2没有的+表2中有但表1没有的

#引入:查询男朋友不在男神表的的女神名


#左外连接


#案例1:查询哪个部门没有员工

左外


右外


全外


Ⅲ、交叉连接


sql92 VS sql99
 功能:sql99支持的较多

 可读性:sql99实现连接条件和筛选条件的分离,可读性较高

自连接:

案例:查询员工名和直接上级的名称


外连接:


额外练习:


8.8 子查询

含义:
出现在其他语句中的select语句,称为子查询或内查询
外部的查询语句,称为主查询或外查询

分类:
按子查询出现的位置:
    select后面:
        仅仅支持标量子查询
    
    from后面:
        支持表子查询
    where或having后面:★
        标量子查询(单行) √
        列子查询  (多行) √
        
        行子查询
        
    exists后面(相关子查询)
        表子查询
按结果集的行列数不同:

  •     标量子查询(结果集只有一行一列)
  •     列子查询(结果集只有一列多行)
  •     行子查询(结果集有一行多列)
  •     表子查询(结果集一般为多行多列)

Ⅰ、where或having后面

  1. 标量子查询(单行子查询)
  2. 列子查询(多行子查询)
  3. 行子查询(多列多行)

特点:
①子查询放在小括号内
②子查询一般放在条件的右侧
③标量子查询,一般搭配着单行操作符使用
> < >= <= = <>

列子查询,一般搭配着多行操作符使用
in、any/some、all

④子查询的执行优先于主查询执行,主查询的条件用到了子查询的结果

1.标量子查询★

案例1:谁的工资比 Abel 高?

①查询Abel的工资


查询员工的信息,满足 salary>①结果


案例2:返回job_id与141号员工相同,salary比143号员工多的员工姓名,job_id 和工资

①查询141号员工的job_id


②查询143号员工的salary


③查询员工的姓名,job_id 和工资,要求job_id=①并且salary>②


案例3:返回公司工资最少的员工的last_name,job_id和salary

①查询公司的 最低工资


②查询last_name,job_id和salary,要求salary=①


案例4:查询最低工资大于50号部门最低工资的部门id和其最低工资

①查询50号部门的最低工资


②查询每个部门的最低工资


③ 在②基础上筛选,满足min(salary)>①


非法使用标量子查询


2.列子查询(多行子查询)★
案例1:返回location_id是1400或1700的部门中的所有员工姓名

①查询location_id是1400或1700的部门编号


②查询员工姓名,要求部门号是①列表中的某一个


案例2:返回其它工种中比job_id为‘IT_PROG’工种任一工资低的员工的员工号、姓名、job_id 以及salary

①查询job_id为‘IT_PROG’部门任一工资


②查询员工号、姓名、job_id 以及salary,salary<(①)的任意一个



案例3:返回其它部门中比job_id为‘IT_PROG’部门所有工资都低的员工   的员工号、姓名、job_id 以及salary



3、行子查询(结果集一行多列或多行多列)

案例:查询员工编号最小并且工资最高的员工信息


①查询最小的员工编号


②查询最高工资


③查询员工信息


Ⅱ、select后面
仅仅支持标量子查询

案例:查询每个部门的员工个数


案例2:查询员工号=102的部门名


Ⅲ、from后面
将子查询结果充当一张表,要求必须起别名
案例:查询每个部门的平均工资的工资等级
①查询每个部门的平均工资


②连接①的结果集和job_grades表,筛选条件平均工资 between lowest_sal and highest_sal


Ⅳ、exists后面(相关子查询)
语法:
exists(完整的查询语句)
结果:
1或0

SELECT EXISTS(SELECT employee_id FROM employees WHERE salary=);

案例1:查询有员工的部门名
in


#exists


案例2:查询没有女朋友的男神信息

in


exists


额外练习:


8.9 分页查询

应用场景:当要显示的数据,一页显示不全,需要分页提交sql请求
语法:
    select 查询列表
    from 表
    【join type join 表2
    on 连接条件
    where 筛选条件
    group by 分组字段
    having 分组后的筛选
    order by 排序的字段】
    limit 【offset,】size;
    
    offset要显示条目的起始索引(起始索引从0开始)
    size 要显示的条目个数
特点:
    ①limit语句放在查询语句的最后
    ②公式
    要显示的页数 page,每页的条目数size
    
    select 查询列表
    from 表
    limit (page-1)*size,size;
    
    size=10
    page  
    1    0
    2      10
    3    20

#案例1:查询前五条员工信息


#案例2:查询第11条——第25条


#案例3:有奖金的员工信息,并且工资较高的前10名显示出来


8.10 union联合查询

引入:
    union 联合、合并:将多条查询语句的结果合并成一个结果

语法:

    select 字段|常量|表达式|函数 【from 表】 【where 条件】 union 【all】
    select 字段|常量|表达式|函数 【from 表】 【where 条件】 union 【all】
    select 字段|常量|表达式|函数 【from 表】 【where 条件】 union  【all】
    …..
    select 字段|常量|表达式|函数 【from 表】 【where 条件】

查询语句1
union
查询语句2
union

特点:

    1、多条查询语句的查询的列数必须是一致的
    2、多条查询语句的查询的列的类型几乎相同
    3、union代表去重,union all可以包含重复项

案例1:查询部门编号>90或邮箱包含a的员工信息


案例2:查询中国用户中男性的信息以及外国用户中年男性的用户信息


九、数据操作语言 DML

9.1 插入语句(insert)

方式一:经典的插入
语法:
insert into 表名(列名,…) values(值1,…);


方式二:

语法:
insert into 表名
set 列名=值,列名=值,…


两种方式大pk ★

#1、方式一支持插入多行,方式二不支持

INSERT INTO beauty
VALUES(23,’唐艺昕1′,’女’,’1990-4-23′,”,NULL,2)
,(24,’唐艺昕2′,’女’,’1990-4-23′,”,NULL,2)
,(25,’唐艺昕3′,’女’,’1990-4-23′,”,NULL,2);

#2、方式一支持子查询,方式二不支持

INSERT INTO beauty(id,NAME,phone)
SELECT 26,’宋茜’,”;

INSERT INTO beauty(id,NAME,phone)
SELECT id,boyname,”
FROM boys WHERE id<3;

9.2 修改语句(update)

1.修改单表的记录★

语法:
update 表名
set 列=新值,列=新值,…
where 筛选条件;

2.修改多表的记录【补充】

语法:
sql92语法:
update 表1 别名,表2 别名
set 列=值,…
where 连接条件
and 筛选条件;

sql99语法:
update 表1 别名
inner|left|right join 表2 别名
on 连接条件
set 列=值,…
where 筛选条件;

#1.修改单表的记录
#案例1:修改beauty表中姓唐的女神的电话为

UPDATE beauty SET phone = ”
WHERE NAME LIKE ‘唐%’;

#案例2:修改boys表中id好为2的名称为张飞,魅力值 10
UPDATE boys SET boyname=’张飞’,usercp=10
WHERE id=2;

#2.修改多表的记录

#案例 1:修改张无忌的女朋友的手机号为114

UPDATE boys bo
INNER JOIN beauty b ON bo.`id`=b.`boyfriend_id`
SET b.`phone`=’119′,bo.`userCP`=1000
WHERE bo.`boyName`=’张无忌’;

#案例2:修改没有男朋友的女神的男朋友编号都为2号

UPDATE boys bo
RIGHT JOIN beauty b ON bo.`id`=b.`boyfriend_id`
SET b.`boyfriend_id`=2
WHERE bo.`id` IS NULL;

SELECT * FROM boys

9.3 删除语句 (delete)

方式一:delete
语法:

1、单表的删除【★】
delete from 表名 where 筛选条件

2、多表的删除【补充】

sql92语法:
delete 表1的别名,表2的别名
from 表1 别名,表2 别名
where 连接条件
and 筛选条件;

sql99语法:

delete 表1的别名,表2的别名
from 表1 别名
inner|left|right join 表2 别名 on 连接条件
where 筛选条件;

方式二:truncate
语法:truncate table 表名;

#方式一:delete
#1.单表的删除
#案例:删除手机号以9结尾的女神信息

DELETE FROM beauty WHERE phone LIKE ‘%9’;
SELECT * FROM beauty;

#2.多表的删除

#案例:删除张无忌的女朋友的信息

DELETE b
FROM beauty b
INNER JOIN boys bo ON b.`boyfriend_id` = bo.`id`
WHERE bo.`boyName`=’张无忌’;

#案例:删除黄晓明的信息以及他女朋友的信息
DELETE b,bo
FROM beauty b
INNER JOIN boys bo ON b.`boyfriend_id`=bo.`id`
WHERE bo.`boyName`=’黄晓明’;

#方式二:truncate语句

#案例:将魅力值>100的男神信息删除
TRUNCATE TABLE boys ;

#delete pk truncate【面试题★】

/*

1.delete 可以加where 条件,truncate不能加

2.truncate删除,效率高一丢丢
3.假如要删除的表中有自增长列,
如果用delete删除后,再插入数据,自增长列的值从断点开始,
而truncate删除后,再插入数据,自增长列的值从1开始。
4.truncate删除没有返回值,delete删除有返回值

5.truncate删除不能回滚,delete删除可以回滚.

*/

SELECT * FROM boys;

DELETE FROM boys;
TRUNCATE TABLE boys;
INSERT INTO boys (boyname,usercp)
VALUES(‘张飞’,100),(‘刘备’,100),(‘关云长’,100);

数据的增删改额外练习


十、事务控制语言 TCL

10.1 事务和事务处理

事务的概念:

一个或一组sql语句组成一个执行单,这个执行单要么全部执行,要么全部不执行。

特点:

ACID
原子性:一个事务不可再分割,要么都执行要么都不执行
一致性:一个事务执行会使数据从一个一致状态切换到另外一个一致状态
隔离性:一个事务的执行不受其他事务的干扰
持久性:一个事务一旦提交,则会永久的改变数据库的数据.

事务的分类:

隐式事务,没有明显的开启和结束事务的标志

    比如
    insert、update、delete语句本身就是一个事务

显式事务,具有明显的开启和结束事务的标志

        1、开启事务
        取消自动提交事务的功能
        
        2、编写事务的一组逻辑操作单(多条sql语句)
        insert
        update
        delete
        
        3、提交事务或回滚事务

使用到的关键字

    set autocommit=0;
    start transaction;
    commit;
    rollback;
    
    savepoint  断点
    commit to 断点
    rollback to 断点

事务的隔离级别:

事务并发问题如何发生?

当多个事务同时操作同一个数据库的相同数据时

事务的并发问题有哪些?

  • 脏读:一个事务读取到了另外一个事务未提交的数据
  • 不可重复读:同一个事务中,多次读取到的数据不一致
  • 幻读:一个事务读取数据时,另外一个事务进行更新,导致第一个事务读取到了没有更新的数据

如何避免事务的并发问题?

    通过设置事务的隔离级别
    1、READ UNCOMMITTED
    2、READ COMMITTED 可以避免脏读
    3、REPEATABLE READ 可以避免脏读、不可重复读和一部分幻读
    4、SERIALIZABLE可以避免脏读、不可重复读和幻读
    
设置隔离级别:

set session|global  transaction isolation level 隔离级别名;

查看隔离级别:

    select @@tx_isolation;

事务的创建

隐式事务:事务没有明显的开启和结束的标记

比如insert、update、delete语句

delete from 表 where id =1;

显式事务:事务具有明显的开启和结束的标记
前提:必须先设置自动提交功能为禁用

set autocommit=0;

步骤1:开启事务
set autocommit=0;
start transaction;可选的

步骤2:编写事务中的sql语句(select insert update delete)
语句1;
语句2;

步骤3:结束事务
commit;提交事务
rollback;回滚事务

savepoint 节点名;设置保存点

事务的隔离级别:

脏读 不可重复读幻读read uncommitted√√ √ read committed×√ √ repeatable read××√serializable ×××

mysql中默认 第三个隔离级别 repeatable read
oracle中默认第二个隔离级别 read committed
查看隔离级别
select @@tx_isolation;
设置隔离级别
set session|global transaction isolation level 隔离级别;

开启事务的语句;
update 表 set 张三丰的余额=500 where name=’张三丰’

update 表 set 郭襄的余额=1500 where name=’郭襄’ 
结束事务的语句;

SHOW VARIABLES LIKE ‘autocommit’;
SHOW ENGINES;

1.演示事务的使用步骤


2.演示事务对于delete和truncate的处理的区别


3.演示savepoint 的使用


十一、视图

11.1 定义:

        一张虚拟的表(逻辑表),不占用物理空间。

11.2 视图和表的区别:

使用方式占用物理空间视图完全相同 不占用,仅仅保存的是sql逻辑表 完全相同占用

11.3 视图的好处:

    1、sql语句提高重用性,效率高
    2、和表实现了分离,提高了安全性

11.4 视图的创建

语法:

    CREATE VIEW  视图名
    AS
    查询语句;

11.5 视图的增删改查:

    1、查看视图的数据 ★


    2、插入视图的数据


    3、修改视图的数据


    4、删除视图的数据


11.6 某些视图不能更新

  • 包含以下关键字的sql语句:分组函数、distinct、group  by、having、union或者union all
  • 常量视图
  • Select中包含子查询
  • join
  • from一个不能更新的视图
  • where子句的子查询引用了from子句中的表

11.7 视图逻辑的更新


11.8 视图的删除


11.9 视图结构的查看    


11.10 案例

案例一:创建视图emp_v1,要求查询电话号码以‘011’开头的员工姓名和工资、邮箱


案例二:创建视图emp_v2,要求查询部门的最高工资高于12000的部门信息


十二、变量

系统变量:
    全局变量
    会话变量

自定义变量:
    用户变量
    局部变量

#一、系统变量
/*
说明:变量由系统定义,不是用户定义,属于服务器层面
注意:全局变量需要添加global关键字,会话变量需要添加session关键字,如果不写,默认会话级别
使用步骤:
1、查看所有系统变量
show global|【session】variables;
2、查看满足条件的部分系统变量
show global|【session】 variables like ‘%char%’;
3、查看指定的系统变量的值
select @@global|【session】系统变量名;
4、为某个系统变量赋值
方式一:
set global|【session】系统变量名=值;
方式二:
set @@global|【session】系统变量名=值;

*/
#1》全局变量
/*
作用域:针对于所有会话(连接)有效,但不能跨重启
*/
#①查看所有全局变量
SHOW GLOBAL VARIABLES;
#②查看满足条件的部分系统变量
SHOW GLOBAL VARIABLES LIKE ‘%char%’;
#③查看指定的系统变量的值
SELECT @@global.autocommit;
#④为某个系统变量赋值
SET @@global.autocommit=0;
SET GLOBAL autocommit=0;

#2》会话变量
/*
作用域:针对于当前会话(连接)有效
*/
#①查看所有会话变量
SHOW SESSION VARIABLES;
#②查看满足条件的部分会话变量
SHOW SESSION VARIABLES LIKE ‘%char%’;
#③查看指定的会话变量的值
SELECT @@autocommit;
SELECT @@session.tx_isolation;
#④为某个会话变量赋值
SET @@session.tx_isolation=’read-uncommitted’;
SET SESSION tx_isolation=’read-committed’;

#二、自定义变量
/*
说明:变量由用户自定义,而不是系统提供的
使用步骤:
1、声明
2、赋值
3、使用(查看、比较、运算等)
*/

#1》用户变量
/*
作用域:针对于当前会话(连接)有效,作用域同于会话变量
*/

#赋值操作符:=或:=
#①声明并初始化
SET @变量名=值;
SET @变量名:=值;
SELECT @变量名:=值;

#②赋值(更新变量的值)
#方式一:
    SET @变量名=值;
    SET @变量名:=值;
    SELECT @变量名:=值;
#方式二:
    SELECT 字段 INTO @变量名
    FROM 表;
#③使用(查看变量的值)
SELECT @变量名;

#2》局部变量
/*
作用域:仅仅在定义它的begin end块中有效
应用在 begin end中的第一句话
*/

#①声明
DECLARE 变量名 类型;
DECLARE 变量名 类型 【DEFAULT 值】;

#②赋值(更新变量的值)

#方式一:
    SET 局部变量名=值;
    SET 局部变量名:=值;
    SELECT 局部变量名:=值;
#方式二:
    SELECT 字段 INTO 具备变量名
    FROM 表;
#③使用(查看变量的值)
SELECT 局部变量名;

案例:声明两个变量,求和并打印

用户变量


局部变量


用户变量和局部变量的对比

作用域定义位置语法用户变量 当前会话会话的任何地方加@符号,不用指定类型局部变量 定义它的BEGIN END中BEGIN END的第一句话一般不用加@,需要指定类型

十三、存储过程和函数

存储过程和函数:类似于java中的方法
好处:
1、提高代码的重用性
2、简化操作

存储过程
含义:一组预先编译好的SQL语句的集合,理解成批处理语句
1、提高代码的重用性
2、简化操作
3、减少了编译次数并且减少了和数据库服务器的连接次数,提高了效率

#一、创建语法

CREATE PROCEDURE 存储过程名(参数列表)
BEGIN

    存储过程体(一组合法的SQL语句)
END

#注意:
/*
1、参数列表包含三部分
参数模式  参数名  参数类型
举例:
in stuname varchar(20)

参数模式:
in:该参数可以作为输入,也就是该参数需要调用方传入值
out:该参数可以作为输出,也就是该参数可以作为返回值
inout:该参数既可以作为输入又可以作为输出,也就是该参数既需要传入值,又可以返回值

2、如果存储过程体仅仅只有一句话,begin end可以省略
存储过程体中的每条sql语句的结尾要求必须加分号。
存储过程的结尾可以使用 delimiter 重新设置
语法:
delimiter 结束标记
案例:
delimiter $
*/

#二、调用语法

CALL 存储过程名(实参列表);

#——————————–案例演示———————————–
#1.空参列表
#案例:插入到admin表中五条记录

SELECT * FROM admin;

DELIMITER $
CREATE PROCEDURE myp1()
BEGIN
    INSERT INTO admin(username,`password`) 
    VALUES(‘john1′,’0000’),(‘lily’,’0000′),(‘rose’,’0000′),(‘jack’,’0000′),(‘tom’,’0000′);
END $

#调用
CALL myp1()$

#2.创建带in模式参数的存储过程

#案例1:创建存储过程实现 根据女神名,查询对应的男神信息

CREATE PROCEDURE myp2(IN beautyName VARCHAR(20))
BEGIN
    SELECT bo.*
    FROM boys bo
    RIGHT JOIN beauty b ON bo.id = b.boyfriend_id
    WHERE b.name=beautyName;
    

END $

#调用
CALL myp2(‘柳岩’)$

#案例2 :创建存储过程实现,用户是否登录成功

CREATE PROCEDURE myp4(IN username VARCHAR(20),IN PASSWORD VARCHAR(20))
BEGIN
    DECLARE result INT DEFAULT 0;#声明并初始化
    
    SELECT COUNT(*) INTO result#赋值
    FROM admin
    WHERE admin.username = username
    AND admin.password = PASSWORD;
    
    SELECT IF(result>0,’成功’,’失败’);#使用
END $

#调用
CALL myp3(‘张飞’,’8888′)$

#3.创建out 模式参数的存储过程
#案例1:根据输入的女神名,返回对应的男神名

CREATE PROCEDURE myp6(IN beautyName VARCHAR(20),OUT boyName VARCHAR(20))
BEGIN
    SELECT bo.boyname INTO boyname
    FROM boys bo
    RIGHT JOIN
    beauty b ON b.boyfriend_id = bo.id
    WHERE b.name=beautyName ;
    
END $

#案例2:根据输入的女神名,返回对应的男神名和魅力值

CREATE PROCEDURE myp7(IN beautyName VARCHAR(20),OUT boyName VARCHAR(20),OUT usercp INT) 
BEGIN
    SELECT boys.boyname ,boys.usercp INTO boyname,usercp
    FROM boys 
    RIGHT JOIN
    beauty b ON b.boyfriend_id = boys.id
    WHERE b.name=beautyName ;
    
END $

#调用
CALL myp7(‘小昭’,@name,@cp)$
SELECT @name,@cp$

#4.创建带inout模式参数的存储过程
#案例1:传入a和b两个值,最终a和b都翻倍并返回

CREATE PROCEDURE myp8(INOUT a INT ,INOUT b INT)
BEGIN
    SET a=a*2;
    SET b=b*2;
END $

#调用
SET @m=10$
SET @n=20$
CALL myp8(@m,@n)$
SELECT @m,@n$

#三、删除存储过程
#语法:drop procedure 存储过程名
DROP PROCEDURE p1;
DROP PROCEDURE p2,p3;#×

#四、查看存储过程的信息
DESC myp2;×
SHOW CREATE PROCEDURE  myp2;

函数
含义:一组预先编译好的SQL语句的集合,理解成批处理语句
1、提高代码的重用性
2、简化操作
3、减少了编译次数并且减少了和数据库服务器的连接次数,提高了效率

区别:

存储过程:可以有0个返回,也可以有多个返回,适合做批量插入、批量更新
函数:有且仅有1 个返回,适合做处理数据后返回一个结果

#一、创建语法
CREATE FUNCTION 函数名(参数列表) RETURNS 返回类型
BEGIN
    函数体
END
/*

注意:
1.参数列表 包含两部分:
参数名 参数类型

2.函数体:肯定会有return语句,如果没有会报错
如果return语句没有放在函数体的最后也不报错,但不建议

return 值;
3.函数体中仅有一句话,则可以省略begin end
4.使用 delimiter语句设置结束标记

*/

#二、调用语法
SELECT 函数名(参数列表)

#——————————案例演示—————————-
#1.无参有返回
#案例:返回公司的员工个数
CREATE FUNCTION myf1() RETURNS INT
BEGIN

    DECLARE c INT DEFAULT 0;#定义局部变量
    SELECT COUNT(*) INTO c#赋值
    FROM employees;
    RETURN c;
    
END $

SELECT myf1()$

#2.有参有返回
#案例1:根据员工名,返回它的工资

CREATE FUNCTION myf2(empName VARCHAR(20)) RETURNS DOUBLE
BEGIN
    SET @sal=0;#定义用户变量 
    SELECT salary INTO @sal   #赋值
    FROM employees
    WHERE last_name = empName;
    
    RETURN @sal;
END $

SELECT myf2(‘k_ing’) $

#案例2:根据部门名,返回该部门的平均工资

CREATE FUNCTION myf3(deptName VARCHAR(20)) RETURNS DOUBLE
BEGIN
    DECLARE sal DOUBLE ;
    SELECT AVG(salary) INTO sal
    FROM employees e
    JOIN departments d ON e.department_id = d.department_id
    WHERE d.department_name=deptName;
    RETURN sal;
END $

SELECT myf3(‘IT’)$

#三、查看函数

SHOW CREATE FUNCTION myf3;

#四、删除函数
DROP FUNCTION myf3;

#案例
#一、创建函数,实现传入两个float,返回二者之和

CREATE FUNCTION test_fun1(num1 FLOAT,num2 FLOAT) RETURNS FLOAT
BEGIN
    DECLARE SUM FLOAT DEFAULT 0;
    SET SUM=num1+num2;
    RETURN SUM;
END $

SELECT test_fun1(1,2)$

十四、流程控制结构  

顺序、分支、循环

一、分支结构
1.if函数

语法:if(条件,值1,值2)
功能:实现双分支
应用在begin end中或外面

#2.case结构
/*
语法:
情况1:类似于switch
case 变量或表达式
when 值1 then 语句1;
when 值2 then 语句2;

else 语句n;
end 

情况2:
case 
when 条件1 then 语句1;
when 条件2 then 语句2;

else 语句n;
end 

应用在begin end 中或外面

*/

#3.if结构

/*
语法:
if 条件1 then 语句1;
elseif 条件2 then 语句2;
….
else 语句n;
end if;
功能:类似于多重if

只能应用在begin end 中

*/

#案例1:创建函数,实现传入成绩,如果成绩>90,返回A,如果成绩>80,返回B,如果成绩>60,返回C,否则返回D

CREATE FUNCTION test_if(score FLOAT) RETURNS CHAR
BEGIN
    DECLARE ch CHAR DEFAULT ‘A’;
    IF score>90 THEN SET ch=’A’;
    ELSEIF score>80 THEN SET ch=’B’;
    ELSEIF score>60 THEN SET ch=’C’;
    ELSE SET ch=’D’;
    END IF;
    RETURN ch;
    
    
END $

SELECT test_if(87)$

#案例2:创建存储过程,如果工资<2000,则删除,如果5000>工资>2000,则涨工资1000,否则涨工资500

CREATE PROCEDURE test_if_pro(IN sal DOUBLE)
BEGIN
    IF sal<2000 THEN DELETE FROM employees WHERE employees.salary=sal;
    ELSEIF sal>=2000 AND sal<5000 THEN UPDATE employees SET salary=salary+1000 WHERE employees.`salary`=sal;
    ELSE UPDATE employees SET salary=salary+500 WHERE employees.`salary`=sal;
    END IF;
    
END $

CALL test_if_pro(2100)$

#案例1:创建函数,实现传入成绩,如果成绩>90,返回A,如果成绩>80,返回B,如果成绩>60,返回C,否则返回D

CREATE FUNCTION test_case(score FLOAT) RETURNS CHAR
BEGIN 
    DECLARE ch CHAR DEFAULT ‘A’;
    
    CASE 
    WHEN score>90 THEN SET ch=’A’;
    WHEN score>80 THEN SET ch=’B’;
    WHEN score>60 THEN SET ch=’C’;
    ELSE SET ch=’D’;
    END CASE;
    
    RETURN ch;
END $

SELECT test_case(56)$

#二、循环结构
/*
分类:
while、loop、repeat

循环控制:

iterate类似于 continue,继续,结束本次循环,继续下一次
leave 类似于  break,跳出,结束当前所在的循环

*/

#1.while
/*

语法:

【标签:】while 循环条件 do
    循环体;
end while【 标签】;

联想:

while(循环条件){

    循环体;
}

*/

#2.loop
/*

语法:
【标签:】loop
    循环体;
end loop 【标签】;

可以用来模拟简单的死循环

*/

#3.repeat
/*
语法:
【标签:】repeat
    循环体;
until 结束循环的条件
end repeat 【标签】;

*/

#1.没有添加循环控制语句
#案例:批量插入,根据次数插入到admin表中多条记录
DROP PROCEDURE pro_while1$
CREATE PROCEDURE pro_while1(IN insertCount INT)
BEGIN
    DECLARE i INT DEFAULT 1;
    WHILE i<=insertCount DO
        INSERT INTO admin(username,`password`) VALUES(CONCAT(‘Rose’,i),’666′);
        SET i=i+1;
    END WHILE;
    
END $

CALL pro_while1(100)$

/*

int i=1;
while(i<=insertcount){

    //插入
    
    i++;

}

*/

#2.添加leave语句

#案例:批量插入,根据次数插入到admin表中多条记录,如果次数>20则停止
TRUNCATE TABLE admin$
DROP PROCEDURE test_while1$
CREATE PROCEDURE test_while1(IN insertCount INT)
BEGIN
    DECLARE i INT DEFAULT 1;
    a:WHILE i<=insertCount DO
        INSERT INTO admin(username,`password`) VALUES(CONCAT(‘xiaohua’,i),’0000′);
        IF i>=20 THEN LEAVE a;
        END IF;
        SET i=i+1;
    END WHILE a;
END $

CALL test_while1(100)$

#3.添加iterate语句

#案例:批量插入,根据次数插入到admin表中多条记录,只插入偶数次
TRUNCATE TABLE admin$
DROP PROCEDURE test_while1$
CREATE PROCEDURE test_while1(IN insertCount INT)
BEGIN
    DECLARE i INT DEFAULT 0;
    a:WHILE i<=insertCount DO
        SET i=i+1;
        IF MOD(i,2)!=0 THEN ITERATE a;
        END IF;
        
        INSERT INTO admin(username,`password`) VALUES(CONCAT(‘xiaohua’,i),’0000′);
        
    END WHILE a;
END $

CALL test_while1(100)$

/*

int i=0;
while(i<=insertCount){
    i++;
    if(i%2==0){
        continue;
    }
    插入
    
}

*/

流程控制经典案例:


十五、常见约束

含义:

        一种限制,用于限制表中的数据,为了保证表中的数据的准确和可靠性

分类:六大约束
    NOT NULL:非空,用于保证该字段的值不能为空
    比如姓名、学号等
    DEFAULT:默认,用于保证该字段有默认值
    比如性别
    PRIMARY KEY:主键,用于保证该字段的值具有唯一性,并且非空
    比如学号、员工编号等
    UNIQUE:唯一,用于保证该字段的值具有唯一性,可以为空
    比如座位号
    CHECK:检查约束【mysql中不支持】
    比如年龄、性别
    FOREIGN KEY:外键,用于限制两个表的关系,用于保证该字段的值必须来自于主表的关联列的值
        在从表添加外键约束,用于引用主表中某列的值
    比如学生表的专业编号,员工表的部门编号,员工表的工种编号

添加约束的时机:
    1.创建表时
    2.修改表时    

约束的添加分类:
    列级约束:
        六大约束语法上都支持,但外键约束没有效果
        
    表级约束:

        除了非空、默认,其他的都支持
        
主键和唯一的大对比:

保证唯一性  是否允许为空一个表中可以有多少个是否允许组合主键√  ×至多有1个√,但不推荐唯一 √  √可以有多个√,但不推荐

外键:
    1、要求在从表设置外键关系
    2、从表的外键列的类型和主表的关联列的类型要求一致或兼容,名称无要求
    3、主表的关联列必须是一个key(一般是主键或唯一)
    4、插入数据时,先插入主表,再插入从表
    删除数据时,先删除从表,再删除主表

CREATE TABLE 表名(
    字段名 字段类型 列级约束,
    字段名 字段类型,
    表级约束

)
CREATE DATABASE students;

15.1 创建表时添加约束

1.添加列级约束

语法:

直接在字段名和类型后面追加约束类型即可。

只支持:默认、非空、主键、唯一



查看stuinfo中的所有索引,包括主键、外键、唯一


2.添加表级约束

语法:在各个字段的最下面
 【constraint 约束名】 约束类型(字段名) 


SHOW INDEX FROM stuinfo;

通用的写法:★


15.2 修改表时添加约束

1、添加列级约束

alter table 表名 modify column 字段名 字段类型 新约束;

2、添加表级约束

alter table 表名 add 【constraint 约束名】 约束类型(字段名) 【外键的引用】;


3.添加非空约束


4.添加默认约束


5.添加主键


6.添加唯一


7.添加外键


15.3 修改表时删除约束

1.删除非空约束


2.删除默认约束


3.删除主键


4.删除唯一


5.删除外键


15.4 常见约束案例

1.向表emp2的id列中添加PRIMARY KEY约束(my_emp_id_pk)


2.    向表dept2的id列中添加PRIMARY KEY约束(my_dept_id_pk)

3.    向表emp2中添加列dept_id,并在其中定义FOREIGN KEY约束,与之相关联的列是dept2表中的id列。


对比:

位置支持的约束类型 是否可以起约束名列级约束列的后面语法都支持,但外键没有效果不可以表级约束所有列的下面 默认和非空不支持,其他支持可以(主键没有效果)

十六、标识列

又称为自增长列
含义:可以不用手动的插入值,系统提供默认的序列值

特点:
1、标识列必须和主键搭配吗?不一定,但要求是一个key
2、一个表可以有几个标识列?至多一个!
3、标识列的类型只能是数值型
4、标识列可以通过 SET auto_increment_increment=3;设置步长
可以通过 手动插入值,设置起始值

16.1 创建表时设置标识列


truncate表:



Navicat Premium 8.1.12激活今天的文章
Navicat Premium 8.1.12激活(Mysql全站最全笔记,从入门到资深!)分享到此就结束了,感谢您的阅读。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/117669.html

(0)
编程小号编程小号
上一篇 2024-07-14
下一篇 2024-07-14

相关推荐