Mysql命令行操作

标签: Mysql 分类: 数据库 创建时间:2020-03-16 05:06:32 更新时间:2025-01-17 10:39:22

有时候习惯了使用navicat或者dbeaver这种界面操作数据库,偶尔使用命令行的方式,可能还是有些不顺手的,权且写一篇文章记录一下。

1.基本操作

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
## 连接数据库
mysql -u root -p
##
mysql -u root -P 3307 -h 101.200.152.192 -p

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

## 创建数据库
create database db_yves;

## 使用数据库
use db_yves;

## 显示数据库中的表
show tables;

## 删除数据库
drop database db_yves;

## 显示
SELECT user FROM mysql.user;

2.命令行导入导出

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
## 导出数据库db_yves的结构和数据
mysqldump -h localhost -u root -p db_yves > D:\db_yves.sql

## 导出数据库db_yves的结构(加-d参数):
mysqldump -h localhost -u root -p db_yves -d > D:\db_yves_stru.sql

## 导出数据库db_yves中的customers表的结构和数据:
mysqldump -h localhost -u root -p db_yves customers > D:\customers.sql

## 导出数据库db_yves中的customers表的结构(加-d参数):
mysqldump -h localhost -u root -p db_yves -d > D:\customers_stru.sql

## 向数据库db_yves导入数据库文件db_yves.sql.
mysql -h localhost -u root -p db_yves < D:\db_yves.sql

## 使用source命令执行sql文件
mysql> source sql文件

3.创建用户并授权

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
## 创建用户,如果是任意位置,则 host 为 %
CREATE USER 'username'@'host' IDENTIFIED BY 'password';

## 传统密码测试
CREATE USER 'username'@'host' IDENTIFIED WITH mysql_native_password BY 'password';

## 授予权限
GRANT privileges[权限列表] ON databasename.tablename TO username;

## 授予全部权限
GRANT ALL ON *.* TO user;

## 例
GRANT ALL ON phkj.* TO 'phkj'@'localhost';

GRANT ALL ON phkj.* TO user;

## mysql8.0,其中*.*第一个*表示所有数据库,第二个*表示所有数据表,如果不想授权全部那就把对应的*写成相应数据库或者数据表;username为指定的用户;%为该用户登录的域名
grant all privileges on *.* to 'username'@'%' with grant option;

## 刷新权限
flush privileges;

## 查看所有用户
select * from mysql.user;

## 删除用户
Delete FROM mysql.user Where User='test' and Host='localhost';

## 修改用户的host属性
UPDATE mysql.user SET Host='%' WHERE Host='localhost' AND User='username';
FLUSH PRIVILEGES;

## 查看某个用户的权限
show grants for 'xxx'@'%';
## or
select * from mysql.user where user='root' \G;
参考文章:
1.MySQL 创建用户并授权
2.MySQL命令行创建用户与授权
3.Mysql创建、删除用户
4.mysql创建远程访问用户
5.【Mysql】MySQL修改用户host的方法整理
6.修改MySQL用户的host属性 这个 update user set host = ‘%’ where user = ‘root’; 没有用,报错:No database selected。
7.更改MySQL用户的主机权限 这个比较有用,就是把上面的user表,改为mysql.user表
8.MySQL 查看用户授予的权限
9.mysql如何查看用户及其权限 查看mysql数据库中的所有用户、查看某个用户的权限、查看当前用户
10.mysql8.0数据库添加用户和授权

4.远程连接

(1) windows上通过控制面板->卸载程序->打开或关闭windows功能->Telent Client,打开widows的telent功能。(Linux找相应的方法)

(2) 测试端口

1
telnet 192.168.1.211 3306

(3) 关闭防火墙

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
## 查看防火墙状态
firewall-cmd --state

## 停止防火墙
systemctl stop firewalld.service

## 禁止开机启动
systemctl disable firewalld.service

## 关闭selinux (有则改之,无责加免)

## 查看状态
sestatus

## 临时关闭
setenforce 0

## 永久关闭
vi /etc/selinux/config

将SELINUX=enforcing改为SELINUX=disabled

(4) 修改端口

1
2
3
4
5
6
# 编辑配置文件
vi /etc/my.cnf
# 增加
bind-address=0.0.0.0
# 重启mysql
systemctl restart mysqld

(5) 检查用户访问权限

1
2
3
4
5
6
7
8
9
10
11
## 登录
mysql -u root -p
## 连接数据库
mysql> use mysql;
## 修改用户登录地址
musql> update user set host='%' where user='phkj';
## 刷新权限
flush privileges;

## 重启mysql(看情况)
/etc/init.d/mysql restart

5.修改普通用户密码

尝试了好多中方法,很多都不能用,总是提示语法错误。正确的这三种,每一次只能使用一种,然后调用权限刷新,然后才能使用下一种

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
## 错误,总是提示语法错误。
update user set password=password('passwd') where user='jack';
GRANT USAFE ON . TO ‘username’@’localhost’ IDENTIFIED BY [PASSWORD] ‘new_password’;

## 正确
## 第一种
update mysql.user set authentication_string=password('123qwe') where user='root' and Host = 'localhost';

## 第二种
alter user 'root'@'localhost' identified by '123';

## 第三种
set password for 'root'@'localhost'=password('123');

## 注意刷新权限
flush privileges;

6.设置时间默认值

1
2
3
4
5
6
7
8
9
10
11
-- 创建表时设置
create table table_name{
id int,
create_time DATETIME DEEFAULT CURRENT_TIMESTAMP
};

--- 修改时间默认值
alter table tablename modify create_time DATETIME default CURRENT_TIMESTAMP;

---- 修改时间戳默认值
alter table tablename modify create_time bigint default (UNIX_TIMESTAMP(now()));
参考文章:
【1】.mysql 设置数值型时间变量默认值为当前时间(for the right syntax to use near ‘unix_timestamp(now())‘) 这里是设置了bigint
【2】.mysql datetime字段默认值 这里是两种方法,一直在创建表的时候设置,一种是在后期修改。
小额赞助
本人提供免费与付费咨询服务,感谢您的支持!赞助请发邮件通知,方便公布您的善意!
**光 3.01 元
Sun 3.00 元
bibichuan 3.00 元
微信公众号
广告位
诚心邀请广大金主爸爸洽谈合作
每日一省
isNaN 和 Number.isNaN 函数的区别?

1.函数 isNaN 接收参数后,会尝试将这个参数转换为数值,任何不能被转换为数值的的值都会返回 true,因此非数字值传入也会返回 true ,会影响 NaN 的判断。

2.函数 Number.isNaN 会首先判断传入参数是否为数字,如果是数字再继续判断是否为 NaN ,不会进行数据类型的转换,这种方法对于 NaN 的判断更为准确。

每日二省
为什么0.1+0.2 ! == 0.3,如何让其相等?

一个直接的解决方法就是设置一个误差范围,通常称为“机器精度”。对JavaScript来说,这个值通常为2-52,在ES6中,提供了Number.EPSILON属性,而它的值就是2-52,只要判断0.1+0.2-0.3是否小于Number.EPSILON,如果小于,就可以判断为0.1+0.2 ===0.3。

每日三省
== 操作符的强制类型转换规则?

1.首先会判断两者类型是否**相同,**相同的话就比较两者的大小。

2.类型不相同的话,就会进行类型转换。

3.会先判断是否在对比 null 和 undefined,是的话就会返回 true。

4.判断两者类型是否为 string 和 number,是的话就会将字符串转换为 number。

5.判断其中一方是否为 boolean,是的话就会把 boolean 转为 number 再进行判断。

6.判断其中一方是否为 object 且另一方为 string、number 或者 symbol,是的话就会把 object 转为原始类型再进行判断。

每日英语
Happiness is time precipitation, smile is the lonely sad.
幸福是年华的沉淀,微笑是寂寞的悲伤。