MYSQL基础语法笔记

MYSQL基础语法

学习目标

  1. 能够理解数据库的概念(知道数据库是什么,能够做什么)
  2. 能够安装MySQL数据库(重点)
  3. 能够启动,关闭及登录MySQL(简单)
  4. 能够使用SQL语句操作数据库(创建、修改、删除数据库)(了解)
  5. 能够使用SQL语句操作表结构(创建(掌握)、修改、删除表)(了解)
  6. 能够使用SQL语句进行数据的添加修改和删除的操作(重点,必须掌握)
  7. 能够使用SQL语句简单查询数据(重中之重)

第1章 数据库的介绍

1.1 数据库概述

1.1.1 什么是数据库

​ 存储数据的仓库. 其本质是一个文件系统,数据库按照特定的格式将数据存储起来,用户可以对数据库中的数据进行增加,修改,删除及查询操作。

1.1.2 数据的存储方式

  1. 数据保存在内存

    int[] arr = newint[]{1, 2, 3, 4};
    ArrayList<Integer>list = new ArrayList<Integer>();
    list.add(1);
    

    new出来的对象存储在堆中.堆是内存中的一小块空间

    优点:内存速度快
    缺点:断电/程序退出,数据就清除了.内存价格贵

  2. 数据保存在普通文件
    优点:永久保存
    缺点:查找,增加,修改,删除数据比较麻烦,效率低

  3. 数据保存在数据库
    优点:永久保存,通过SQL语句比较方便的操作数据库

大文件存放的方法:将这些文件存放在普通文件夹中,然后将这些文件的路径存放在数据库

1.2 数据库的优点

​ 数据库是按照特定的格式将数据存储在文件中,通过SQL语句可以方便的对大量数据进行增、删、改、查操作,数据库是对大量的信息进行管理的高效的解决方案。

1.3 常见关系型数据库软件

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-niO4g3YK-1571680089067)(image\常见数据库.PNG)]
MYSQL:开源免费的数据库,小型的数据库.已经被Oracle收购了.MySQL6.x版本也开始收费。
Oracle:收费的大型数据库,Oracle公司的产品。Oracle收购SUN公司,收购MYSQL。
DB2 :IBM公司的数据库产品,收费的。常应用在银行系统中.
SQLServer:MicroSoft 公司收费的中型的数据库。C#、.net等语言常使用。
SyBase:已经淡出历史舞台。提供了一个非常专业数据建模的工具PowerDesigner。
SQLite: 嵌入式的小型数据库,应用在手机端。

常用数据库MYSQLOracle
在web应用中,使用的最多的就是MySQL数据库,原因如下:

  1. 开源、免费
  2. 功能足够强大,足以应付web应用开发(最高支持千万级别的并发访问)

第2章 数据库的安装与使用

2.1 数据库的安装

Mac的MySQL下载地址:https://dev.mysql.com/downloads/mysql/5.7.html#downloads

Max的MySQL安装教程:https://www.jianshu.com/p/07a9826898c0

  1. 打开下载的mysql安装文件双击解压缩,运行“mysql-5.5.40-win32.msi”。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Gm0zLyKo-1571680089068)(image\MYSQL安装01.png)]
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-zRBrjOIS-1571680089068)(image\MYSQL安装02.png)]

  2. 选择安装类型,有“Typical(默认)”、“Complete(完全)”、“Custom(用户自定义)”三个选项,选择“Custom”,按“next”键继续。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0X7F6xDV-1571680089069)(image\MYSQL安装03.png)]

  3. 点选“Browse”,手动指定安装目录。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wg9Z1lrF-1571680089071)(image\MYSQL安装04.png)]

  4. 填上安装目录,我的是“d:\Program Files (x86)\MySQL\MySQL Server 5.0”,按“OK”继续。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XmbXwXzu-1571680089072)(image\MYSQL安装05.png)]

  5. 确认一下先前的设置,如果有误,按“Back”返回重做。按“Install”开始安装。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9DJeyvOx-1571680089073)(image\MYSQL安装06.png)]
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fm9JT8qL-1571680089074)(image\MYSQL安装07.png)]
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gIQVAT1z-1571680089075)(image\MYSQL安装08.png)]
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YTLKgpIY-1571680089076)(image\MYSQL安装09.png)]
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-AYPiH4CO-1571680089077)(image\MYSQL安装10.png)]

  6. 正在安装中,请稍候,直到出现下面的界面, 则完成MYSQL的安装
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-AV4KDJBI-1571680089078)(image\MYSQL安装11.png)]

数据库安装好了还需要对数据库进行配置才能使用
MYSQL的配置

  1. 安装完成了,出现如下界面将进入mysql配置向导。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WV2IBBMv-1571680089081)(image\MYSQL安装12.png)]

  2. 选择配置方式,“Detailed Configuration(手动精确配置)”、“Standard Configuration(标准配置)”,我们选择“Detailed Configuration”,方便熟悉配置过程。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XLNHIzF7-1571680089083)(image\MYSQL安装13.png)]

  3. 选择服务器类型,“Developer Machine(开发测试类,mysql占用很少资源)”、“Server Machine(服务器类型,mysql占用较多资源)”、“Dedicated MySQL Server Machine(专门的数据库服务器,mysql占用所有可用资源)”
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vqXLStGb-1571680089086)(image\MYSQL安装14.png)]

  4. 选择mysql数据库的大致用途,“Multifunctional Database(通用多功能型,好)”、“Transactional Database Only(服务器类型,专注于事务处理,一般)”、“Non-Transactional Database Only(非事务处理型,较简单,主要做一些监控、记数用,对MyISAM数据类型的支持仅限于non-transactional),按“Next”继续。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uxhq2gVx-1571680089088)(image\MYSQL安装15.png)]
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hiojUqj4-1571680089090)(image\MYSQL安装16.png)]

  5. 选择网站并发连接数,同时连接的数目,“Decision Support(DSS)/OLAP(20个左右)”、“Online Transaction Processing(OLTP)(500个左右)”、“Manual Setting(手动设置,自己输一个数)”。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Yi4sL7Qy-1571680089091)(image\MYSQL安装17.png)]

  6. 是否启用TCP/IP连接,设定端口,如果不启用,就只能在自己的机器上访问mysql数据库了,在这个页面上,您还可以选择“启用标准模式”(Enable Strict Mode),这样MySQL就不会允许细小的语法错误。如果是新手,建议您取消标准模式以减少麻烦。但熟悉MySQL以后,尽量使用标准模式,因为它可以降低有害数据进入数据库的可能性。按“Next”继续
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nXQOW3Dq-1571680089092)(image\MYSQL安装18.png)]

  7. 就是对mysql默认数据库语言编码进行设置(重要),一般选UTF-8,按 “Next”继续。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qJSQmkOW-1571680089093)(image\MYSQL安装19.png)]

  8. 选择是否将mysql安装为windows服务,还可以指定Service Name(服务标识名称),是否将mysql的bin目录加入到Windows PATH(加入后,就可以直接使用bin下的文件,而不用指出目录名,比如连接,“mysql.exe -uusername -ppassword;”就可以了,不用指出mysql.exe的完整地址,很方便),我这里全部打上了勾,Service Name不变。按“Next”继续。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9tFQxHCm-1571680089094)(image\MYSQL安装20.png)]

  9. 询问是否要修改默认root用户(超级管理)的密码。“Enable root access from remote machines(是否允许root用户在其它的机器上登陆,如果要安全,就不要勾上,如果要方便,就勾上它)”。最后“Create An Anonymous Account(新建一个匿名用户,匿名用户可以连接数据库,不能操作数据,包括查询)”,一般就不用勾了,设置完毕,按“Next”继续。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kB88qDkW-1571680089096)(image\MYSQL安装21.png)]

  10. 确认设置无误,按“Execute”使设置生效,即完成MYSQL的安装和配置。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HNvECAgr-1571680089102)(image\MYSQL安装22.png)]
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MF6zhmHq-1571680089103)(image\MYSQL安装23.png)]

注意:设置完毕,按“Finish”后有一个比较常见的错误,就是不能“Start service”,一般出现在以前有安装mysql的服务器上,解决的办法,先保证以前安装的mysql服务器彻底卸载掉了;不行的话,检查是否按上面一步所说,之前的密码是否有修改,照上面的操作;如果依然不行,将mysql安装目录下的data文件夹备份,然后删除,在安装完成后,将安装生成的 data文件夹删除,备份的data文件夹移回来,再重启mysql服务就可以了,这种情况下,可能需要将数据库检查一下,然后修复一次,防止数据出错。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6Hu5JLH8-1571680089104)(image\MYSQL安装24.png)]

解决方法:卸载MySQL,重装MySQL

2.3 数据库的卸载

  1. 停止window的MySQL服务。
    找到“控制面板”-> “管理工具”-> “服务”,停止MySQL后台服务。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-knuItTY3-1571680089105)(image\MYSQL卸载01.png)]

  2. 卸载MySQL安装程序。找到“控制面板”-> “程序和功能”,卸载MySQL程序。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-3DvGdsrA-1571680089106)(image\MYSQL卸载02.png)]

  3. 删除MySQL安装目录下的所有文件。

  4. 删除c盘ProgramDate目录中关于MySQL的目录。路径为:C:\ProgramData\MySQL(是隐藏文件,需要显示出来)
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mo0nuBY2-1571680089106)(image\MYSQL卸载03.png)]
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-CwewtUsV-1571680089107)(image\MYSQL卸载04.png)]

2.4 数据库的启动

MySQL启动方式和普通的windows程序双击启动方式不同,分为以下2种:

  1. Windows服务方式启动
    操作步骤:
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uAtKWwfb-1571680089109)(image\mysql启动01.png)]
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-R2PuJuJG-1571680089111)(image\mysql启动02.png)]

  2. DOS命令方式启动
    操作步骤:
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Tojzq4iy-1571680089120)(image\mysql启动03.png)]
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Wxr7to5D-1571680089126)(image\mysql启动04.png)]

    启动MYSQL: net start mysql
    停止MYSQL: net stop mysql

2.5 控制台连接数据库(了解)

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

  1. 登录格式1:mysql -u用户名 -p密码
    例如:mysql –uroot -proot
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SzeNW8tt-1571680089133)(image\MYSQL登录01.png)]
    后输入密码方式:

    mysql -u用户名 -p回车

    密码

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-UMs2rfyx-1571680089135)(image\MYSQL登录04.png)]

  2. 登录格式2:连接另外一台电脑的MySQL服务器)
    例如:mysql –h127.0.0.1 –uroot -proot
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-T9zwo3qO-1571680089143)(image\MYSQL登录02.png)]

  3. 登录格式3:mysql --host=ip地址 --user=用户名 --password=密码
    例如:mysql --host=localhost --user=root --password=root
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-G6veLbKC-1571680089144)(image\MYSQL登录03.png)]

  4. 退出MySQL:exit
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-CkCrC1TB-1571680089145)(image\MYSQL退出01.png)]

2.6 SQLyog图形化工具安装

​ SQLyog是业界著名的Webyog公司出品的一款简洁高效、功能强大的图形化MySQL数据库管理工具。使用SQLyog可以快速直观地让您从世界的任何角落通过网络来维护远端的MySQL数据库

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-iCiyI9dx-1571680089146)(image\SQLYog介绍.png)]

  1. 双击[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8bAZN5MS-1571680089148)(image\SQLYog程序.png)]
  2. 一直下一步,直到出现下面对话框
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xjSWle1w-1571680089156)(image\SQLYog注册.png)]
  3. 双击[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GJ07hJzv-1571680089158)(image\SQLYog破解.png)]进行注册
  4. 重启SQLyog即可
  5. 使用SQLyog登录数据库
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4KlnokkO-1571680089163)(image\SQLyog使用01.png)]

2.7 MySQL目录结构(了解)

│-- bin:mysql相关的可执行文件*.exe
   │-- MySQLInstanceConfig.exe mysql的配置程序
│-- data: mysql自带的数据库文件
│-- include: c语言的头文件(不用关注)
│-- lib: 存放mysql使用到的dll动态库(相当于jar包,不用关注)
│-- my.ini mysql的配置文件,配置了mysql的相关信息

2.8 数据库管理系统(了解)

​ 数据库管理系统(DataBase Management System,DBMS):指一种操作和管理数据库的大型软件,用于建立、使用和维护数据库,对数据库进行统一管理和控制,以保证数据库的安全性和完整性。用户通过数据库管理系统访问数据库中表内的数据

2.9 数据库管理系统、数据库和表的关系

​ 数据库管理程序(DBMS)可以管理多个数据库,一般开发人员会针对每一个应用创建一个数据库。为保存应用中实体的数据,一般会在数据库创建多个表,以保存程序中实体的数据。数据库管理系统、数据库和表的关系如图所示:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-zewAGg9N-1571680089167)(image\DBMS.png)]

先有数据库 → 再有表 → 再有数据
一个库包含多个表

2.10 实体类与表的对应关系

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9zAwg328-1571680089171)(image\实体类与表的对应关系.png)]

第3章 SQL语句

3.1 SQL的概念

3.1.1 什么是SQL

​ 结构化查询语言(Structured Query Language)简称SQL,SQL语句就是对数据库进行操作的一种语言。

3.1.2 SQL作用

​ 通过SQL语句我们可以方便的操作数据库中的数据、表、数据库。
SQL是数据库管理系统都需要遵循的规范。不同的数据库生产厂商都支持SQL语句,但都有特有内容。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Y1VXWgTK-1571680089174)(image\SQL规范.png)]

3.1.2 SQL语句分类

  1. DDL(Data Definition Language)数据定义语言(用于创建、修改、删除数据库以及表)(了解)
    用来定义数据库对象:数据库,表,列等。关键字:create, drop,alter等

  2. DML(Data Manipulation Language)数据操作语言(掌握)
    用来对数据库中表的数据进行增删改。关键字:insert(添加), delete(删除), update(修改)等

  3. DCL(Data Control Language)数据控制语言(了解)

    用来定义数据库的访问权限和安全级别,及创建用户。关键字:GRANT, REVOKE等

  4. TCL(Transaction Control Language) 事务控制语言

​ 用于控制数据库的事务操作,关键字; COMMIT,SAVEPOINT,ROLLBACK等

  1. DQL(Data Query Language) 数据查询语言(最重要)

    DQL语言并不是属于MYSQL官方的分类,但是对数据库的操作最多就是查询,所以

    我们的程序员把查询语句的语句称作为DQL语言

3.2 SQL通用语法

  1. SQL语句可以单行或多行书写。只有当SQL语句是写在DOS窗口的时候,才需要使用";",因为分号是DOS命令行中一句命令结束的标记。
  2. 可使用空格和缩进来增强语句的可读性。
  3. MySQL数据库的SQL语句不区分大小写,关键字建议使用大写。
    SELECT * FROM student
    
  4. 3种注释(在SQLYog中写SQL语句的时候可以添加注释)
    单行注释: – 注释内容 或 # 注释内容(mysql特有)
    多行注释: /* 注释 */

3.3 DDL语句(了解)

3.3.1 DDL操作数据库

3.3.1.1 创建数据库

  1. 直接创建数据库
    CREATE DATABASE 数据库名;

  2. 判断是否存在并创建数据库
    CREATE DATABASE IF NOT EXISTS 数据库名;

  3. 创建数据库并指定字符集(编码表)
    CREATE DATABASE 数据库名 CHARACTER SET 字符集;

  4. 具体操作:

  • 直接创建数据库db1

    CREATE DATABASE db1;
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-U4ZbAZhb-1571680089177)(image\直接创建数据库.png)]

  • 判断是否存在并创建数据库db2

    CREATE DATABASE IF NOT EXISTS db2;
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-e30irAfj-1571680089178)(image\判断是否存在并创建数据库.png)]

  • 创建数据库并指定字符集为gbk

    CREATE DATABASE db2 CHARACTER SET gbk;
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0IwNOAxJ-1571680089179)(image\创建数据库并指定字符集.png)]

3.3.1.2 查看数据库

  1. 查看所有的数据库
    SHOW databases;
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VVzD3wUP-1571680089181)(image\查看所有数据库.png)]

  2. 查看某个数据库的定义信息
    SHOW CREATE DATABASE 数据库名;
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qxM20AWJ-1571680089184)(image\查看某个数据库的定义信息.png)]

3.3.1.3 修改数据库

修改数据库字符集格式

ALTER DATABASE 数据库名 CHARACTER SET 字符集;

具体操作:

  • 将db3数据库的字符集改成utf8
    ALTER DATABASE db3 CHARACTER SET utf8;
    
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vBURtqJH-1571680089185)(image\修改数据库字符集.png)]

3.3.1.4 删除数据库

DROP DATABASE 数据库名;

具体操作:

  • 删除db2数据库
    DROP DATABASE db2;
    
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-CTRZuwL1-1571680089186)(image\删除数据库.png)]

3.3.1.5 使用数据库

  1. 查看正在使用的数据库
    SELECT DATABASE();
  2. 使用/切换数据库
    USE 数据库名;

具体操作:

  • 查看正在使用的数据库
    SELECT DATABASE();
    
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dsIVo1jS-1571680089187)(image\查看正在使用的数据库.png)]
  • 使用db1数据库
    USE db1;
    
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-U8uV6ewm-1571680089188)(image\使用db1数据库.png)]

3.3.2 DDL操作表

前提先使用某个数据库

3.3.2.1 创建表

CREATE TABLE 表名 (字段名1 字段类型1, 字段名2 字段类型2…);

建议写成如下格式:

CREATE TABLE 表名 (
字段名1 字段类型1, 
字段名2 字段类型2
);

关键字说明:

CREATE -- 表示创建
TABLE -- 表示创建一张表

MySQL数据类型
MySQL中的我们常使用的数据类型如下:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-3XYmDB7L-1571680089189)(image\MYSQL常用数据类型.png)]

详细的数据类型如下(不建议详细阅读!)

分类 类型名称 说明
整数类型 tinyInt 很小的整数(-128,127)(0-255)
smallint 小的整数
mediumint 中等大小的整数
int(integer) 普通大小的整数
小数类型 float 单精度浮点数
double 双精度浮点数
日期类型 year YYYY 1901~2155
time HH:MM:SS -838:59:59~838:59:59
date YYYY-MM-DD 1000-01-01~9999-12-3
datetime YYYY-MM-DD HH:MM:SS 1000-01-01 00:00:00~ 9999-12-31 23:59:59
timestamp YYYY-MM-DD HH:MM:SS 19700101 00:00:01 UTC~2038-01-19 03:14:07UTC
文本、二进制类型 CHAR(M) M为0~255之间的整数
VARCHAR(M) M为0~65535之间的整数
TINYBLOB 允许长度0~255字节
BLOB 允许长度0~65535字节
MEDIUMBLOB 允许长度0~167772150字节
LONGBLOB 允许长度0~4294967295字节
TINYTEXT 允许长度0~255字节
TEXT 允许长度0~65535字节
MEDIUMTEXT 允许长度0~167772150字节
LONGTEXT 允许长度0~4294967295字节
VARBINARY(M) 允许长度0~M个字节的变长字节字符串
BINARY(M) 允许长度0~M个字节的定长字节字符串

我们在使用char和varchar的时候,都要指定其最大长度:char(12),varchar(12)

char类型:固定长度,有一个能够存放的最大长度,当存放的字符串的长度小于最大长度(最大是12,传入了8个字符)

varchar类型:可变长度,有一个最大长度范围,当存放的字符串的长度小于最大长度的时候,会先判断字符串的长度,然后申请对应大小的空间。

什么时候使用char:当传入的字符串的长度肯定是固定的时候,比如说手机号码字段。

具体操作:

创建student表包含id,name,birthday字段

CREATE TABLE student (
      id INT,
      name VARCHAR(20),
      birthday DATE
);

3.3.2.2 查看表

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

  2. 查看表结构
    DESC 表名;

  3. 查看创建表的SQL语句
    SHOW CREATE TABLE 表名;

具体操作:

  • 查看mysql数据库中的所有表

    SHOW TABLES;
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LQz69Z6g-1571680089190)(image\查看某个数据库中的所有表.png)]

  • 查看student表的结构

    DESC student;
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-oCvL1UxS-1571680089192)(image\查看student表的结构.png)]

  • 查看student的创建表SQL语句

    SHOW CREATE TABLE student;
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-zYPVFJ4o-1571680089193)(image\查看student的创建表SQL语句.png)]

3.3.2.3 快速创建一个表结构相同的表

CREATE TABLE 新表名 LIKE 旧表名;

具体操作:

  • 创建s1表,s1表结构和student表结构相同
    CREATE TABLE s1 LIKE student;
    
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4fWY2NXr-1571680089195)(image\创建表结构相同的表.png)]

3.3.2.4 删除表

  1. 直接删除表
    DROP TABLE 表名;
  2. 判断表是否存在并删除表
    DROP TABLE IF EXISTS 表名;

具体操作:

  • 直接删除表s1表
    DROP TABLE s1;
    
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xjxc8joT-1571680089197)(image\直接删除表.png)]
  • 判断表是否存在并删除s1表
    DROP TABLE IF EXISTS s1;
    
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-EmE2Nw7p-1571680089198)(image\判断表存在并删除.png)]

3.3.2.5 修改表结构

修改表结构使用不是很频繁,只需要了解,等需要使用的时候再回来查即可

  1. 添加表列
    ALTER TABLE 表名 ADD 列名 类型;

    具体操作:

    • 为学生表添加一个新的字段remark,类型为varchar(20)
      ALTER TABLE student ADD remark VARCHAR(20);
      
      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uNPYTJVN-1571680089199)(image\添加字段.png)]
  2. 修改列类型
    ALTER TABLE 表名 MODIFY列名 新的类型;
    具体操作:

    • 将student表中的remark字段的改成varchar(100)
      ALTER TABLE student MODIFY remark VARCHAR(100);
      
      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-KNeN9QJB-1571680089200)(image\修改字段类型.png)]
  3. 修改列名
    ALTER TABLE 表名 CHANGE 旧列名 新列名 类型;
    具体操作:

    • 将student表中的remark字段名改成intro,类型varchar(30)
      ALTER TABLE student CHANGE remark intro varchar(30);
      
      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aiNxPiyb-1571680089202)(image\修改表字段名称.png)]
  4. 删除列
    ALTER TABLE 表名 DROP 列名;
    具体操作:

    • 删除student表中的字段intro
      ALTER TABLE student DROP intro;
      
      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-InfBCaaT-1571680089203)(image\删除字段.png)]
  5. 修改表名
    RENAME TABLE 表名 TO 新表名;
    具体操作:

    • 将学生表student改名成student2
       RENAME TABLE student TO student2;
      
      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Nnyq8muK-1571680089204)(image\修改表名.png)]
  6. 修改字符集
    ALTER TABLE 表名 character set 字符集;
    具体操作:

    • 将sutden2表的编码修改成gbk
      ALTER TABLE student2 character set gbk;
      
      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pbT3Im4Q-1571680089205)(image\修改字符集.png)]

3.4 DML语句(重点)

3.4.1 插入记录

3.4.1.1 插入全部字段

  • 所有的字段名都写出来
    INSERT INTO 表名 (字段名1, 字段名2, 字段名3…) VALUES (值1, 值2, 值3);
  • 不写字段名
    INSERT INTO 表名 VALUES (值1, 值2, 值3…);

3.4.1.2 插入部分数据

INSERT INTO 表名 (字段名1, 字段名2, ...) VALUES (值1, 值2, ...);
没有添加数据的字段会使用NULL

  1. 关键字说明

    INSERT INTO 表名 – 表示往哪张表中添加数据
    (字段名1, 字段名2,)  --  要给哪些字段设置值
    VALUES (1,2,); -- 设置具体的值
    
  2. 注意

    • 值与字段必须对应,个数相同,类型相同
    • 值的数据大小必须在字段的长度范围内
    • 除了数值类型外,其它的字段类型的值必须使用引号引起。(建议单引号)
    • 如果要插入空值,可以不写字段,或者插入null
  3. 具体操作:

    • 插入部分数据,往学生表中添加 id, name, age, sex数据
    INSERT INTO student (id, NAME, age, sex) VALUES (1, '张三', 20, '男');
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7uwXxMO6-1571680089210)(image\添加部分数据.png)]

    • 向表中插入所有字段

      • 所有的字段名都写出来
       INSERT INTO student (NAME, id, age, sex, address) VALUES ('李四', 2, 23, '女', '广州');
      

      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-59UklX3J-1571680089211)(image\所有字段都添加数据.png)]

      • 不写字段名
      INSERT INTO student VALUES (3, '王五', 18, '男', '北京');
      

      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-zZaCIdxM-1571680089212)(image\添加所有字段数据.png)]

3.4.1.3 DOS命令窗口操作数据乱码问题的解决(不用管)

当我们使用DOS命令行进行SQL语句操作如有有中文会出现乱码,导致SQL执行失败
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tW1qbfM3-1571680089220)(image\DOS中文乱码01.png)]
错误原因:因为MySQL的客户端设置编码是utf8,而系统的DOS命令行编码是gbk,编码不一致导致的乱码
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QDCSMizY-1571680089221)(image\DOS中文乱码02.png)]

查看 MySQL 内部设置的编码
show variables like 'character%';
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vOOPIFrC-1571680089222)(image\DOS中文乱码03.png)]

解决方案:修改client、connection、results的编码为GBK,保证和DOS命令行编码保持一致

  1. 单独设置

    set character_set_client=gbk; 
    set character_set_connection=gbk;
    set character_set_results=gbk;
    
  2. 快捷设置

    set names gbk;
    

    注意:以上2种方式为临时方案,退出DOS命令行就失效了,需要每次都配置

  3. 修改MySQL安装目录下的my.ini文件,重启服务所有地方生效。此方案将所有编码都修改了[不建议]
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hFoBYw41-1571680089222)(image\DOS中文乱码04.png)]

3.4.1.4 蠕虫复制(了解)

什么是蠕虫复制:在已有的数据基础之上,将原来的数据进行复制,插入到对应的表中
语法格式:INSERT INTO 表名1 SELECT * FROM 表名2;
作用:将表名2中的数据复制到表名1

具体操作:

  • 创建student2表,student2结构和student表结构一样
CREATE TABLE student2 LIKE student;
  • 将student表中的数据添加到student2表中
INSERT INTO student2 SELECT * FROM student;

注意:如果只想复制student表中name,age字段数据到student2表中使用如下格式
INSERT INTO student2(NAME, age) SELECT NAME, age FROM student;
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-w3Ehn3Om-1571680089223)(image\蠕虫复制.png)]

3.4.2 更新表记录

  1. 不带条件修改数据
    UPDATE 表名 SET 字段名=值;

  2. 带条件修改数据
    UPDATE 表名 SET 字段名=值 WHERE 字段名=值;

  3. 关键字说明

    UPDATE: 修改表名
    SET: 修改哪些字段
    WHERE: 指定条件
    
  4. 具体操作:

    • 不带条件修改数据,将所有的性别改成女

      UPDATE student SET sex='女';
      

      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YadhprxQ-1571680089224)(image\修改所有数据.png)]

    • 带条件修改数据,将id号为2的学生性别改成男

      UPDATE student SET sex='男' WHERE id=2;
      

      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vxQ58tXY-1571680089224)(image\带条件修改.png)]

    • 一次修改多个列,把id为3的学生,年龄改成26岁,address改成北京

      UPDATE student SET age=26, address='北京' WHERE id=3;
      

      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MVjbBh0G-1571680089227)(image\一次性修改2个字段.png)]

3.4.3 删除表记录

  1. 不带条件删除数据
    DELETE FROM 表名;

  2. 带条件删除数据
    DELETE FROM 表名 WHERE 字段名=值;

  3. truncate删除表记录
    TRUNCATE TABLE 表名;

    truncate和delete的区别:

    • delete是将表中的数据一条一条删除
    • truncate是将整个表摧毁,重新创建一个新的表,新的表结构和原来表结构一模一样
      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dwzJW2pj-1571680089228)(image\truncate.png)]
  4. 具体操作:

    • 带条件删除数据,删除id为3的记录

      DELETE FROM student WHERE id=3;
      

      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vsb9rgmc-1571680089228)(image\删除满足条件的记录.png)]

    • 不带条件删除数据,删除表中的所有数据

      DELETE FROM student;
      

      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-c6NKc6gv-1571680089229)(image\删除所有记录.png)]

3.5 DQL(重中之重)

查询不会对数据库中的数据进行修改.只是一种显示数据的方式

3.5.1 简单查询

3.5.1.1 查询表所有数据

  1. 使用*表示所有列
    SELECT * FROM 表名;
    具体操作:

    SELECT * FROM student;
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-o1eY7Y2h-1571680089230)(image\查询所有列.png)]

  2. 写出查询每列的名称
    SELECT 字段名1, 字段名2, 字段名3, ... FROM 表名;
    具体操作:

    SELECT id, NAME ,age, sex, address FROM student;
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6IGqMwRG-1571680089231)(image\查询所有列.png)]

3.5.1.2 查询指定列

查询指定列的数据,多个列之间以逗号分隔
SELECT 字段名1, 字段名2... FROM 表名;

具体操作:
查询student表中的name 和 age 列

SELECT NAME, age FROM student;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YGVxMJ5T-1571680089236)(image\查询指定字段.png)]

3.5.1.3 别名查询(了解)

  1. 查询时给列、表指定别名需要使用AS关键字

  2. 使用别名的好处是方便观看和处理查询到的数据
    SELECT 字段名1 AS 别名, 字段名2 AS 别名... FROM 表名;
    SELECT 字段名1 AS 别名, 字段名2 AS 别名... FROM 表名 AS 表别名;
    注意:

    查询给表取别名目前还看不到效果,需要到多表查询的时候才能体现出好处
    AS关键字可以省略

  3. 具体操作:

    • 查询sudent表中name 和 age 列,name列的别名为”姓名”,age列的别名为”年龄”
    SELECT NAME AS 姓名, age AS 年龄 FROM student;
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1jNTLvlg-1571680089240)(image\查询字段别名.png)]

    • 查询sudent表中name和age列,student表别名为s
    SELECT NAME, age FROM student AS s;
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4DffQRLu-1571680089241)(image\查询表别名.png)]

    查询给表取别名目前还看不到效果,需要到多表查询的时候才能体现出好处

3.5.1.4 清除重复值(去重查询)

  1. 查询指定列并且结果不出现重复数据
    SELECT DISTINCT 字段名 FROM 表名;
  2. 具体操作:
    • 查询name,age列并且结果不出现重复name和age
    SELECT DISTINCT NAME, age FROM student;
    
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VrNXQ5X0-1571680089256)(image\取出重复数据.png)]

3.5.1.5 查询结果参与运算(运算查询)

  1. 某列数据和固定值运算
    SELECT 列名1 + 固定值 FROM 表名;

  2. 某列数据和其他列数据参与运算
    SELECT 列名1 + 列名2 FROM 表名;

    注意: 参与运算的必须是数值类型

  3. 需求:

    • 添加数学,英语成绩列,给每条记录添加对应的数学和英语成绩
    • 查询的时候将数学和英语的成绩相加
  4. 实现:

  • 修改student表结构,添加数学和英语成绩列

    ALTER TABLE student ADD math INT;
    ALTER TABLE student ADD english INT;
    
  • 给每条记录添加对应的数学和英语成绩
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Eilyo80y-1571680089261)(image\添加数学和英语成绩.png)]

  • 查询math + english的和

    SELECT math + english FROM student;
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-a5iesRNV-1571680089262)(image\查询math和english的和.png)]

    结果确实将每条记录的math和english相加,但是效果不好看

  • 查询math + english的和使用别名”总成绩”

    SELECT math + english 总成绩 FROM student;
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Z7pweuSV-1571680089264)(image\组合查询结果取别名.png)]

  • 查询所有列与math + english的和并使用别名”总成绩”

    SELECT *, math + english 总成绩 FROM student;
    

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-C1TPeVnO-1571680089267)(image\查询所有列数据和参与运算.png)]

  • 查询姓名、年龄,将每个人的年龄增加10岁

    SELECT name, age + 10 FROM student;
    

    [外链图片转存中…(img-C3CNUpbO-1571680089268)]

3.6 条件查询(重要)

​ 前面我们的查询都是将所有数据都查询出来,但是有时候我们只想获取到满足条件的数据
语法格式:SELECT 字段名 FROM 表名 WHERE 条件;
流程:取出表中的每条数据,满足条件的记录就返回,不满足条件的记录不返回

3.6.1 准备数据

CREATE TABLE student3 (
  id int,
  name varchar(20),
  age int,
  sex varchar(5),
  address varchar(100),
  math int,
  english int
);

INSERT INTO student3(id,NAME,age,sex,address,math,english) VALUES (1,'马云',55,'男','杭州',66,78),(2,'马化腾',45,'女','深圳',98,87),(3,'马景涛',55,'男','香港',56,77),(4,'柳岩',20,'女','湖南',76,65),(5,'柳青',20,'男','湖南',86,NULL),(6,'刘德华',57,'男','香港',99,99),(7,'马德',22,'女','香港',99,99),(8,'德玛西亚',18,'男','南京',56,65);

3.6.2 比较运算符

>大于
<小于
<=小于等于
>=大于等于
=等于
<>!=不等于

具体操作:

  • 查询math分数大于80分的学生
SELECT * FROM student3 WHERE math>80;

[外链图片转存中…(img-oTnUHtAQ-1571680089269)]

  • 查询english分数小于或等于80分的学生
SELECT * FROM student3 WHERE english<=80;

[外链图片转存中…(img-Z0lpePYE-1571680089271)]

  • 查询age等于20岁的学生
SELECT * FROM student3 WHERE age=20;

[外链图片转存中…(img-L8gB1P3c-1571680089292)]

  • 查询age不等于20岁的学生
SELECT * FROM student3 WHERE age!=20;
SELECT * FROM student3 WHERE age<>20;

[外链图片转存中…(img-BRwZnkFL-1571680089293)]

3.6.3 逻辑运算符

and(&&) 多个条件同时满足
or(||) 多个条件其中一个满足
not(!) 不满足

具体操作:

  • 查询age大于35且性别为男的学生(两个条件同时满足)
SELECT * FROM student3 WHERE  age>35 AND sex='男';

[外链图片转存中…(img-ViSHZNjb-1571680089295)]

  • 查询age大于35或性别为男的学生(两个条件其中一个满足)
SELECT * FROM student333 WHERE age>35 OR sex='男';

[外链图片转存中…(img-s4LreBfg-1571680089296)]

  • 查询id是1或3或5的学生
SELECT * FROM student3 WHERE id=1 OR id=3 OR id=5;

[外链图片转存中…(img-WtV6G5jc-1571680089297)]

in关键字
语法格式:SELECT 字段名 FROM 表名 WHERE 字段 in (数据1, 数据2...);
in里面的每个数据都会作为一次条件,只要满足条件的就会显示

具体操作:

  • 查询id是1或3或5的学生
SELECT * FROM student3 WHERE id IN (1,3,5);

[外链图片转存中…(img-s1OChkma-1571680089298)]

  • 查询id不是1或3或5的学生
SELECT * FROM student3 WHERE not(id in(1,3,5))

[外链图片转存中…(img-8TSBT38s-1571680089299)]

3.6.4 范围

BETWEEN 值1 AND 值2 表示从值1到值2范围,包头又包尾
比如:age BETWEEN 80 AND 100
相当于: age>=80 && age<=100

具体操作:

  • 查询学生的英语成绩小于等于90并且大于等于75 的学生信息
SELECT * FROM student3 WHERE english>=75 AND english<=90;
SELECT * FROM student3 WHERE english BETWEEN 75 AND 90;

[外链图片转存中…(img-sdj5q5on-1571680089300)]

3.6.5 like

LIKE表示模糊查询
SELECT * FROM 表名 WHERE 字段名 LIKE '通配符字符串';
满足通配符字符串规则的数据就会显示出来
所谓的通配符字符串就是含有通配符的字符串
MySQL通配符有两个:
%: 表示0个或多个字符(任意个字符)
_: 表示一个字符

具体操作:

  • 查询姓马的学生
SELECT * FROM student3 WHERE NAME LIKE '马%';

[外链图片转存中…(img-eHBHEHqs-1571680089301)]

  • 查询姓名中包含’德’字的学生
SELECT * FROM student3 WHERE NAME LIKE '%德%';

[外链图片转存中…(img-UODUlpGh-1571680089302)]

  • 查询姓马,且姓名有三个字的学生
SELECT * FROM student3 WHERE NAME LIKE '马__';

[外链图片转存中…(img-svOjwTxz-1571680089303)]

你可能感兴趣的:(MYSQL基础语法笔记)