图片.png
1.Linux系统安装MySQL
1.1.安装之前先查看linux是否有mysql
- rpm -qa|grep -i mysql
- 如果有mysql先停止服务,再进行卸载
- service mysql stop
- rpm -e --nodeps MySQL-client-5.6.22-1.el6.i686
- rpm -e --nodeps MySQL-server-5.6.22-1.el6.i686
- find / -name mysql(删除老版本的文件和库)
- rm -rf 上一条命令查找的文件或目录
- rm -rf /etc/my.cnf
- rpm -qa|grep -i mysql最后再检查一遍
1.2.安装mysql
- alt + p -------> put E:/test/MySQL-5.6.22-1.el6.i686.rpm-bundle.tar
- mkdir mysql
- 解压tar -xvf MySQL-5.6.22-1.el6.i686.rpm-bundle.tar -C /root/mysql
- 安装依赖包 yum -y install libaio.so.1 libgcc_s.so.1 libstdc++.so.6 libncurses.so.5 --setopt=protected_multilib=false
- 安装依赖包 yum update libstdc++-4.4.7-4.el6.x86_64 (可能会失败 失败就查一下rpm -qa|grep -i libstdc 有高版本的就跳过此步骤)
- rpm -ivh MySQL-client-5.6.22-1.el6.i686.rpm
- rpm -ivh MySQL-server-5.6.22-1.el6.i686.rpm
- yum -y install autoconf(可能需要安装)
- /usr/bin/mysql_install_db --user=mysql(上一步执行的话,此步骤也要执行)
- find / -name my.cnf(/usr/my.cnf)
- 修改mysql默认字符集 [mysqld]下添加两行character-set-server=utf8 collation-server=utf8_general_ci 在文件最下方添加 [client] default-character-set=utf8
1.3.启动mysql服务
图片.png
1.4.登录mysql
图片.png
- service iptables status
- systemctl stop firewalld(关闭防火墙)
2.索引
2.1.概述
索引(index)是帮助MySQL高效获取数据的数据结构(有序)。在数据之外,数据库系统还维护者满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据, 这样就可以在这些数据结构上实现高级查找算法,这种数据结构就是索引。图片.png
左边是数据表,一共有两列七条记录,最左边的是数据记录的物理地址(注意逻辑上相邻的记录在磁盘上也并不是 一定物理相邻的)。为了加快Col2的查找,可以维护一个右边所示的二叉查找树,每个节点分别包含索引键值和一 个指向对应数据记录物理地址的指针,这样就可以运用二叉查找快速获取到相应数据。
2.2.优势劣势
- 优势
1) 类似于书籍的目录索引,提高数据检索的效率,降低数据库的IO成本。
2) 通过索引列对数据进行排序,降低数据排序的成本,降低CPU的消耗。 - 劣势
1) 实际上索引也是一张表,该表中保存了主键与索引字段,并指向实体类的记录,所以索引列也是要占用空间 的。
2) 虽然索引大大提高了查询效率,同时却也降低更新表的速度,如对表进行INSERT、UPDATE、DELETE。因为 更新表时,MySQL 不仅要保存数据,还要保存一下索引文件每次更新添加了索引列的字段,都会调整因为更新所 带来的键值变化后的索引信息
2.3.结构
图片.png
-
BTREE结构
最顶端是根节点,中间是子节点,最末端是叶子节点
图片.png
插入 C N G A H E K Q M F W L T Z D P R X Y S 数据为例。图片.png图片.png图片.png图片.png -
B+TREE结构
图片.png -
mysql中的B+Tree
图片.png
2.4.分类
图片.png
2.5.语法
- 环境准备
CREATE DATABASE demo_01 DEFAULT CHARSET = utf8mb4 ;
USE demo_01;
CREATE TABLE `city` (
`city_id` INT (11) NOT NULL AUTO_INCREMENT,
`city_name` VARCHAR (50) NOT NULL,
`country_id` INT (11) NOT NULL,
PRIMARY KEY (`city_id`)
) ENGINE = INNODB DEFAULT CHARSET = utf8 ;
CREATE TABLE `country` (
`country_id` INT (11) NOT NULL AUTO_INCREMENT,
`country_name` VARCHAR (100) NOT NULL,
PRIMARY KEY (`country_id`)
) ENGINE = INNODB DEFAULT CHARSET = utf8 ;
INSERT INTO `city` (`city_id`, `city_name`, `country_id`) VALUES(1,'西安',1);
INSERT INTO `city` (`city_id`, `city_name`, `country_id`) VALUES(2,'NewYork',2);
INSERT INTO `city` (`city_id`, `city_name`, `country_id`) VALUES(3,'北京',1);
INSERT INTO `city` (`city_id`, `city_name`, `country_id`) VALUES(4,'上海',1);
INSERT INTO `country` (`country_id`, `country_name`) VALUES(1,'China');
INSERT INTO `country` (`country_id`, `country_name`) VALUES(2,'America');
INSERT INTO `country` (`country_id`, `country_name`) VALUES(3,'Japan');
INSERT INTO `country` (`country_id`, `country_name`) VALUES(4,'UK');
- 创建索引CREATE INDEX index_city_name ON city(city_name)
- 查看索引SHOW INDEX FROM city
- 删除索引DROP INDEX index_city_name ON city
-
alert命令创建索引
图片.png
2.6.设计原则
图片.png
3.视图
参考02_MySQL进阶
4.存储过程和函数
游标需要用的数据
CREATE TABLE emp (
id INT (11) NOT NULL AUTO_INCREMENT,
NAME VARCHAR (50) NOT NULL COMMENT '姓名',
age INT (11) COMMENT '年龄',
salary INT (11) COMMENT '薪水',
PRIMARY KEY (`id`)
) ENGINE = INNODB DEFAULT CHARSET = utf8 ;
INSERT INTO emp(id,NAME,age,salary)
VALUES
(NULL,'金毛狮王',55,3800),
(NULL,'白眉鹰 王',60,4000),
(NULL,'青翼蝠王',38,2800),
(NULL,'紫衫龙王',42,1800);
参考03_MySQL高级
5.触发器
CREATE TABLE emp_logs (
id INT (11) NOT NULL AUTO_INCREMENT,
operation VARCHAR (20) NOT NULL COMMENT '操作类型, insert/update/delete',
operate_time DATETIME NOT NULL COMMENT '操作时间',
operate_id INT (11) NOT NULL COMMENT '操作表的ID',
operate_params VARCHAR (500) COMMENT '操作参数',
PRIMARY KEY (`id`)
) ENGINE = INNODB DEFAULT CHARSET = utf8 ;
参考03_MySQL高级