Linux运维必会MySQL30道基础命令

 Linux运维必会MySQL 30道基础命令 

老男孩老师教学与培训核心思想:重目标、重思路、重方法、重实践、重习惯、重总结。

版权声明:余连辉

本系列文档为《老男孩 Linux 运维实战培训中心》内部教学用教案,只允许 VIP 学员 个人使用,为保护大家的学习利益,禁止私自传播,违者将取消 VIP 学员资格。严重者我们将法律起诉。如果你已经参加本培训,即视为你已无条件接受上述内容说明!

联系方式:

意见投诉信箱:[email protected] 网站运维交流群:114580181 246054962 45039636 37081784

==========================================

老男孩linux 实训联系方式

咨询:QQ:70271111 41117397 41117483 80042789 电话:1860033834018911718229 网站地址:http://www.etiantian.org http://bbs.etiantian.org blog

http://oldboy.blog.51cto.com

文档信息:

文档版本:Version 1.6

文档作用:课后总结

修改记录:2015-12-21

系统环境:CentOS release 6.7 (Final)

技术交流:http://yulianhui.blog.51cto.com/

  

Linux运维必会MySQL 30道基础命令... 1

1.登陆数据库。... 2

2.查看数据库版本及当前登录用户是什么。... 2

3.创建GBK字符集的数据库oldboy,并查看已建库的完整语句。... 3

4.创建用户oldboy,使之可以管理数据库oldboy... 4

5.查看创建的用户oldboy拥有哪些权限。... 4

5.查看当前数据库里有哪些用户。... 5

6.进入oldboy数据库... 5

8.创建一innodb引擎字符集为GBKtest,字段为idnamevarchar(16),查看建表结构及SQL语句。... 6

9.插入一条数据 1,oldboy. 7

10.批量插入数据 2,老男孩,3,etiantian要求中文不能乱码。... 8

11.查询插入的所有记录,查询名字为oldboy的记录。查询id大于1的记录。... 8

12.把数据id等于1的名字oldboy更改为oldgirl... 10

13.在字段name前插入age字段,类型tinyint(2)... 10

14.备份oldboy库及MySQL库。... 11

15.删除表中的所有数据,并查看。... 11

16.删除表testoldboy数据库并查看... 12

17.Linux命令行恢复以上删除的数据。... 13

18.GBK字符集修改为UTF8(可选,注意,此题有陷阱)。... 14

19.MySQL密码丢了,如何找回实战?... 16

20.MySQL内中文数据乱码的原理及如何防止乱码?(可选)。... 19

21.在把id列设置为主键,在Name字段上创建普通索引。... 20

22.在字段name后插入手机号字段(shouji),类型char(11)... 21

23.所有字段上插入2条记录(自行设定数据)... 22

24.在手机字段上对前8个字符创建普通索引。... 23

25.查看创建的索引及索引类型等信息。... 23

26.删除Nameshouji列的索引。... 25

27.Name列的前6个字符以及手机列的前8个字符组建联合索引。... 26

28.查询手机号以135开头的,名字为oldboy的记录(此记录要提前插入)。... 28

29.查询上述语句的执行计划(是否使用联合索引等)。... 28

30.test表的引擎改成MyISAM... 29

 

 

数据库的重要性是所有技术里最核心最需要掌握的(理解原理,并且被面试时能清晰的表达出来),直接决定运维人员薪水的高低!

 

所有题都要给出专业的解答方案,不是很水的那种泛泛的解答。

 

 

1.登陆数据库。

mysql-uroot -poldboy123 -S /data/3306/mysql.sock
Welcometo the MySQL monitor.  Commands end with; or \g.
YourMySQL connection id is 12
Serverversion: 5.5.32-log Source distribution
 
Copyright(c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
 
Oracleis 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>

 

2.查看数据库版本及当前登录用户是什么。

#查看数据库版本
mysql>select version();
+------------+
|version()  |
+------------+
|5.5.32-log |
+------------+
1row in set (0.00 sec)
#查看当前登录用户
mysql>select user();
+----------------+
|user()         |
+----------------+
|root@localhost |
+----------------+
1row in set (0.00 sec)

 

3.创建GBK字符集的数据库oldboy,并查看已建库的完整语句。

mysql>create database oldboy character set gbk collate gbk_chinese_ci;
QueryOK, 1 row affected (0.00 sec)
 
mysql>show databases;
+--------------------+
|Database           |
+--------------------+
|information_schema |
|mysql              |
|oldboy             |
|performance_schema |
+--------------------+
4rows in set (0.00 sec)
 
mysql>

#查看已建库的完整语句

mysql>show create database oldboy\G
***************************1. row ***************************
       Database: oldboy
CreateDatabase: CREATE DATABASE `oldboy` /*!40100 DEFAULT CHARACTER SET gbk */
1row in set (0.00 sec)

 

4.创建用户oldboy,使之可以管理数据库oldboy。

mysql>grant all on oldboy.* to oldboy@'localhost' identified by '123';
QueryOK, 0 rows affected (0.00 sec)

 

5.查看创建的用户oldboy拥有哪些权限。

mysql>show grants for oldboy@'localhost'\G
***************************1. row ***************************
Grantsfor oldboy@localhost: GRANT USAGE ON *.* TO 'oldboy'@'localhost' IDENTIFIED BYPASSWORD '*23AE809DDACAF96AF0FD78ED04B6A265E05AA257'
***************************2. row ***************************
Grantsfor oldboy@localhost: GRANT ALL PRIVILEGES ON`oldboy`.* TO 'oldboy'@'localhost'
2rows in set (0.00 sec)

 

6.查看当前数据库里有哪些用户。

mysql>select user,host from mysql.user;
+--------+-----------+
|user   | host      |
+--------+-----------+
|rep    | 10.0.0.%  |
|root   | 127.0.0.1 |
|oldboy | localhost |
|root   | localhost |
+--------+-----------+
4rows in set (0.00 sec)

 

 

6.进入oldboy数据库

mysql>use oldboy;

Databasechanged

mysql>select database();

+------------+

|database() |

+------------+

| oldboy   |

+------------+

1row in set (0.00 sec)

 

8.创建一innodb引擎字符集为GBK表test,字段为id和namevarchar(16),查看建表结构及SQL语句。

mysql>create table test(
    -> id int(4),
    -> name varchar(16)
    -> ) ENGINE=innodb default charset=gbk;
QueryOK, 0 rows affected (0.01 sec)
mysql>show tables;
+------------------+
|Tables_in_oldboy |
+------------------+
|test          |
+------------------+
1row in set (0.00 sec)

#查看表结构:方法一

mysql>desc test;
+-------+-------------+------+-----+---------+-------+
|Field | Type     | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
|id    | int(4)      | YES |     | NULL |  |
|name  | varchar(16) | YES  |     |NULL |  |
+-------+-------------+------+-----+---------+-------+
2rows in set (0.00 sec)

#查看表结构:方法二

mysql>show columns from test;
+-------+-------------+------+-----+---------+-------+
|Field | Type        | Null | Key |Default | Extra |
+-------+-------------+------+-----+---------+-------+
|id    | int(4)      | YES |     | NULL    |      |
|name  | varchar(16) | YES  |     |NULL    |       |
+-------+-------------+------+-----+---------+-------+
2rows in set (0.00 sec)

#查看表结构sql语句

mysql>show create table test\G
***************************1. row ***************************
       Table: test
CreateTable: CREATE TABLE `test` (
  `id` int(4) DEFAULT NULL,
  `name` varchar(16) DEFAULT NULL
)ENGINE=InnoDB DEFAULT CHARSET=gbk
1row in set (0.00 sec)

 

 

9.插入一条数据 1,oldboy

mysql>insert into test values(1,'oldboy');

Query OK, 1 row affected (0.00 sec)

 

mysql> select * from test;

+------+--------+

| id   |name   |

+------+--------+

|    1 | oldboy |

+------+--------+

1 row in set (0.00 sec)

 

 

 

10.批量插入数据 2,老男孩,3,etiantian。要求中文不能乱码。

mysql> insert into test values(2,'老男孩'),(3,'etiantian');
Query OK, 2 rows affected (0.01 sec)
Records: 2 Duplicates: 0  Warnings: 0
 
mysql> select * from test;                                
+------+-----------+
| id   |name       |
+------+-----------+
|    1 |oldboy     |
|    2 | 老男孩  |
|    3 | etiantian |
+------+-----------+
3 rows in set (0.00 sec)

 

11.查询插入的所有记录,查询名字为oldboy的记录。查询id大于1的记录。

(1)查询插入的所有记录

mysql> select * from test;                                
+------+-----------+
| id   |name   |
+------+-----------+
|    1 |oldboy  |
|    2 | 老男孩 |
|    3 | etiantian |
+------+-----------+
3 rows in set (0.00 sec)

(2)查询名字为oldboy的记录

mysql> select * from test where name='oldboy';
+------+--------+
| id   | name   |
+------+--------+
|    1 |oldboy |
+------+--------+
1 row in set (0.01 sec)

(3)查询id大于1的记录

mysql> select * from test where id>1;
+------+-----------+
| id   |name   |
+------+-----------+
|    2 | 老男孩 |
|    3 |etiantian |
+------+-----------+
2 rows in set (0.00 sec)

 

 

12.把数据id等于1的名字oldboy更改为oldgirl。

mysql> update test set name='oldgirl' whereid=1;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1  Warnings: 0
 
mysql> select * from test;
+------+-----------+
| id   |name   |
+------+-----------+
|    1 |oldgirl  |
|    2 | 老男孩 |
|    3 |etiantian |
+------+-----------+
3 rows in set (0.00 sec)

 

13.在字段name前插入age字段,类型tinyint(2)。

 

mysql> alter table test add age tinyint(2)after id;
Query OK, 3 rows affected (0.01 sec)
Records: 3 Duplicates: 0  Warnings: 0
 
mysql> desc test;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    |int(4)      | YES  |    | NULL  |  |
| age   |tinyint(2)  | YES  |    |NULL   |  |
| name  |varchar(16) | YES  |    | NULL |  |
+-------+-------------+------+-----+---------+-------+
rows in set (0.00 sec)

 

 

14.备份oldboy库及MySQL库。

退出mysql数据库在命令行输入

mysqldump -uroot -poldboy123 -S /data/3306/mysql.sock--events -B oldboy mysql >/opt/bak.sql
[root@db02 ~]# ll /opt/bak.sql
-rw-r--r-- 1 root root 529737 Dec 21 16:55/opt/bak.sql

 

 

15.删除表中的所有数据,并查看。

delete是逻辑删除表中的数据,一列一列的删除表中数据,速度比较慢

mysql> delete from test;

truncate是物理删除表中的数据,一次性全部都给清空表中数据,速度很快

mysql> truncate table test;
Query OK, 0 rows affected (0.00 sec)

##查看结果

mysql> select * from test;
Empty set (0.00 sec)

 

16.删除表test和oldboy数据库并查看

#删除表test

mysql> show tables;
+------------------+
| Tables_in_oldboy |
+------------------+
| test            |
+------------------+
1 row in set (0.00 sec)
 
mysql> drop table test;
Query OK, 0 rows affected (0.01 sec)
 
mysql> show tables;   
Empty set (0.00 sec)

#删除数据库oldboy

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| oldboy             |
| performance_schema |
+--------------------+
4 rows in set (0.00 sec)
 
mysql> drop database oldboy;
Query OK, 0 rows affected (0.00 sec)

##查看结果

mysql> show databases;     
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
+--------------------+
3 rows in set (0.00 sec)

 

17.Linux命令行恢复以上删除的数据。

#退出mysql数据库在命令输入命令

mysql -uroot -poldboy123 -S /data/3306/mysql.sock</opt/bak.sql

#登录数据库并查看结果

mysql> show databases;
+--------------------+
| Database        |
+--------------------+
| information_schema |
| mysql            |
| oldboy            |
| performance_schema |
+--------------------+
4 rows in set (0.00 sec)


#查看test表的数据

mysql> select * from oldboy.test;
+------+------+-----------+
| id   | age  | name  |
+------+------+-----------+
|    1 | NULL |oldgirl |
|    2 | NULL | 老男孩|
|    3 | NULL |etiantian |
+------+------+-----------+
3 rows in set (0.00 sec)


 

18.把GBK字符集修改为UTF8(可选,注意,此题有陷阱)。

 

#首先查看一下

mysql> show variables like 'character_set%';
+--------------------------+-------------------------------------------+
| Variable_name            | Value                  |
+--------------------------+-------------------------------------------+
| character_set_client     | utf8                       |
| character_set_connection | utf8                       |
| character_set_database   | utf8                      |
| character_set_filesystem | binary                      |
| character_set_results    | utf8                       |
| character_set_server     | utf8                       |
| character_set_system     | utf8                       |
| character_sets_dir       |/application/mysql-5.5.32/share/charsets/ |
+--------------------------+-------------------------------------------+
8 rows in set (0.00 sec)

###人品好字符集都是utf8O(∩_∩)O哈哈~

#现在开始模拟gbk字符集测试环境

mysql> set global character_set_database = gbk;
mysql> quit;
[root@db02 ~]# mysql -uroot -poldboy -S/data/3306/mysql.sock
mysql> show variables like 'character_set%';
+--------------------------+-------------------------------------------+
| Variable_name            | Value                  |
+--------------------------+-------------------------------------------+
| character_set_client     | utf8                       |
| character_set_connection | utf8                       |
| character_set_database   | gbk                       |
| character_set_filesystem | binary                      |
| character_set_results    | utf8                       |
| character_set_server     | utf8                       |
| character_set_system     | utf8                       |
| character_sets_dir       | /application/mysql-5.5.32/share/charsets/|
+--------------------------+-------------------------------------------+
8 rows in set (0.00 sec)

##现在把字符集修改成utf8会了吗?

操作一下吧-_-!!!

mysql> set global character_set_database = utf8;
Query OK, 0 rows affected (0.00 sec)
 
mysql> quit;
Bye
mysql> show variables like 'character_set%';
+--------------------------+-------------------------------------------+
| Variable_name            | Value                  |
+--------------------------+-------------------------------------------+
| character_set_client     | utf8                       |
| character_set_connection | utf8                       |
| character_set_database   | utf8                      |
| character_set_filesystem | binary                      |
| character_set_results    | utf8                      |
| character_set_server     | utf8                       |
| character_set_system     | utf8                       |
| character_sets_dir       |/application/mysql-5.5.32/share/charsets/ |
+--------------------------+-------------------------------------------+
8 rows in set (0.00 sec)

#这就完成了!

 

19.MySQL密码丢了,如何找回实战?

#查看一下进程是否服务在运行

[root@db02 ~]# ps -ef |grep 3306
root     1466     1  0 10:36 ?        00:00:00 /bin/sh/application/mysql/bin/mysqld_safe --defaults-file=/data/3306/my.cnf
mysql    2190  1466  0 10:36 ?        00:00:11/application/mysql-5.5.32/bin/mysqld --defaults-file=/data/3306/my.cnf--basedir=/application/mysql --datadir=/data/3306/data--plugin-dir=/application/mysql/lib/plugin --user=mysql--log-error=/data/3306/mysql_oldboy3306.err --open-files-limit=1024--pid-file=/data/3306/mysqld.pid --socket=/data/3306/mysql.sock --port=3306
root     3935  3703  0 16:16 pts/3    00:00:00 mysql -uroot -px xxxxxxx -S/data/3306/mysql.sock
root     4099  4008  0 17:17 pts/1    00:00:00 grep --color=auto 3306

#杀死进程pid号

 

[root@db02~]# kill 1466
 [root@db02~]# kill 1466
-bash: kill: (1466) - No such process
[root@db02 ~]# ps -ef |grep 3306
root     3935  3703  0 16:16 pts/3    00:00:00 mysql -uroot -px xxxxxxx -S/data/3306/mysql.sock
root     4104  4008  0 17:17 pts/1    00:00:00 grep --color=auto 3306

[root@db02 ~]# pkill mysql   ###<====这里别忘了杀死-_-!!

#启动mysql实例3306跳过输入用户密码文件

[root@db02 ~]# mysqld_safe--defaults-file=/data/3306/my.cnf --skip-grant-tables &>/dev/null &    ##<=====放在后台运行

[1] 4697

[root@db02 ~]# ps -ef |grep 3306
root     4697  4008  1 17:24 pts/1    00:00:00 /bin/sh/application/mysql/bin/mysqld_safe --defaults-file=/data/3306/my.cnf--skip-grant-tables
mysql    5434  4697  2 17:24 pts/1    00:00:00/application/mysql-5.5.32/bin/mysqld --defaults-file=/data/3306/my.cnf--basedir=/application/mysql --datadir=/data/3306/data --plugin-dir=/application/mysql/lib/plugin--user=mysql --skip-grant-tables --log-error=/data/3306/mysql_oldboy3306.err--open-files-limit=1024 --pid-file=/data/3306/mysqld.pid--socket=/data/3306/mysql.sock --port=3306
root     5453  4008  0 17:24 pts/1    00:00:00 grep --color=auto 3306
[root@db02 ~]# netstat -ltunp |grep 3306
tcp       0      0 0.0.0.0:3306                0.0.0.0:*                   LISTEN      5434/mysqld

#登录到数据库3306实例

[root@db02 ~]# mysql -S /data/3306/mysql.sock
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.5.32-log Source distribution
Copyright (c) 2000, 2013, Oracle and/or itsaffiliates. All rights reserved.
Oracle is a registered trademark of OracleCorporation and/or its
affiliates. Other names may be trademarks oftheir respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clearthe current input statement.
mysql>

#修改mysql超级管理root密码

mysql> update mysql.user setpassword=PASSWORD('oldboy') where user='root' and host='localhost';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1  Warnings: 0
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

#修改mysql启动脚本中用户密码

[root@db02 ~]# grep "pwd"/data/3306/mysql
mysql_pwd="oldboy"

#停止服务

[root@db02 ~]# /data/3306/mysql stop
Stoping MySQL...
[1]+ Done                   mysqld_safe --defaults-file=/data/3306/my.cnf --skip-grant-tables&>/dev/null
[root@db02 ~]# netstat -lutnp |grep 3306

#在启动服务

[root@db02 ~]# /data/3306/mysql start
Starting MySQL...

#登录数据库

[root@db02 ~]# mysql -uroot -poldboy -S/data/3306/mysql.sock
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.5.32-log Source distribution
Copyright (c) 2000, 2013, Oracle and/or itsaffiliates. All rights reserved.
Oracle is a registered trademark of OracleCorporation and/or its
affiliates. Other names may be trademarks oftheir respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clearthe current input statement.
mysql>

#完成!

 

20.MySQL内中文数据乱码的原理及如何防止乱码?(可选)。

数据库服务的字符集

|character_set_client      | utf8                      |
| character_set_connection | utf8                      |
| character_set_database   | utf8                      |
| character_set_filesystem | binary                    |
| character_set_results    | utf8                      |
| character_set_server     | utf8                      |
| character_set_system     | utf8                      |

系统字符集配置文件

[root@db02 ~]# cat /etc/sysconfig/i18n
LANG="en_US.UTF-8"
SYSFONT="latarcyrheb-sun16"

客户端软件CRT/xshell等软件字符集要用utf8

 

 

21.在把id列设置为主键,在Name字段上创建普通索引。

mysql> alter table oldboy.test add primarykey(id);     

Query OK, 3 rows affected (0.01 sec)

Records: 3 Duplicates: 0  Warnings: 0

 

mysql> desc oldboy.test;

+-------+-------------+------+-----+---------+-------+

| Field | Type    | Null | Key | Default | Extra |

+-------+-------------+------+-----+---------+-------+

| id    |int(4)      | NO  | PRI | 0   |     |

| age   |tinyint(2)  | YES  |  |NULL |      |

| name  |varchar(16) | YES  |  | NULL |    |

+-------+-------------+------+-----+---------+-------+

3 rows in set (0.00 sec)

#name字段上创建普通索引

方法一:

mysql> alter table oldboy.test add indexindex_name(name);
Query OK, 0 rows affected (0.02 sec)
Records: 0 Duplicates: 0  Warnings: 0

方法二:

mysql> create index index_name onoldboy.test(name);

#查看一下

mysql> desc oldboy.test;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    |int(4)      | NO   | PRI | 0 |     |
| age   |tinyint(2)  | YES  |     |NULL  | |
| name  | varchar(16) |YES  | MUL | NULL | |
+-------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

 

22.在字段name后插入手机号字段(shouji),类型char(11)。

mysql> alter table oldboy.test add shoujichar(11) after name;

Query OK, 3 rows affected (0.01 sec)

Records: 3 Duplicates: 0  Warnings: 0

 

mysql> desc oldboy.test;                                     
+--------+-------------+------+-----+---------+-------+
| Field  |Type     | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| id     |int(4)      | NO   | PRI | 0 |     |
| age    |tinyint(2)  | YES  |   |NULL |    |
| name   |varchar(16) | YES  | MUL | NULL|  |
| shouji | char(11)    | YES |   | NULL  |    |
+--------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)

 

23.所有字段上插入2条记录(自行设定数据)

mysql> insert into oldboy.testvalues(4,21,'yifeny','15511024633'),(5,38,'oldboy','13512569874');
Query OK, 2 rows affected (0.00 sec)
Records: 2 Duplicates: 0  Warnings: 0
 
mysql> select * from oldboy.test;
+----+------+-----------+-------------+
| id | age | name  | shouji      |
+----+------+-----------+-------------+
|  1 | NULL| oldgirl  | NUL    |
|  2 | NULL| 老男孩 |NULL  |
|  3 | NULL| etiantian | NUL    |
|  4 |  21 | yifeny | 15511024633 |
|  5 | 38 |oldboy  | 13512569874 |
+----+------+-----------+-------------+
5 rows in set (0.00 sec)

 

24.在手机字段上对前8个字符创建普通索引。

 

mysql> alter table oldboy.test add indexindex_shouji(shouji(8));
Query OK, 0 rows affected (0.15 sec)
Records: 0 Duplicates: 0  Warnings: 0
 
mysql> desc oldboy.test;
+--------+-------------+------+-----+---------+-------+
| Field  |Type     | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| id     |int(4)      | NO   | PRI | 0  |    |
| age    |tinyint(2)  | YES  |     |NULL  |   |
| name   | varchar(16)| YES  | MUL | NULL |    |
| shouji | char(11)    | YES | MUL | NULL   |  |
+--------+-------------+

------+-----+---------+-------+

4 rows in set (0.00 sec)

25.查看创建的索引及索引类型等信息。

mysql> show index from oldboy.test\G
*************************** 1. row***************************
        Table:test
  Non_unique: 0
    Key_name: PRIMARY
 Seq_in_index: 1
 Column_name: id
   Collation: A
 Cardinality: 5
    Sub_part: NULL
      Packed: NULL
        Null:
  Index_type: BTREE
     Comment:
Index_comment:
*************************** 2. row***************************
       Table: test
  Non_unique: 1
    Key_name: index_name
 Seq_in_index: 1
 Column_name: name
   Collation: A
 Cardinality: 5
    Sub_part: NULL
      Packed: NULL
        Null: YES
  Index_type: BTREE
      Comment:
Index_comment:
*************************** 3. row***************************
       Table: test
  Non_unique: 1
    Key_name: index_shouji
 Seq_in_index: 1
 Column_name: shouji
   Collation: A
 Cardinality: 5
    Sub_part: 8
      Packed: NULL
        Null: YES
  Index_type: BTREE
     Comment:
Index_comment:
3 rows in set (0.00 sec)

 

26.删除Name,shouji列的索引。

mysql> alter table oldboy.test drop indexindex_name;

Query OK, 0 rows affected (0.00 sec)

Records: 0 Duplicates: 0  Warnings: 0

mysql> drop index index_shouji on oldboy.test;

Query OK, 0 rows affected (0.00 sec)

Records: 0 Duplicates: 0  Warnings: 0

 

mysql> show index from oldboy.test\G                
*************************** 1. row***************************
       Table: test
  Non_unique: 0
    Key_name: PRIMARY
 Seq_in_index: 1
 Column_name: id
   Collation: A
 Cardinality: 5
    Sub_part: NULL
      Packed: NULL
        Null:
  Index_type: BTREE
     Comment:
Index_comment:
1 row in set (0.00 sec)

 

27.对Name列的前6个字符以及手机列的前8个字符组建联合索引。

mysql> alter table oldboy.test add indexindex_name_shouji(name(6),shouji(8));

Query OK, 0 rows affected (0.02 sec)

Records: 0 Duplicates: 0  Warnings: 0

 

mysql> show index from oldboy.test\G                                          
*************************** 1. row***************************
       Table: test
  Non_unique: 0
    Key_name: PRIMARY
 Seq_in_index: 1
 Column_name: id
   Collation: A
 Cardinality: 5
    Sub_part: NULL
      Packed: NULL
        Null:
  Index_type: BTREE
     Comment:
Index_comment:
*************************** 2. row***************************
       Table: test
  Non_unique: 1
    Key_name: index_name_shouji
 Seq_in_index: 1
 Column_name: name
   Collation: A
 Cardinality: 5
    Sub_part: 6
      Packed: NULL
        Null: YES
  Index_type: BTREE
     Comment:
Index_comment:
*************************** 3. row***************************
       Table: test
  Non_unique: 1
    Key_name: index_name_shouji
 Seq_in_index: 2
 Column_name: shouji
   Collation: A
 Cardinality: 5
    Sub_part: 8
      Packed: NULL
        Null: YES
  Index_type: BTREE
     Comment:
Index_comment:
3 rows in set (0.00 sec)

 

28.查询手机号以135开头的,名字为oldboy的记录(此记录要提前插入)。

mysql> select * from oldboy.test wherename='oldboy' and shouji like '135%';
+----+------+--------+-------------+
| id | age | name   | shouji      |
+----+------+--------+-------------+
|  5 |   38 | oldboy | 13512569874 |
+----+------+--------+-------------+
1 row in set (0.00 sec)

 

29.查询上述语句的执行计划(是否使用联合索引等)。

mysql> explain select * from oldboy.test where name='oldboy' andshouji like '135%';   

+----+-------------+-------+-------+-------------------+-------------------+---------+------+------+-------------+

| id | select_type | table | type | possible_keys    | key   | key_len | ref  | rows | Extra        |

+----+-------------+-------+-------+-------------------+-------------------+---------+------+------+-------------+

| 1 | SIMPLE | test | range | index_name_shouji |index_name_shouji | 32 | NULL | 1 |Using where |

+----+-------------+-------+-------+-------------------+-------------------+---------+------+------+-------------+

1 row in set (0.00 sec)

mysql> explain select * from oldboy.test where name='oldboy' andshouji like '135%'\G
*************************** 1. row***************************
           id: 1
  select_type: SIMPLE
        table: test
         type: range
possible_keys: index_name_shouji
          key:index_name_shouji
      key_len: 32
          ref: NULL
         rows: 1
        Extra: Using where
1 row in set (0.00 sec)

 

30.把test表的引擎改成MyISAM。

MySQL数据库5.1版本以前默认的引擎是MyISAM

MySQL数据库5.5版本以后默认的引擎都是InnoDB

 

#首先现在查看一下test表的引擎

mysql> show create table oldboy.test\G
*************************** 1. row ***************************
       Table: test
Create Table: CREATE TABLE `test` (
  `id` int(4) NOT NULL DEFAULT'0',
  `age` tinyint(2) DEFAULTNULL,
  `name` varchar(16) DEFAULTNULL,
  `shouji` char(11) DEFAULTNULL,
  PRIMARY KEY (`id`),
  KEY `index_name_shouji`(`name`(6),`shouji`(8))
) ENGINE=InnoDB DEFAULT CHARSET=gbk
1 row in set (0.00 sec)

#修改默认引擎为MyISAM

mysql> alter table oldboy.test ENGINE=MyISAM;
Query OK, 5 rows affected (0.01 sec)
Records: 5  Duplicates: 0  Warnings: 0
 
mysql> show create table oldboy.test\G      
*************************** 1. row ***************************
       Table: test
Create Table: CREATE TABLE `test` (
  `id` int(4) NOT NULL DEFAULT'0',
  `age` tinyint(2) DEFAULTNULL,
  `name` varchar(16) DEFAULTNULL,
  `shouji` char(11) DEFAULTNULL,
  PRIMARY KEY (`id`),
  KEY `index_name_shouji`(`name`(6),`shouji`(8))
) ENGINE=MyISAM DEFAULT CHARSET=gbk
1 row in set (0.00 sec)

 

 在这里有些代码字体颜色不了高亮显示,这是一个忧伤的故事!如果有人知道麻烦指点一下,真的很难受!

 


你可能感兴趣的:(Linux运维必会MySQL30道基础命令)