mysql常用操作
有一个图形管理mysql的工具叫phpmyadmin,而如何在命令行下面来管理和操作mysql。
data:image/s3,"s3://crabby-images/6bc39/6bc39502c2b1fdab32549a984bc08fde0227a8d0" alt=""
查看某个库的表
1 2
| mysql> use mysql; mysql> show tables;
|
data:image/s3,"s3://crabby-images/25bf2/25bf2742e9dc168c3d11799d52ec07fbab1ff7c5" alt=""
查看表的字段
1
| mysql> desc pre_ucenter_vars;
|
data:image/s3,"s3://crabby-images/6a09a/6a09a65e04a8f96dd04fce2489ec10f7f2cf791c" alt=""
查看建表的语句
1
| mysql> show create table pre_ucenter_vars\G;
|
data:image/s3,"s3://crabby-images/025a1/025a121b696754694199392c6f0cc204dc112efc" alt=""
当前是哪个用户
data:image/s3,"s3://crabby-images/2bb55/2bb55e66f562ab59577ff2d3b80d1b0e22e9ba66" alt=""
查看当前库
1
| mysql> select database();
|
data:image/s3,"s3://crabby-images/d7772/d77721af4238c1f91b47e3eb47830bf91c8f9096" alt=""
创建库
1
| mysql> create database yanyi;
|
data:image/s3,"s3://crabby-images/aa0b2/aa0b28fd0aae05d7a1b33263b312990f0f7a051d" alt=""
创建表
1
| mysql> create table tb1 (`id` int(4), `name` char(40)) ENGINE=MyISAM DEFAULT CHARSET=gbk;
|
tb1 是表名;第一个字段是 id
,格式是 int ,长度 4位;第二个字段 name
格式是 char 长度 40;指定 ENGINE 为 MyISAM ;字符集 DEFAULT CHARSET 为 gbk。
data:image/s3,"s3://crabby-images/0f558/0f558e00fc621289e0450fcc873cc58c17992e1c" alt=""
创建完成后查看
data:image/s3,"s3://crabby-images/ef43b/ef43be213e2f9f3dd561a10452de7f083766a528" alt=""
data:image/s3,"s3://crabby-images/d1654/d16543d87cf38469e63d5000213d42521ac057f3" alt=""
data:image/s3,"s3://crabby-images/c2791/c2791c7d2e5fc0888c4f95c2d5cacb984c84cfec" alt=""
插入数据
1
| mysql> insert into tb1 values (1,'yanyi');
|
data:image/s3,"s3://crabby-images/a90d7/a90d715e21003697f8828e6461af77e0c677ce7d" alt=""
还可以继续插入
data:image/s3,"s3://crabby-images/42428/424284caedb19b14371a3bb699a9715008f3a2ea" alt=""
也可以只插入一个字段
1
| mysql> insert into tb1 (`id`) values (2);
|
data:image/s3,"s3://crabby-images/39a29/39a2986d937e4c4231c658c09449fbf815133feb" alt=""
1
| mysql> insert into tb1 (`name`) values ('docker');
|
data:image/s3,"s3://crabby-images/33274/33274702d81ef960e70ba062422abe63386652fb" alt=""
1
| mysql> insert into tb1 (`name`,`id`) values ('redis',6);
|
data:image/s3,"s3://crabby-images/eeb06/eeb06f32aca6da16c1b11e872f67df0f771c7a90" alt=""
查看数据库版本
1
| mysql> select version();
|
data:image/s3,"s3://crabby-images/10883/1088385270696fc2060f4d1cb272094ec39b45a8" alt=""
查看 mysql 状态
data:image/s3,"s3://crabby-images/dc773/dc773642feea60523a5cfd48a3ef314443090195" alt=""
也可以用 like 过滤,% 通配
1
| mysql> show status like '%running';
|
data:image/s3,"s3://crabby-images/00513/00513f303837ff330de5c5672587036fe52719ff" alt=""
1
| mysql> show status like '%buffer%';
|
data:image/s3,"s3://crabby-images/bd738/bd7381fa6a65fdc141b7389c8e851984c4b9de05" alt=""
修改 mysql 参数
data:image/s3,"s3://crabby-images/2103b/2103b74aec0115e3556af96c2ede206d4d78b9c3" alt=""
1 2
| mysql> set global max_connections=200; mysql> show variables like 'max_connections';
|
data:image/s3,"s3://crabby-images/f2a26/f2a262dc5324fae5128c4e19950f95154f900947" alt=""
如果记不住也可以用 % 通配
1
| mysql> show variables like 'max_connec%';
|
data:image/s3,"s3://crabby-images/b4326/b4326dfec5b7b440a13826ce16b58a7169eb7609" alt=""
不过这些方法,重启就会变回以前配置,要永久生效需更改 /etc/my.cnf
查看 mysql 队列
1
| mysql> show processlist;
|
data:image/s3,"s3://crabby-images/2c073/2c073a51db71ff67f8ee0c7d503d0c2af199ee57" alt=""
查看 mysql 变量
创建普通用户并授权
1 2 3 4 5
| mysql> grant all on *.* to user1 identified by '123456'; mysql> grant all on discuz.* to 'user2'@'192.168.0.%' identified by '123456'; mysql> grant all on discuz.* to 'user3'@'%' identifined by '123456';
|
all 代表所有权限;.代表所有库里的所有表,discuz.*代表 discuz 库里的所有表;to 后边是用户名;@ 后边是客户端 ip ,192.168.0.%代表整个网段,% 代表通配,直接用 % 代替 ip 就表示所有网段;identfied by 后边是密码。
用户创建完以后还没有即时生效,需要刷新下权限命令如下
1
| mysql> flush privileges;
|
更改密码
1
| mysql> update mysql.user set password=password("newpwd") where user='username';
|
查询
1
| mysql> select count(*) from mysql.user;
|
data:image/s3,"s3://crabby-images/23eb0/23eb0820237629a5b76b3c28650c8e15a8d69af1" alt=""
1
| mysql> select * from mysql.db;select * from mysql.db where host like '10.0.%'\G;
|
data:image/s3,"s3://crabby-images/17143/1714386b8f02427778adf23d2dd230bded2b8f92" alt=""
插入
1
| mysql> update tb1 set id=5 where name = 'docker';
|
data:image/s3,"s3://crabby-images/3763f/3763fcec6c439d23de23c26e25c27ee6ee359f23" alt=""
清空表
1
| mysql> truncate table yanyi.tb1;
|
yanyi是库名,tb1是表名,清空以后表还在。
data:image/s3,"s3://crabby-images/a301f/a301fde388e55292d3508776c85a696f0b9e87ef" alt=""
删除表
1
| mysql> delete from tb1 where name='redis'
|
这是删除表中指定的行
data:image/s3,"s3://crabby-images/52844/52844bfbf1bd24d9b3002c997c05c4c6c66d85d1" alt=""
这是删除整个表
data:image/s3,"s3://crabby-images/a8bbe/a8bbe2a0a6d881b7ea3845165676b67050eb61a2" alt=""
删除数据库
1
| mysql> drop database yanyi;
|
data:image/s3,"s3://crabby-images/ec9be/ec9bee49bbdffc5e95ee75d4d0280538723bdb5b" alt=""
修复表
1
| mysql> repair table discuz.pre_forum_post;
|
data:image/s3,"s3://crabby-images/4b7e0/4b7e0ed5d438a09bce0bdb36e7894e7ce17ab16a" alt=""
以上就是一些常用的 mysql相关操作。还有个知识点,在 shell 的命令下去执行 mysql 的操作
-e 前面的 mysql 指的是库的名字, -e 选项后面双引号括起来的就是 mysql 的命令。
data:image/s3,"s3://crabby-images/70c79/70c7967eba3b9627caffba88d397444b1e3d03cf" alt=""
授权超级用户
1
| grant all privileges on *.* to 'tangnanbing'@'%' identified by '1qaz@WSX' with grant option;
|