MySQL5.7从入门到精通 (视频教学版) 刘增杰 编著
第1章 初识MySQL
MySQL是一个开放源代码的数据库管理系统(DBMS),它是由MySQL AB公司开发、发布和支持的。MySQL是一个跨平台(Windows、Linux、UNIX、MacOS)的开源“关系型”数据库管理系统,广泛地应用在Internet上的中小型网站开发中。
1.1 数据库基础
- 1.1.1 什么是数据库
1)保管数据的“仓库”;
2)数据管理的方法和技术;
- 1.1.2 表
类似于Excel表,行记录,列字段!
- 1.1.3 数据类型
常见的数据类型有:整数、浮点数、精确小数、二进制、日期/时间、字符串
- 1.1.4 主键
1)主键又称为主码,用于唯一标识表中的每一条记录。
2)可定义表中一列或者多列为主键(Primary Key)
3)主键列上不能有两行相同的值,也不能为空值null
1.2 数据库技术构成
- 1.2.1 数据库系统
数据库管理系统的3个主要组成部分
1)数据库:用于存储数据的地方
2)数据库管理系统:用于管理数据库的软件software
3)数据库应用:为了提高数据库系统的处理能力所使用的管理数据库软件的补充
数据库管理系统(DataBase Management System,DBMS)是用户创建、管理和维护数据库时使用的软件,位于操作系统和用户之间,对数据库进行统一管理。DBMS能定义数据存储结构,提供数据的从操作机制,维护数据库的安全性、完整性和可靠性。
- 用户 用户 用户———— Layer5
- 应用程序 ————Layer4
- 数据库管理系统 ————Layer3
- 操作系统 ————Layer2
- 硬件————Layer1
- 1.2.2 SQL语言
对数据库进行查询和修改操作的语言叫做SQL。(Structured Query Language)工业标准SQL-92
SQL包含如下
1)数据定义语言(DDL):DROP、CREATE、ALTER等语句
2)数据操作语言(DML):INSERT、UPDATE、DELETE语句
3)数据查询语言(DQL):SELECT语句
4)数据控制语言(DCL):GRANT、REVOKE、COMMIT、ROLLBACK语句
- 1.2.3 数据库访问接口
1)ODBC(Open Database Connectivity开放数据库互连),最大优点是可以以统一的方式处理所有数据库。
2)JDBC(Java Data Base ConnectivityJava数据库连接),用于Java应用程序连接数据库的标准和方法。
3)ADO.NET,是在微软.NET框架下开发设计的一组用于和数据源进行交互的面向对象的类库。
4)PDO(PHP Data Object),为PHP访问数据库定义了一个轻量级的、一致性的接口。
针对不同的语言,MySQL提供了不同数据库的“访问连接驱动”,可登录官网下载。
1.3 什么是MySQL
MySQL是一个小型关系型数据库管理系统,与其他大象数据库管理系统(Oracle、DB2、SQL Server)相比,MySQL规模小、功能有限,但是它体积小、速度快、成本低且它提供的功能对稍微复杂的应用已经够用,这些特性使得MySQL成为世界上最受欢迎的开放源码数据库。
- 1.3.1 客户机-服务器软件
主从式架构(Client-server-model)或客户端——服务器(Client/Server)结构简称C/S结构,是一种网络架构,通常在该网络架构下软件分为客户端(Client)和服务器(Server)
这种系统的特点是,客户端和服务器程序不在同一台计算机运行,这些客户端和服务器程序通常归属不同的计算机。
主从式架构通过不同的途径应用于很多不同类型的应用程序,比如在因特网上使用的网页。
举例:当顾客从京东上买东西的时候,电脑和网页浏览器就被当做一个客户端,同时组成当当网的电脑、数据库和应用程序就被当做服务器。
服务器端一般使用高性能的计算机,并配合使用不同类型的数据,如oracle、Sybase或者MySQL。
- 1.3.2 MySQL版本
1)MySQL Community Server(社区版):完全免费,但官方不提供技术支持
2)MySQL Enterprise Server(企业版服务器):它能够以很高性价比为企业提供数据库仓库应用,支持ACID事物处理,提供完整的提交、回滚、崩溃恢复和行级锁定功能。需付费,官方提供电话技术支持。
3)MySQL Cluster主要用于架设集群服务器,需要在社区版或者企业版的基础上使用。
Server version: 5.7.13-log MySQL Community Server (GPL)
1)第1个数字,主版本号
2)第2个数字,发行级别
3)第3个数字,是再次发行系列的版本号,随每次新分发版本递增,通常是已发行的最新版本。
4)MySQL(Current Generally Available Release)版本已经过严格标准的测试,可以保证其安全可靠的使用。
- 1.3.3 MySQL优势
1)速度:运行速度快;
2)价格:MySQL对多数人来说是免费的;
3)容易使用:与其他大型数据库的设置和管理相比,其复杂程度较低,易于学习掌握;
4)可移植性(跨平台):Windows、Linux、UNIX、Mac OS等众多不同的系统平台上使用;
5)丰富的接口:提供了用于C、C++、Java、Perl、PHP、Python、Ruby等语言的API;
6)支持查询语言:MySQL可以利用标准的SQL语法和支持ODBC(开放式数据库连接)的应用程序;
7)安全性和连接性:十分灵活和安全的权限和密码系统,允许基于主机的验证。连接到服务器时,所有的密码传输均采用加密形式,从而保证了密码安全;
8)MySQL是网络化的,可以在因特网上的任何地方访问,提高数据共享的效率;
- 1.3.4 MySQL5.7的新功能
1)支持JSON
JSON(JavaScript Object Notation的缩写)是一种存储信息的格式,可以很好地替代XML。从MySQL5.7.8版本开始,MySQL将支持JSON。
2)性能和可拓展性
改进InnoDB的可拓展性和临时表的性能,从而实现更快的网络和大数据家在等操作
3)改进复制以提高可用性的性能
改进复制包括多源复制、多从线程增强、在线GTIDs和增强的半同步复制
4)性能模式提供更好的视角
5)安全
6)优化
7)GIS
1.4 MySQL工具
- 1.4.1 MySQL命令行实用程序
1)mysqld:SQL后台程序(即MySQL服务器进程)。该程序必须运行之后,客户端才能通过连接服务器来访问数据库。
2)mysqld_safe:服务器启动脚本。
3)mysql.server:服务器启动脚本。
4)mysql_multi:服务器启动脚本,可以启动或停止系统上安装的多个服务器
- 1.4.2 MySQL Workbench
MySQL Workbench是下一代可视化数据库设计软件,功能如下:
1)数据库设计和模型建立
2)SQL开发(取代MySQL Query Browser)
3)数据库管理(取代MySQL Administrator)
MySQL Workbench Community Edition(也叫MySQL Workbench OSS,社区版)
MySQL Workbench Standard Edition(也叫 MySQL Workbench SE,商业版)
1.5 如何学习MySQL
1)培养兴趣(兴趣是最好的老师,不论学习什么知识,兴趣都可以极大的提高学习效率)
2)夯实基础
计算机领域的技术非常强调基础,刚开始学习可能还认识不到这一点,随着技术应用的深入,只有有着扎实的基础功底,才能在技术的道路上走的更快、更远。对于MySQL的学习,SQL语句就是其中最为基础的部分。
3)及时学习新知识
搜索引擎、参考他人的解决问题的思路,吸取别人的经验以及获取最新的技术资料
4)多实践操作
数据库系统具有极强的操作性,需要多动手上机操作。
第2章 MySQL的安装与配置
Windows平台下安装MySQL,可以使用图形化的安装包,它提供了详细的安装向导,读者可一步一步地按照提示完成的MySQL的安装。
2.1 Windows平台下安装与配置MySQL5.7
- 2.1.1 安装MySQL5.7
Windows平台下提供两种安装方式:
1)MySQL二进制分发版(.msi安装文件)
2)免安装版.zip压缩文件
一般来讲,应当使用二进制分发版,因为该版本比其他的分发版本使用起来要简单,不需要借助其他工具来启动就可以运行MySQL。
- 2.1.2 配置MySQL5.7
1)Development Machine(开发机器):该选项代表典型的个人用桌面工作站。假定机器上运行着多个桌面应用程序,将MySQL服务器配置成使用最少的系统资源。
2)Server Machine(服务器):该选项该表服务器,MySQL服务器可以同其他应用程序一起运行,如FTP、Email和Web服务器,MySQL服务器配置成使用适当比例的系统资源
3)Dedicated Machine(专用服务器):该选项代表只运行MySQL服务的服务器。假定没有运行其他服务程序,MySQL服务器配置成使用所有可用的系统资源。
2.2 启动服务并登录MySQL数据库
MySQL安装完毕之后,需要启动服务器的进程,不然客户端无法连接数据库。客户端通过命令行工具登录数据库。
1)cmd-》net start mysql
2)cmd-》net stop mysql
- 2.2.1 启动MySQL服务
- 2.2.2 登录MySQL数据库
1)DOS窗口登录MySQL数据库
2)使用MySQL Commond Line Client登录MySQL
- 2.2.3 配置Path环境变量
1)解决窗口闪一下消失的问题,复制mysql-default.ini,然后将副本命名为mysql.ini即可。
2.3 MySQL常用图形化管理工具
MySQL图形化管理工具极大地方便了数据库的操作与管理,常用图形化工具介绍如下:
1)MySQL Workbench
2)phpMyAdmin
3)Navicat for MySQL
4)MySQL Dumper
5)SQLyog
2.4 Linux平台下安装与配置MySQL5.7
Linux操作系统有众多的发行版,不同平台下需要安装不同的MySQL版本,MySQL主要支持的Linux版本有SUSE Linux enterprise Server和Red Hat&Oracle Enterprise Linux
- 2.4.1 Linux操作系统下的MySQL版本介绍
Linux操作系统是自由软件和开放源代码发展中最著名的例子。其诞生以后,经过全世界各地计算机爱好者的共同努力,现已成为今天世界上使用最多的一种“类UNIX”操作系统,目前已经开发超过300个发行版本,比较流行的版本有:Ubuntu、Debian、GNU/Linux、Fedora、openSUSE、和RedHat系列。
目前MySQL主要支持的Linux版本为SUSE和Red Hat,Linux操作系统下MySQL安装包分为3类
1)RPM:RPM软件包是一种在Linux平台下的安装文件,通过安装命令可很方便地安装与卸载。(RedHat系列),MySQL的RPM安装文件分为两个:服务端和客户端,需分别下载和安装。
2)Generic Binaries:二进制软件包,经过编译生成的二进制文件软件包。
3)源码包:源码包是MySQL数据库的源代码,用户需要自己编译成二进制文件后方可安装。
- 2.4.2 安装和配置MySQL的RPM包
MySQL推荐使用RPM包进行Linux平台下的安装,从官方下载的RPM包能够在所有支持RPM packages,glibc2.3的Linux系统下安装和使用
Linux平台下的MySQL安装目录
/usr/bin 客户端和脚本
/usr/sbin MySQLD服务器
/var/lib/mysql 日志文件和数据库
/usr/share/info 信息格式的手册
/usr/share/man UNIX帮助页
/usr/include/mysql 头文件
/usr/lib/mysql 库
/usr/share/mysql 错误消息、字符集、示例配置文件等
mysql-5.7.13-1.el7.x86_64.rpm-bundle.tar解压缩之后如下:
- mysql-community-client-5.7.13-1.el7.x86_64.rpm#是客户端安装包;
- mysql-community-common-5.7.13-1.el7.x86_64.rpm#是服务端的安装包;
- mysql-community-devel-5.7.13-1.el7.x86_64.rpm#是包含开发用的库文件安装的包;
- mysql-community-embedded-5.7.13-1.el7.x86_64.rpm#是嵌入式MySQL的安装包;
- mysql-community-embedded-compat-5.7.13-1.el7.x86_64.rpm;
- mysql-community-embedded-devel-5.7.13-1.el7.x86_64.rpm;
- mysql-community-libs-5.7.13-1.el7.x86_64.rpm;
- mysql-community-libs-compat-5.7.13-1.el7.x86_64.rpm;
- mysql-community-minimal-debuginfo-5.7.13-1.el7.x86_64.rpm;
- mysql-community-server-5.7.13-1.el7.x86_64.rpm;
- mysql-community-server-minimal-5.7.13-1.el7.x86_64.rpm;
- mysql-community-test-5.7.13-1.el7.x86_64.rpm#是一些测试的安装包;
一般情况下,只需要安装client和server两个包,如需进行C、C++MySQL相关开发,请安装mysql-community-devel-5.7.13-1.el7.x86_64.rpm
安装之前,要查看机器上是否已经装有就办的MySQL,如果有,最好先把旧版MySQL卸载,否则可能产生冲突。
rpm -qa|grep -i mysql
从MySQL5.0开始,MySQL的服务名改为mysql,而不是4.*版本的mysqld
MySQL服务的操作命令是
1)service mysql start|stop|restart|status#CentOS6.X下
2)systemctl start|stop|restart|status mysqld#CentOS7.X下,因为CentOS7系列使用了systemd管理工具
- 2.4.3 安装和配置MySQL的源码包
进入下载页面:https://downloads.mysql.com/archives/community/
源码安装需要一些开发工具
1)CMaked(cross platform make),构建程序必需的一个跨平台的构建工具。官方地址:http://www.cmake.org/
2)一个好的make工具,MySQL官方推荐使用GNU make3.75,GNUmake下载地址:http://www.gun.org/software/make/
3)ANSI C++编译器,GCC 4.2.1及以上版本
4)Perl,运行test版本所必需的。
5)rpm包管理器,rpmbuild工具
输入如下命令:
rpmbuild --rebuild --clean MySQL-5.7.20-1.linux2.6.src.rpm,编译完成后会形成一个rpm包,然后按照rpm包的安装方法就可以了。
初级用户,不建议使用源码包进行安装。
2.5 专家解惑
计算机技术具有很强的操作性,MySQL的安装和配置是一件非常简单的事,但是在操作过程中也可能出现问题,多实践,多总结。
在安装MySQL5.7软件安装包之前,用户需要确保系统中已经安装了.Net Framework3.5和.Net Framework4.0,如何缺少,将不能正常安装。
2.6 经典习题
1)下载并安装MySQL
2)使用配置向导配置MySQL为系统服务,在系统服务对话框中,手动启动或关闭MySQL服务
3)使用net命令启动或者关闭MySQL服务
4)使用免安装的软件包安装MySQL
第3章 数据库的基本操作
MySQL安装好之后,首先要“创建数据库实例”,这是使用MySQL各种功能的前提。
3.1 创建数据库
MySQL安装好之后,将会在data目录之下自动创建几个必须的数据库,可使用SHOW DATABASES;语句来查看。
1)mysql是必须的,它描述用户访问权限;
2)用户经常用test数据库实例做测试工作;
3)创建数据库是在系统磁盘上划分一块区域,用于数据的存储和管理;
MySQL中创建数据库的基本SQL语法格式为:
CREATE DATABASE database_name;
【例3.1】创建测试数据库 test_db;
CREATE DATABASE test_db;
【例3.2】查看创建好的数据库test_db的定义,如下:
SHOW CREATE DATABASE test_db\G;
[root@iZ2ze3eaa380cnnuepvyrwZ ~]# mysql -uroot -p
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 45
Server version: 5.7.13 MySQL Community Server (GPL) Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sys |
+--------------------+
4 rows in set (0.00 sec) mysql> create database test_db;
Query OK, 1 row affected (0.15 sec) mysql> show create database test_db;
+----------+--------------------------------------------------------------------+
| Database | Create Database |
+----------+--------------------------------------------------------------------+
| test_db | CREATE DATABASE `test_db` /*!40100 DEFAULT CHARACTER SET latin1 */ |
+----------+--------------------------------------------------------------------+
1 row in set (0.03 sec) mysql> show create database test_db\G;
*************************** 1. row ***************************
Database: test_db
Create Database: CREATE DATABASE `test_db` /*!40100 DEFAULT CHARACTER SET latin1 */
1 row in set (0.00 sec) ERROR:
No query specified mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sys |
| test_db |
+--------------------+
5 rows in set (0.00 sec) mysql>
3.2 删除数据库
删除数据库是将已存在的数据库从磁盘空间上清除,清除之后,数据库实例中的所有数据也将一同被删除。
1、MySQL中删除数据的基本语法格式为:
DROP DATABASE database_name(数据库实例名);如果不存在,则报错!
【例3.3】删除测试数据库test_db,输入语句如下:
DORP DATABASE test_db;
mysql> drop database test_db;
Query OK, 0 rows affected (0.01 sec) mysql> show create database test_db\G;
ERROR 1049 (42000): Unknown database 'test_db'
ERROR:
No query specified mysql> show create database test_db;
ERROR 1049 (42000): Unknown database 'test_db'
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sys |
+--------------------+
4 rows in set (0.00 sec) mysql>
小结:
1、使用DROP DATABASE命令时要非常谨慎,在执行该命令时,MySQL不会给出任何提示确认信息,DROP DATABASE 声明删除数据库实例后,数据库中存储的所有数据表和数据也将一同被删除,而且不能恢复。
3.3 数据库存储引擎
数据库存储引擎是数据库底层软件的组件,数据库管理系统(DBMS)使用数据引擎进行创建、查询、更新和删除数据操作。
不同的存储引擎提供不同的存储机制、索引技巧、锁定水平等功能,使用不同的存储引擎,可以获得特定的功能。MySQL数据库的核心就是存储引擎。
可以通过SHOW ENGINES语句查看系统所支持的引擎类型,结果如下:
mysql> SHOW ENGINES\G;
*************************** 1. row ***************************
Engine: InnoDB
Support: DEFAULT
Comment: Supports transactions, row-level locking, and foreign keys
Transactions: YES
XA: YES
Savepoints: YES
*************************** 2. row ***************************
Engine: MRG_MYISAM
Support: YES
Comment: Collection of identical MyISAM tables
Transactions: NO
XA: NO
Savepoints: NO
*************************** 3. row ***************************
Engine: MEMORY
Support: YES
Comment: Hash based, stored in memory, useful for temporary tables
Transactions: NO
XA: NO
Savepoints: NO
*************************** 4. row ***************************
Engine: BLACKHOLE
Support: YES
Comment: /dev/null storage engine (anything you write to it disappears)
Transactions: NO
XA: NO
Savepoints: NO
*************************** 5. row ***************************
Engine: MyISAM
Support: YES
Comment: MyISAM storage engine
Transactions: NO
XA: NO
Savepoints: NO
*************************** 6. row ***************************
Engine: CSV
Support: YES
Comment: CSV storage engine
Transactions: NO
XA: NO
Savepoints: NO
*************************** 7. row ***************************
Engine: ARCHIVE
Support: YES
Comment: Archive storage engine
Transactions: NO
XA: NO
Savepoints: NO
*************************** 8. row ***************************
Engine: PERFORMANCE_SCHEMA
Support: YES
Comment: Performance Schema
Transactions: NO
XA: NO
Savepoints: NO
*************************** 9. row ***************************
Engine: FEDERATED
Support: NO
Comment: Federated MySQL storage engine
Transactions: NULL
XA: NULL
Savepoints: NULL
9 rows in set (0.00 sec) ERROR:
No query specified mysql> SHOW ENGINES;
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| Engine | Support | Comment | Transactions | XA | Savepoints |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| InnoDB | DEFAULT | Supports transactions, row-level locking, and foreign keys | YES | YES | YES |
| MRG_MYISAM | YES | Collection of identical MyISAM tables | NO | NO | NO |
| MEMORY | YES | Hash based, stored in memory, useful for temporary tables | NO | NO | NO |
| BLACKHOLE | YES | /dev/null storage engine (anything you write to it disappears) | NO | NO | NO |
| MyISAM | YES | MyISAM storage engine | NO | NO | NO |
| CSV | YES | CSV storage engine | NO | NO | NO |
| ARCHIVE | YES | Archive storage engine | NO | NO | NO |
| PERFORMANCE_SCHEMA | YES | Performance Schema | NO | NO | NO |
| FEDERATED | NO | Federated MySQL storage engine | NULL | NULL | NULL |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
9 rows in set (0.00 sec) mysql>
其中,YES表示可以使用;NO表示不可以;DEFAULT表示引擎为当前默认;
3.3.1 MySQL存储引擎简介
3.3.2 InnoDB存储引擎
3.3.3 MyISAM存储引擎
3.3.4 MEMORY存储引擎
3.3.5 存储引擎的选择
3.4 综合案例——数据库的创建和删除
3.5 专家解惑
3.6 经典习题
第4章 数据表的基本操作
4.1 创建数据表
4.1.1 创建表的语法形式
4.1.2 使用主键约束
4.1.3 使用外键约束
4.1.4 使用非空约束
4.1.5 使用唯一性约束
4.1.6 使用默认约束
4.1.7 设置表的属性值自动增加
4.2 查看数据表结构
4.2.1 查看表基本结构语句DESCRIBE
4.2.2 查看表的详细结构语句SHOW CREATE TABLE
4.3 修改数据表
4.3.1 修改表名
4.3.2 修改字段的数据类型
4.3.3 修改字段名
4.3.4 添加字段
4.3.5 删除字段
4.3.6 修改字段的排列位置
4.3.7 更改表的存储引擎
4.3.8 删除表的外键约束
4.4 删除数据表
4.4.1 删除没有被关联的表
4.4.4 删除被其他表关联的主表
4.5 综合案例——数据表的基本操作
4.6 转接解惑
4.7 经典习题
第5章 数据类型和运算符
5.1 MySQL数据类型介绍
5.1.1 整数类型
5.1.2 浮点数类型和定点数类型
5.1.3 日期与时间类型
5.1.4 文本字符串类型
5.1.5 二进制字符串类型
5.2 如何选择数据类型
5.3 常见运算符介绍
5.3.1 运算符概述
5.3.2 算术运算符
5.3.3 比较运算符
5.3.4 逻辑运算符
5.3.5 位运算符
5.3.6 运算符的优先级
5.4 综合案例——运算符的使用
5.5 专家解惑
5.6 经典习题
第6章 MySQL函数
6.1 MySQL函数简介
6.2 数学函数
6.2.1 绝对值函数ABS(x)和返回圆周率的函数PI()
6.2.2 平方根函数SQRT(x)和求余函数MOD(x,y)
6.2.3 获取整数的函数CEIL(x)、CEILNG(x)和FLOOR(x)
6.2.4 获取随机数的函数RAND()和RAND(x)
6.2.5 函数ROUND(x)、ROUND(x,y)和TRUNCATE(x,y)
6.2.6 符号函数SIGN(x)
6.2.7 幂运算函数POW(x,y)、POWER(x,y)和EXP(x)
6.2.8 对数运算函数LOG(x)和LOG10(x)
6.2.9 角度与弧度相互转换的函数RADIANS(x)和DEGREES(x)
6.2.10 正弦函数SIN(x)和反正弦函数ASIN(x)
6.2.11 余弦函数COS(x)和反余弦函数ACOS(x)
6.2.12 正切函数、反正切函数和余切函数
6.3 字符串函数
6.3.1 计算字符串字符数的函数和字符串长度的函数
6.3.2 合并字符串函数CONCAT(s1,s2,...)、CONCAT_WS(x,s1,s2,...)
6.3.3 替换字符串的函数INSERT(s1,x,len,s2)
6.3.4 字母大小写转换函数
6.3.5 获取指定长度的字符串的函数LEFT(s,n)和RIGHT(s,n)
6.3.6 填充字符串的函数LPAD(s1,len,s2)和RPAD(s1,len,s2)
6.3.7删除空格的函数LTRIM(s)、RTRIM(s)和TRIM(s)
6.3.8 删除指定字符串的函数TRIM(s1 FROM s)
6.3.9 重复生成字符串的函数REPEAT(s,n)
6.3.10 空格函数SPACE(n)和替换函数REPLACE(s,s1,s2)
6.3.11 比较字符串大小的函数STRCMP(s1,s2)
6.3.12 获取子串的函数SUBSTRING(s,n,len)和MID(s,n,len)
6.3.13 匹配子串开始位置的函数
6.3.14 字符串逆序的函数REVERSE(s)
6.3.15 返回指定位置的字符串函数
6.3.16 返回指定字符串位置的函数FIELD(s,s1,s2,...)
6.3.17 返回子串位置的函数FIND_IN_SET(s1,s2)
6.3.18 选取字符串的函数MAKE_SET(x,s1,s2,...)
6.4 日期和时间函数
6.4.1 获取当前日期的函数和获取当前时间的函数
6.4.2 获取当前日期和时间的函数
6.4.3 UNIX时间戳函数
6.4.4 返回UTC日期的函数和返回UTC时间的函数
6.4.5 获取月份的函数MONTH(date)和MONTHNAME(date)
6.4.6 获取星期的函数DAYNAME(d)、DAYOFWEEK(d)和WEEKDAY(d)
6.4.7 获取星期数的函数WEEK(d)和WEEKOFYEAR(d)
6.4.8 获取天数的函数DAYOFYEAR(d)和DAYOFMONTH(d)
6.4.9 获取年份、季度、小时、分钟和秒钟的函数
6.4.10 获取日期的指定值的函数EXTRACT(type FROM date)
6.4.11 时间和秒钟转换的函数
6.4.12 计算日期和时间的函数
6.4.13 将日期和时间格式化的函数
6.5 条件判断函数
6.5.1 IF(expr,v1,v2)函数
6.5.2 IFNULL(v1,v2)
6.5.3 CASE函数
6.6 系统信息函数
6.6.1 获取MySQL版本号、连接数和数据库名的函数
6.6.2 获取用户数的函数
6.6.3 获取字符串的字符集和排序方式的函数
6.6.4 获取最后一个自动生成的ID值的函数
6.7 加/解密函数
6.7.1 加密函数PASSWORD(str)
6.7.2 加密函数MD5(str)
6.7.3 加密函数ENCODE(str,pswd_str)
6.7.4 解密函数DECODE(crypt_str,pswd_str)
6.8 其他函数
6.8.1 格式化函数FORMAT(x,n)
6.8.2 不同进制的数字进行转换的函数
6.8.3 IP地址与数字相互转换的函数
6.8.4 加锁函数和解锁函数
6.8.5 重复执行指定操作的函数
6.8.6 改变字符集的函数
6.8.7 改变数据类型的函数
6.9 综合案例——MySQL函数的使用
6.10 专家解惑
6.11 经典习题
第7章 查询数据
7.1 基本查询语句
7.2 单表查询
7.2.1 查询所有字段
7.2.2 查询指定字段
7.2.3 查询指定记录
7.2.4 带IN关键字的查询
7.2.5 带BETWEEN AND的范围查询
7.2.6 带LIKE的字符匹配查询
7.2.7 查询空值
7.2.8 带AND的多条件查询
7.2.9 带OR的多条件查询
7.2.10 查询结果不重复
7.2.11 对查询结果排序
7.2.12 分组查询
7.2.13 使用LIMIT限制查询结果的数量
7.3 使用聚合函数查询
7.3.1 COUNT()函数
7.3.2 SUM()函数
7.3.3 AVG()函数
7.3.4 MAX()函数
7.3.5 MIN()函数
7.4 连接查询
7.4.1 内连接查询
7.4.2 外连接查询
7.4.3 复合条件连接查询
7.5 子查询
7.5.1 带ANY、SOME关键字的查询
7.5.2 带ALL关键字的查询
7.5.3 带EXISTS关键字的查询
7.5.4 带IN关键字的查询
7.5.6 带比较运算符的子查询
7.6 合并查询结果
7.7 为表和字段取别名
7.7.1 为表取别名
7.7.2 为字段取别名
7.8 使用正则表达式查询
7.8.1 查询以特定字符或字符串开头的记录
7.8.2 查询以特定字符串或字符串结尾的记录
7.8.3 用符号“.”来替代字符串中的任意一个字符
7.8.4 使用“*”和“+”来匹配多个字符
7.8.5 匹配指定字符串
7.8.6 匹配指定字符串的任意一个
7.8.7 匹配指定字符串以外的字符
7.8.8 使用{n,}或者{n,m}来指定字符串连续出现的次数
7.9 综合案例——数据表查询操作
7.10 专家解惑
7.11 经典习题
第8章 插入、更新与删除数据
8.1 插入数据
8.1.1 为表的所有字段插入数据
8.1.2 为表的指定字段插入数据
8.1.3 同时插入多条记录
8.1.4 将查询结果插入到表中
8.2 更新数据
8.3 删除数据
8.4 综合案例——记录的插入、更新和删除
8.5 专家解惑
8.6 经典习题
第9章 索引
9.1 索引简介
9.1.1 索引的含义和特点
9.1.2 索引的分类
9.1.3 索引的设计原则
9.2 创建索引
9.2.1 创建表的时候创建索引
9.2.2 在已经存在的表上创建索引
9.3 删除索引
9.4 综合案例——创建索引
9.5 专家解惑
9.6 经典习题
第10章 存储过程和函数
10.1 创建存储过程和函数
10.1.1 创建存储过程
10.1.2 创建存储函数
10.1.3 变量的使用
10.1.4 定义条件和处理程序
10.1.5 光标的使用
10.1.6 流程控制的使用
10.2 调用存储过程和函数
10.2.1 调用存储过程
10.2.2 调用存储函数
10.3 查看存储过程和函数
10.3.1 使用SHOW STATUS语句查看存储过程和函数的状态
10.3.2 使用SHOW CREATE语句查看存储过程和函数的定义
10.3.3 从information_schema.Routines 表中查看存储过程和函数的信息
10.4 修改存储过程和函数
10.5 删除存储过程和函数
10.6 综合案例——创建存储过程和函数
10.7 专家解惑
10.8 经典习题
第11章 视图
11.1 视图概述
11.1.1 视图的含义
11.1.2 视图的作用
11.2 创建视图
11.2.1 创建视图的语法形式
11.2.2 在表单上创建视图
11.2.3 在多表上创建视图
11.3 查看视图
11.3.1 使用DESCRIBE语句查看视图基本信息
11.3.2 使用SHOW TABLE STATUS语句查看视图基本信息
11.3.3 使用SHOW CREATE VIEW语句查看视图详细信息
11.3.4 在views表中查看视图详细信息
11.4 修改视图
11.4.1 使用CREATE OR REPLACE VIEW语句修改视图
11.4.2 使用ALTER语句修改视图
11.5 更新视图
11.6 删除视图
11.7 综合案例——视图应用
11.8 专家解惑
11.9 经典习题
第12章 MySQL触发器
12.1 创建触发器
12.1.1 创建只有一个执行语句的触发器
12.1.2 创建有多个执行语句的触发器
12.2 查看触发器
12.2.1 SHOW TRIGGERS语句查看触发器信息
12.2.2 在triggers表中查看触发器信息
12.3 触发器的作用
12.4 删除触发器
12.5 综合案例——触发器的作用
12.6 专家解惑
12.7 经典习题
第13章 MySQL用户管理
13.1 权限表
13.1.1 user表
13.1.2 db表和host表
13.1.3 tables_priv表和columns_priv表
13.1.4 procs_priv表
13.2 账户管理
13.2.1 登录和退出MySQL服务器
13.2.2 新建普通用户
13.2.3 删除普通用户
13.2.4 root用户修改自己的密码
13.2.5 root用户修改普通用户的密码
13.2.6 普通用户修改密码
13.2.7 root用户密码丢失的解决办法
13.3 权限管理
13.3.1 MySQL的各种权限
13.3.2 授权
13.3.3 收回权限
13.3.4 查看权限
13.4 访问控制
13.4.1 连接核实阶段
13.4.2 请求核实阶段
13.5 综合案例——综合管理用户权限
13.6 专家解惑
13.7 经典习题
第14章 数据备份与恢复
14.1 数据备份
14.1.1 使用MySQLdump命令备份
14.1.2 直接复制整个数据库目录
14.1.3 使用MySQLhotcopy工具快速备份
14.2 数据恢复
14.2.1 使用MySQL命令恢复
14.2.2 直接复制到数据库目录
14.2.3 MySQLhotcopy快速恢复
14.3 数据库迁移
14.3.1 相同版本的MySQL数据库之间的迁移
14.3.2 不同版本的MySQL数据库之间的迁移
14.3.3 不同数据库之间的迁移
14.4 表的导出和导入
14.4.1 使用SELECT...INT OUTFILE导出文本文件
14.4.2 使用MySQLdump命令导出文本文件
14.4.3 使用MySQL命令导出文本文件
14.4.4 使用LOAD DATA INFILE方式导入文本文件
14.4.5 使用MySQLimport命令导入文本文件
14.5 综合案例——数据备份与恢复
14.6 专家解惑
14.7 经典习题
第15章 MySQL日志
15.1 日志简介
15.2 二进制日志
15.2.1 启动和设置二进制日志
15.2.2 查看二进制日志
15.2.3 删除二进制日志
15.2.4 使用二进制日志恢复数据库
15.2.5 暂时停止二进制日志功能
15.3 错误日志
15.3.1 启动和设置错误日志
15.3.2 查看错误日志
15.3.3 删除错误日志
15.4 通用查询日志
15.4.1 启动和设置通用查询日志
15.4.2 查看通用查询日志
15.4.3 删除通用查询日志
15.5 慢查询日志
15.5.1 启动和设置慢查询日志
15.5.2 查看慢查询日志
15.5.3 删除慢查询日志
15.6 综合案例——MySQL日志综合管理
15.7 专家解惑
15.8 经典习题
第16章 性能优化
16.1 优化简介
16.2 优化查询
16.2.1 分析查询语句
16.2.2 索引对查询速度的影响
16.2.3 使用索引查询
16.2.4 优化子查询
16.3 优化数据库结构
16.3.1 将字段很多的表分解成多个表
16.3.2 增加中间表
16.3.3 增加冗余字段
16.3.4 优化插入记录的速度
16.3.5 分析表、检查表和优化表
16.4 优化MySQL服务器
16.4.1 优化服务器硬件
16.4.2 优化MySQL的参数
16.5 综合案例——全面优化MySQL服务器
16.6 专家解惑
16.7 经典习题
第17章 MySQL Replication
17.1 MySQL Replication概述
17.2 Windows环境下的MySQL主从复制
17.2.1 复制前的准备工作
17.2.2 Windows环境下实现主从复制
17.2.3 Windows环境下主从复制测试
17.3 Linux环境下的MySQL复制
17.3.1 下载并安装MySQL5.7
17.3.2 单击主从复制前的准备工作
17.3.3 MySQLd_multi实现单机主从复制
17.3.4 不同服务器之间实现主从复制
17.3.5 MySQL主从复制启动选项
17.3.6 指定复制的数据库或者表
17.4 查看Slave的复制进度
17.5 日常管理维护
17.5.1 了解服务器的状态
17.5.2 服务器复制出错的原因
17.6 切换主从服务器
17.7 专家解惑
17.8 经典习题
第18章 MySQL Workbench的使用
18.1 MySQL Workbench的概述
18.1.1 MySQL Workbench的概述
18.1.2 MySQL Workbench的优势
18.1.3 MySQL Workbench的安装
18.2 SQL Development的基本操作
18.2.1 创建数据库连接
18.2.2 创建新的数据库
18.2.3 创建和删除新的数据表
18.2.4 添加、修改表记录
18.2.5 查询表记录
18.2.6 修改表结构
18.3 Data Modeling的基本操作
18.3.1 建立ER模型
18.3.2 导入ER模型
18.4 Server Administration的基本操作
18.4.1 管理MySQL用户
18.4.2 备份MySQL数据库
18.4.3 恢复MySQL数据库
18.5 专家解惑
18.6 经典习题
第19章 MySQL Cluster
19.1 MySQL Cluster概述
19.1.1 MySQL Cluster基本概念
19.1.2 理解MySQL Cluster节点
19.2 Linux环境下MySQL Cluster安装和配置
19.2.1 安装MySQL Cluster软件
19.2.2 管理节点配置步骤
19.2.3 配置SQL节点和数据节点
19.3 管理MySQL Cluster
19.3.1 Cluster的启动
19.3.2 Cluster的测试
19.3.3 Cluster的关闭
19.4 维护MySQL Cluster
19.4.1 Cluster的日志管理
19.4.2 Cluster的联机备份
19.4.3 Cluster的数据恢复
19.5 Windows操作系统中配置Cluster
19.6 专家解惑
19.7 经典习题
第20章 MySQL管理利器——MySQL Utilities
20.1 MySQL Utilities概述
20.2 安装与配置
20.2.1 下载与安装MySQL Utilities
20.2.2 MySQL Utilities连接数据库
20.3 管理与维护
20.3.1 使用mysqldbcompare比较数据
20.3.2 使用mysqldbcopy复制数据
20.3.3 使用mysqldbexport导出数据
20.3.4 使用mysqldbimport导入数据
20.3.5 使用mysqldiff比较对象的定义
20.4 专家解惑
20.5 经典习题
第21章 读写分离利器——MySQL Proxy
21.1 概述
21.2 安装与配置
21.2.1 下载与安装MySQL Proxy
21.2.2 配置MySQL Proxy参数
21.2.3 配置Path变量
21.3 使用MySQL Proxy实现读写分离
21.3 专家解惑
21.4 经典习题
第22章 PHP操作MySQL数据库
22.1 PHP访问MySQL数据的一般步骤
22.2 连接数据库前的准备工作
22.3 PHP操作MySQL数据库的函数
22.3.1 通过MySQLi类库访问MySQL数据库
22.3.2 使用MySQLi_connect()函数连接MySQL服务器
22.3.3 使用MySQLi_select_db()函数选择数据库文件
22.3.4 使用MySQLi_query()函数执行SQL语句
22.3.5 使用MySQLi_fetch_assoc()函数从数组结果集中获取信息
22.3.6 使用MySQLi_fetch_object()函数从结果中获取一行作为对象
22.3.7 使用MySQLi_num_rows()函数获取查询结果集中的记录数
22.3.8 使用MySQLi_free_result()函数释放资源
22.3.9 使用MySQLi_close()函数关闭连接
22.4 综合案例1——使用insert语句动态添加用户信息
22.5 综合案例2——使用select语句查询数据信息
22.6 专家解惑
22.7 经典习题
第23章 新闻发布系统数据库设计
23.1 系统概述
23.2 系统功能
23.3 数据库设计和实现
23.3.1 设计表
23.3.2 设计索引
23.3.3 设计视图
23.3.4 设计触发器
23.4 案例总结
第24章 论坛管理系统数据库设计
24.1 系统概述
24.2 系统功能
24.3 数据库设计和实现
24.3.1 设计方案图表
24.3.2 设计表
24.3.3 设计索引
24.3.4 设计视图
24.3.5 设计触发器
24.4 案例总结
MySQL5.7从入门到精通 (视频教学版) 刘增杰 编著的更多相关文章
- 《MySQL5.7从入门到精通(视频教学版)》
· 一:书籍PDF获取途径 pdf 文档 在 此QQ群(668345923) 的群文件里面 学习视频资源 二:书籍介绍 本书主要包括MySQL的安装与配置.数据库的创建.数据表的创建.数据类型和运算符 ...
- 基于股票大数据分析的Python入门实战(视频教学版)的精彩插图汇总
在我写的这本书,<基于股票大数据分析的Python入门实战(视频教学版)>里,用能吸引人的股票案例,带领大家入门Python的语法,数据分析和机器学习. 京东链接是这个:https://i ...
- 数据库技术丛书:SQL Server 2016 从入门到实战(视频教学版) PDF
1:书籍下载方式: SQL Server2016从入门到实战 PDF 下载 链接:https://pan.baidu.com/s/1sWZjdud4RosPyg8sUBaqsQ 密码:8z7w 学习 ...
- 2015年新版C#从入门到精通(第2版)视频教学录像【无水印版】
<c#从入门到精通(第2版)>以零基础讲解为宗旨,用实例引导读者学习,深入浅出地介绍了c#的相关知识和实战技能.<c#从入门到精通(第2版)>第1篇[c#语言基础]主要讲解c# ...
- Python从入门到精通视频(全60集) ☝☝☝
Python从入门到精通视频(全60集) Python入门到精通 学习 教程 首先,课程的顺序需要调整:一和三主要是介绍学习和布置开发环境的,一介绍的是非VS开发,三介绍的是VS开发.VS2017现在 ...
- Python从入门到精通视频(全60集)✍✍✍
Python从入门到精通视频(全60集) 整个课程都看完了,这个课程的分享可以往下看,下面有链接,之前做java开发也做了一些年头,也分享下自己看这个视频的感受,单论单个知识点课程本身没问题,大家看 ...
- HTML5+CSS3从入门到精通 中文pdf版
HTML5+CSS3从入门到精通是通过基础知识+中小实例+综合案例的方式,讲述了用HTML5+ CSS3设计构建网站的必备知识,相对于专业指南.高级程序设计.开发指南同类图书,本书是一本适合快速入手的 ...
- 《PHP 5.5从零開始学(视频教学版)》内容简单介绍、文件夹
<PHP 5.5从零開始学(视频教学版)>当当网购买地址: http://product.dangdang.com/23586810.html <PHP 5.5从零開始学(视频教学版 ...
- 《LabVIEW 虚拟仪器程序设计从入门到精通(第二版)》一1.3 小结
本节书摘来自异步社区<LabVIEW 虚拟仪器程序设计从入门到精通(第二版)>一书中的第1章,第1.3节,作者 林静 , 林振宇 , 郑福仁,更多章节内容可以访问云栖社区"异步社 ...
随机推荐
- 洛谷 P1807 最长路_NOI导刊2010提高(07)
最长路 #include <iostream> #include <cstdio> #include <cstring> #include <queue> ...
- 理解 JavaScript 的 async/await
随着 Node 7 的发布,越来越多的人开始研究据说是异步编程终级解决方案的 async/await.我第一次看到这组关键字并不是在 JavaScript 语言里,而是在 c# 5.0 的语法中.C# ...
- ./theHarvester.py -d baidu.com -l 100 -b google
./theHarvester.py -d baidu.com -l 100 -b google
- Jenkins上svn更新策略说明
- Windows平台下如何在C#中调用Python
最近迷上了Python,发现它能够做很多C#无法完成的事情,比如,调用CMD或者在CMD中执行一个exe文件命令行并获得输出的结果.过程简单,处理起来也非常方便,但如果要用C#调用Python文件呢, ...
- docker-java的使用
1. docker java 的api需要证书的认证 在/home/hett文件下创建certs证书 生成服务器私钥,命令如下: $openssl genrsa -out server-key.pem ...
- ansys-表格
转自http://blog.sina.com.cn/s/blog_833dee820102xwb3.html ANSYS中表格数组的定义及使用举例 ANSYS中会有许多的参数数据,这些参数的形成后要放 ...
- [dp][uestc]L - 菲波拉契数制升级版
数据很大,以背包的思路数组开不下. 先定序地考虑一个菲波拉契数如fib(i)的表示法,假设i比较大,由菲波拉契数的定义可知道fib(i)=fib(i-1)+fib(i-2);要找到其它表示就继续拆分f ...
- 激光推送报错:APNs is not available,please check your provisioning profile and certification 和 设置别名问题 app not registed, give up set tag:
前几天,项目中用到了推送功能,就集成了激光,遇到了2个问题,就给大家分享一下, 第一个问题: 在集成的过程是按照激光的文档做的,但是最后配置完了,一运行,就打印出这么一句话, APNs is not ...
- anaconda 安装各种库
在anaconda prompt 添加清华源 https://mirrors.tuna.tsinghua.edu.cn/help/anaconda/ conda config --add channe ...