05_在职加薪_MySQL_01

图片.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高级

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容