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高级

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,701评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,649评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,037评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,994评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,018评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,796评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,481评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,370评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,868评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,014评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,153评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,832评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,494评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,039评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,156评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,437评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,131评论 2 356

推荐阅读更多精彩内容