千家信息网

MySQL命令讲析

发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,本文主要给大家介绍MySQL命令讲析,希望可以给大家补充和更新些知识,如有其它问题需要了解的可以持续在行业资讯里面关注我的更新文章的。命令例子说明描述show显示数据库、表、列的信息和云服务器状态SH
千家信息网最后更新 2025年01月22日MySQL命令讲析

本文主要给大家介绍MySQL命令讲析,希望可以给大家补充和更新些知识,如有其它问题需要了解的可以持续在行业资讯里面关注我的更新文章的。

命令

例子

说明

描述

show


显示数据库、表、列的信息和云服务器状态

SHOW has many forms that provide information about databases, tables,

columns, or status information about the server.


mysql> show databases;

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

| Database |

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

| information_schema |

| mysql |

| performance_schema |

| test |

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

4 rows in set (0.00 sec)

显示所有数据库



mysql> show grants for oldboy@'localhost';

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

| Grants for oldboy@localhost |

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

| GRANT USAGE ON *.* TO 'oldboy'@'localhost' IDENTIFIED BY PASSWORD '*FE28814B4

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

1 row in set (0.00 sec)

显示用户权限USAGE表示没有权限



mysql> show databases like '%my%';

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

| Database (%my%) |

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

| mysql |

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

1 row in set (0.00 sec)

模糊匹配



mysql> show create database oldboy;

显示创建数据库的语句



show CHARACTER SET;

显示gbk的校对规则



mysql> show tables;

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

| Tables_in_oldboy |

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

| student |

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

1 row in set (0.00 sec)

#查看表



mysql> show create table student\G

*************************** 1. row ***************************

Table: student

Create Table: CREATE TABLE `student` (

`id` int(4) NOT NULL,

`name` char(20) NOT NULL,

`are` tinyint(2) NOT NULL DEFAULT '0',

`dept` varchar(16) DEFAULT NULL

) ENGINE=InnoDB DEFAULT CHARSET=utf8

1 row in set (0.00 sec)

#查看创建表语句



mysql> show index from student\G

*************************** 1. row ***************************

Table: student

Non_unique: 0

Key_name: PRIMARY #索引类型

Seq_in_index: 1

Column_name: id #索引列名称

Collation: A

Cardinality: 0

Sub_part: NULL

Packed: NULL

Null:

Index_type: BTREE

Comment:

Index_comment:

#查看表的索引


命令

例子

中文说明

英文描述

select





select user,host from mysql.user;

查询mysql库的user表的用户



mysql> select database();

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

| database() |

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

| NULL |

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

1 row in set (0.00 sec)

查看当前数据库



mysql> select user();

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

| user() |

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

| root@localhost |

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

1 row in set (0.01 sec)

查看当前用户



mysql> select version();

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

| version() |

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

| 5.5.32-log |

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

1 row in set (0.00 sec)

查看数据库版本



mysql> select now();

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

| now() |

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

| 2018-04-10 22:25:11 |

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

1 row in set (0.00 sec)

查看当前时间



mysql> select count(distinct user) from mysql.user;

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

| count(distinct user) |

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

| 7 |

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

1 row in set (0.01 sec)

统计表记录的唯一值的命令



mysql> select * from test;

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

| id | name |

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

| 1 | oldboy |

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

1 row in set (0.00 sec)

查看表所有数据



mysql> select * from test limit 2;

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

| id | name |

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

| 1 | oldboy |

| 2 | old111 |

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

2 rows in set (0.00 sec)

查询表的前2行



mysql> select * from test limit 2,3;

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

| id | name |

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

| 3 | kk |

| 4 | zuma |

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

2 rows in set (0.00 sec)

查询表的2到3行



mysql> select * from test where id=1;

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

| id | name |

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

| 1 | oldboy |

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

1 row in set (0.00 sec)

按条件查询表的数据



mysql> select * from test where id>2;

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

| id | name |

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

| 3 | kk |

| 4 | zuma |

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

2 rows in set (0.00 sec)

条件范围查询表数据



mysql> select * from test where id>2 and id<5;

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

| id | name |

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

| 3 | kk |

| 4 | zuma |

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

2 rows in set (0.00 sec)

条件范围查询表数据



mysql> select id,name from test where id>1 and id<5 order by id desc into outfile '/tmp/a.txt';

Query OK, 3 rows affected (0.00 sec)

#导出表数据


命令

例子

中文说明

英文描述

explain





mysql> explain select * from test where name='oldboy'\G

*************************** 1. row ***************************

id: 1

select_type: SIMPLE

table: test

type: ref

possible_keys: index_name #已使用,没使用为NULL

key: index_name #已使用

key_len: 60

ref: const

rows: 1

Extra: Using where; Using index

1 row in set (0.00 sec)

#查看表字段是否使用索引



[root@db02 ~]# mysql -uroot -poldboy123 -S /data/3306/mysql.sock -e "show full processlist;"|egrep -vi "sleep"

Id User Host db Command Time State Info

7 root localhost NULL Query 0 NULL show full process

抓取慢查询语句


命令

例子

中文说明

英文描述

desc

mysql> desc student;

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

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

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

| id | int(4) | NO | | NULL | |

| name | char(20) | NO | | NULL | |

| are | tinyint(2) | NO | | 0 | |

| dept | varchar(16) | YES | | NULL | |

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

4 rows in set (0.00 sec)

查看表结构


命令

例子

中文说明

英文描述

update


UPDATE语法可以用新值更新原有表行中的各列.SET子句指示要修改哪些列和要给予哪些值。WHERE子句指定应更新哪些行。如果没有WHERE子句,则更新所有的行。如果指定了ORDER BY子句,则按照被指定的顺序对行进行更新。

LIMIT子句用于给定一个限值,限制可以被更新的行的数目。

For the single-table syntax, the UPDATE statement updates columns of

existing rows in the named table with new values. The SET clause

indicates which columns to modify and the values they should be given.

Each value can be given as an expression, or the keyword DEFAULT to set

a column explicitly to its default value. The WHERE clause, if given,

specifies the conditions that identify which rows to update. With no

WHERE clause, all rows are updated. If the ORDER BY clause is

specified, the rows are updated in the order that is specified. The

LIMIT clause places a limit on the number of rows that can be updated


mysql> update mysql.user SET password=PASSWORD("oldboy123") WHERE user='root' and host='localhost';

update(修改) mysql.user(mysql数据库的user表) SET(指定哪列?改password列,要给予哪些值?PASSWORD值) password=PASSWORD("oldboy123") (改成oldboy123,PASSWORD必须加因为这个是加密的)WHERE(对谁进行更改?) user='root'(对root用户) and host='localhost';(和主机localhost修改)



mysql> update test set name='inct' where id=3;

Query OK, 1 row affected (0.00 sec)

Rows matched: 1 Changed: 1 Warnings: 0

#修改id为3的name,修改表一定要加条件



mysql> update test set name='inct';

Query OK, 4 rows affected (0.00 sec)

Rows matched: 5 Changed: 4 Warnings: 0

#如果不加条件是全部修改,这种问题是致命的。


命令

例子

中文说明

英文描述

alter


修改语句



mysql> alter table student change id id int primary key auto_increment;

#修改主键索引



mysql> alter table student drop index index_name;

Query OK, 0 rows affected (0.00 sec)

Records: 0 Duplicates: 0 Warnings: 0

#删除普通索引



mysql> alter table student add index index_name(name);

Query OK, 0 rows affected (0.09 sec)

Records: 0 Duplicates: 0 Warnings: 0

修改表的普通索引


命令

例子

中文说明

英文描述

drop





mysql> drop user ""@localhost;

Query OK, 0 rows affected (0.00 sec)

删除用户



mysql> drop database oldboy_gbk;

Query OK, 0 rows affected (0.01 sec)

删除数据库



drop table student;

删除之前建的表


命令

例子

中文说明

英文描述

delete


删除语句

For the single-table syntax, the DELETE statement deletes rows from

tbl_name and returns a count of the number of deleted rows.


mysql> delete from test where id=1;

Query OK, 1 row affected (0.00 sec)

#删除表指定的ID


命令

例子

中文说明

英文描述

create


创建语句



mysql> create database oldboy;

创建一个oldboy的数据库



mysql> create database oldboy_gbk CHARACTER SET gbk COLLATE gbk_chinese_ci;

创建gbk数据库



mysql> create user 'oldboy'@'localhost' identified by 'oldboy123';

Query OK, 0 rows affected (0.01 sec)

#创建用户



create table student(

id int(4) not null,

name char(20) not null,

are tinyint(2) NOT NULL default '0',

dept varchar(16) default NULL

);

创建表



mysql> create index index_dept on student(dept(8));

Query OK, 0 rows affected (0.02 sec)

Records: 0 Duplicates: 0 Warnings: 0

创建表某列的前8个字节的普通索引



mysql> create index index_name_dept on student(name,dept);

Query OK, 0 rows affected (0.05 sec)

Records: 0 Duplicates: 0 Warnings: 0

创建表的联合索引



mysql> create index index_name_dept on student(name(8),dept(10));

Query OK, 0 rows affected (0.03 sec)

Records: 0 Duplicates: 0 Warnings: 0

创建表的联合索引前N个字符



mysql> create unique index uni_ind_name on student(name);

Query OK, 0 rows affected (0.03 sec)

Records: 0 Duplicates: 0 Warnings: 0

#创建表唯一索引


命令

例子

中文说明

英文描述

grant


授权MYSQL用户权限和指定特殊权限

The GRANT statement grants privileges to MySQL user accounts. GRANT

also serves to specify other account characteristics such as use of

secure connections and limits on access to server resources. To use

GRANT, you must have the GRANT OPTION privilege, and you must have the

privileges that you are granting.


mysql> grant all on oldboy.* to oldboy@'localhost';

Query OK, 0 rows affected (0.01 sec)

#授权给oldboy用户



mysql> grant all on oldboy.* to 'oldboy11'@'localhost' identified by 'oldboy123';

Query OK, 0 rows affected (0.00 sec)

创建用户和密码并且授权


命令

例子

中文说明

英文描述

insert


插入语句

INSERT inserts new rows into an existing table. The INSERT ... VALUES

and INSERT ... SET forms of the statement insert rows based on

explicitly specified values. The INSERT ... SELECT form inserts rows

selected from another table or tables. INSERT ... SELECT is discussed

further in [HELP INSERT SELECT].


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

Query OK, 1 row affected (0.00 sec)

插入id=1 name=oldboy的内容到test表中


命令

例子

中文说明

英文描述

REVOKE


撤销权限

The REVOKE statement enables system administrators to revoke privileges

from MySQL accounts. Each account name uses the format described in


mysql> REVOKE INSERT ON oldboy.* FROM 'oldboy'@'localhost';

撤销插入权限


命令

例子

中文说明

英文描述

truncate

mysql> truncate table test;

#清空表数据


命令

例子

中文说明

英文描述

flush


刷新语句

The FLUSH statement has several variant forms that clear or reload

various internal caches, flush tables, or acquire locks. To execute

FLUSH, you must have the RELOAD privilege. Specific flush options might

require additional privileges, as described later.


mysql> flush privileges;



命令

例子

中文说明

英文描述

use


切换数据库相等于CD



mysql> use oldboy

Database changed

切换到oldboy数据库


看了以上关于MySQL命令讲析,希望能给大家在实际运用中带来一定的帮助。本文由于篇幅有限,难免会有不足和需要补充的地方,如有需要更加专业的解答,可在官网联系我们的24小时售前售后,随时帮您解答问题的。

0