MySQL常用操作

时间:2021-07-24 03:13:53

一、结构类操作

1.1 连接数据库

1.1.1 命令连接数据库

# 基础格式
mysql [OPTIONS] [database_name]

# 常用参数格式
mysql [-h<ip>] [-u<username>] [-p<password>] [-P<port>] [-e<command>] [database_name]

说明:选项及其参数间可以有空格也可以没空格;-p可直接接密码也可以后边要求输入时再输入;密码有$等元字符时要用单引号括起来防止被解析掉;-e后的的命令一般都有空格所以一般都用引号括起来。

 

1.1.2 断开数据库连接

-- 方式一
exit

-- 方式二
quit

 

1.1.3 常用图形界面客户端

Navicat:暂时见到最好用的mysql客户端;原来有免费版本Navicat Lite现在已经不提供了

Workbench:MySQL官方客户端,各方面都还可以;最大的糟点大概是界面有点丑。

HeidiSQL:暂时见到的开源免费还算能用的mysql客户端;最让人难受的是数据库列表和打开后的数据库属两个窗口。

phpMyAdmin:web形式的客户端比较受欢迎,但php写的也有就语言局限性。

 

1.2 库操作

1.2.1 创建数据库

-- 基础用法
create database <database_name>;

-- 指定utf8编码格式
create database <database_name> character set utf8 collate utf8_general_ci;

 

1.2.2 删除数据库

drop database <database_name>;

 

1.2.3 修改数据库

应该来讲,修改数据库我们最希望的是修改数据库名,但mysql并没有提供直接的修改数据库名的操作(现在的修改本质上都是新建一个数据库然后把表导过去),只能改改默认编码之类的。

alter database <database_name> character set = utf8 ;

 

1.2.4 查看现有数据库

-- 查看所有数据库
show databases;

-- 查看当前使用的数据库
select database();

-- 查看数据库创建信息
show create database database_name;

 

1.2.5 使用数据库

use <database_name>;

 

1.3 表操作

1.3.1 创建数据表

-- 基础创建格式
create table table_name(column_1_name_1 column_1_type, column_2_name_2 column_1_type)

-- 创建示例;习惯在每个字段后回车换行
create table if not exists test_table(
    id int unsigned auto_increment,
    username varchar(100) not null,
    password varchar(100) not null,
    primary key(id)
)default charset=utf8;

 

1.3.2 删除数据表

drop table <table_name>;

 

1.3.3 修改数据表

-- 重命令数据表
rename table <old_table_name> to <new_table_name>;

 

1.3.4 查看数据表

show tables [ from database_name ];

 

1.4 字段操作

 1.4.1 增加字段

alter table <table_name> add [column] <column_name> <column_type> [first | after ready_column];

 

1.4.2 删除字段

alter table <table_name> drop [column] <column_name>;

 

1.4.3 修改字段

-- 修改字段名
alter table <table_name> rename column <old_column_name> to <new_column_name>;

-- 修改字段类型
alter table <table_name> modify [column] <column_name> <new_column_type> [first | after ready_column];

-- 同时修改字段名和字段类型
alter table <table_name> change [column] <old_column_name> <new_column_name> <new_column_type> [first | after ready_column];

 

1.4.4 查看字段

show columns from <table_name>;
desc <table_name>;

 

1.5 记录操作

1.5.1 插入记录

insert [into] <table_name> [column_name_1,column_name_2] values (value_10,value_20) [,(value_11,value_21)];

 

1.5.2 删除记录

delete from <table_name> [ where column_name = ‘value‘ ];

 

1.5.3 修改记录

update <table_name> set <column_name> = <value> [ where column_name = "value" ];

 

1.5.4 查看记录

select * from <table_name> [ where column_name = "value" ];

 

二、导入导出数据操作

2.1 导出数据

-- 方法一:使用into outfile导出数据
-- 导出默认格式:文件本件,字段以t分隔,行以n分隔
-- 只指定文件名不具体给出目录时,文件会保存到mysql配置的导出目录下
select * from table_name into outfile "<file_path>";

-- 方法二:使用mysqldump导出数据
-- 导出默认格式:.sql文件
-- 不指定数据库名时默认导出所有数据库
mysqldump -u<username> -p<password> [--databases <database_names>] > <file_path>
mysqldump -u<username> -p<password> [--databases <database_names>] --result-file <file_path>

 

2.2 导入数据

-- 方法一:使用mysql命令导入sql语句(.sql)文件
mysql -u<username> -p<password> < <file_path>

-- 方法二:登录数据库后使用source入sql语句(.sql)文件
-- 当然也可以使用mysql -u<username> -p<password> -e <command>转成shell命令形式
source <file_path>

-- 方法三:登录数据库后使用load data导入.cvs等格式文件
-- 当然也可以使用mysql -u<username> -p<password> -e <command>转成shell命令形式
-- local是指文件在登录mysql的那台机器上
-- 默认.cvs格式,即字段分隔符为,行分隔符为换行符(具体是rn还是n还是r看你系统)
-- 对于数据格式,导入时mysql会尽最大可能将导入的数据转成字段的格式
-- 如果导入的字段值中包含分隔符,此种情况导入前应处理,不然会误导mysql的分隔判断
load data local infile <file_path> into table <table_name>;
-- 自定义字段分隔符和行分隔符
load data local infile <file_path> into table <table_name>[(column_names)] fields terminated by : lines terminated by n;
-- 如果导入的文件中某个字段没有值(或者想让自增长字段自增长),则将该字段留空即可(如,,)
-- 如果导入的文件中某个字段对应的位置是有值的但并不想导入数据库,则在column_names位置使用@column_name形式指示导入时跳过该字段即可

-- 方法四:使用mysqlimport导入.cvs等格式文件
-- mysqlimport从功能上来说只是load data的一个shell命令形式
mysqlimport -u<username> -p<password> --local <database_name> <file_path>
mysqlimport -u<username> -p<password> --local --fields-terminated-by "," --lines-terminated-by "n" <database_name> <file_path>

 

三、权限类操作

3.1 授权

-- create只创建用户,该用户没有任何如增删改查的权限
create user <username>@<ip> [identified by <password>];

-- grant先创建用户,后又可给用户赋权
-- with grant option表示允许该用户将其所拥有的权限,赋给其他人
grant <all|create|drop|alter|show|insert|delete|update|select> on <database_name>.<table_name> to <username|rolename>@<ip> [identified by <password>] [with grant option];
-- 给角色增加权限
grant <all|create|drop|alter|show|insert|delete|update|select> on <database_name>.<table_name> to <rolename>;
-- 给用户增加角色
grant <rolename> to <username>@<ip>;

 

3.2 回收权限

-- 从用户回收权限
revoke <all|create|drop|alter|show|insert|delete|update|select> on <database_name>.<table_name> from <username|rolename>@<ip>;
-- 从角色回收权限
revoke <all|create|drop|alter|show|insert|delete|update|select> on <database_name>.<table_name> from <rolename>;
-- 从用户回收角色
revoke <rolename> from <username>@<ip>;

 

3.3 修改用户密码

-- 查看当前登录用户
select user();
-- 查看所有用户
select user,host from mysql.user;

-- 修改当前用户密码
set password = <password>;
-- 修改指定用户密码
set password for <username>@<ip> = <password>;

-- 修改当前用户密码
alter user user() identified by <password>;
-- 修改指定用户密码
alter user <username>@<ip> identified by <password>;

-- 5.7之前版本
update mysql.user set password=PASSWORD(<password>) where user=<username>;
-- 5.7及之后版本
update mysql.user set authentication_string=PASSWORD(<password>) where user=<username>;

 

四、其他常用操作

-- 查看数据库版本
select version();

-- 查看连接数
show status where variable_name = Threads_connected;
show global status like "Threads_connected";
-- 查看具体连接
show processlist;

-- 查看在本机客户端中执行过的mysql命令
cat ~/.mysql_history

-- 大多变量可在my.cnf文件中配置默认值,但下划线要改成杠
-- mysql配置文件中,既允许不同文件间有相同节区,也允许一个文件有重复的节区,最后汇总去重使用
-- 查看变量
show [global|session] variables [like <pattern>];
-- 设置变量值,但set并不写入文件即重启后失效
set <variable_name> = <value>;
-- 查看支持的编码
show character set [ likt <pattern> ];

-- 服务端使用什么编码存并不那么重要,只要客户端使用正确的编码即可正确显示
-- 将character_set_client, character_set_connection及character_set_results三个变量设为给定编码
set names utf8;

 

参考:

https://dev.mysql.com/doc/refman/8.0/en/insert.html