Mysql数据库应用与常见问题
一、安装mysql
1、CentOS系统
1.)安装mysql
下载并安装mysql的repo源
1
2
$
$ sudo rpm -ivh mysql-community-release-el7-5.noarch.rpm
安装mysql
1
$ sudo yum install -y mysql-server
2.)启动/重启/关闭服务
1
service mysqld start | restart | stop
2、alpine系统
alpine系统中安装mysql实际是开源的MariaDB,MariaDB数据库是MySQL的一个分支/衍生版,完全兼容MySQL,并在扩展功能、存储引擎以及一些新的功能改进方面都强过MySQL,安装参考
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
$ apk update
# 安装数据库及客户端
$ apk add mysql mysql-client
# 初始化数据库
$ mysql_install_db --user=mysql --datadir=/var/lib/mysql
# 启动服务
$ rc-service mariadb start # 若没有rc,安装:apk add openrc
# 修改密码
$ mysqladmin -u root password '新root密码'
# 加入开机启动
$ rc-update add mariadb default
二、操作mysql
1、登录数据库
默认初始化直接登录
1
$ mysql
若提示失败,说明有密码,运行:
1
2
3
4
$ mysql -uroot -p
# 一次性登录
$ mysql -u用户 -p密码
2、操作数据库
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
38
39
40
41
42
# 查看所有数据库
mysql> show databases;
# 创建数据库
mysql> create database xxx charset=utf8;
# 删除数据库
mysql> drop database xxx;
# 切换数据库
mysql> use mysql;
# 查看表
mysql> show tables;
# 创建表
mysql> create table xxx (
id int,
name varchar(20),
update_time datetime
);
# 删除表
mysql> drop table xxx;
# 显示表结构
mysql> desc xxx;
# 查询指定a,b字段的记录,不知道用*代替
mysql> select a,b form xxx;
# 插入记录
mysql> insert into xxx(id,user) values(1,'wang',now());
# 删除记录
mysql> delete from xxx where name='wang';
# 清屏命令
mysql> system clear;
# 退出
mysql> quit;
3、用户管理
mysql的user表用来存储所有用户权限,其中host字段表示指定ip用户能使用,同名不同host的为两个用户,host常见值如下:
localhost:只能服务器端上使用
192.168.4.%:指定ip段能用
%:通配符,表示所有ip用户都能用,多用于远程连接
下面新建/删除用户操作时,可通过user@'host'指定,若不指定默认为%
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
# 切换到mysql权限数据库
mysql> use mysql;
# 查看用户及所属的host
mysql> select user,host from user;
# 新建用户并设置密码
mysql> create user '用户名' identified by '密码';
# 上面不指定host,默认%,等同于:
mysql> create user '用户名'@'%' identified by '密码';
# 删除用户(只删除host为%的用户)
mysql> drop user '用户名';
# 查看用户权限
mysql> show grants for '用户名';
# 设置权限,并指定数据库
mysql> grant all privileges on xxxDB.* to '用户名';
# 修改密码,注意密码处不能直接password='新密码'
mysql> update user set password=password('新密码') where user='用户名';
# 刷新权限表
mysql> flush privileges;
4、批量操作
1.)sql脚本批量执行
1
$ mysql -uroot -p -Dxxx < ./init.sql # xxx为数据库
2.)备份/恢复数据库
1
2
$ mysqldump --all-databases -h127.0.0.1 -u root -p > ./backup/mysql-bak.sql
$ mysqldump --all-databases -h127.0.0.1 -u root -p < ./backup/mysql-bak.sql
三、常见问题
1、root密码忘记怎么擦除?
1
2
3
4
5
$ mysql –skip-grant-table &
mysql> use mysql;
mysql> update user set password=password('新密码') where user='root';
mysql> flush privileges;
mysql> quit;
这里需要注意的是每句命令需要用分号“;”结尾,执行完以上得操作,root的密码就被清空。
2、空用户错误
ERROR 1044 (42000): Access denied for user ''@'localhost' to database 'mysql'错误:
原因:
mysql数据库的user表里,存在用户名为空的账户即匿名账户,导致登录的时候虽然用的是root,但实际是匿名登录的。
处理方案:
1
2
3
4
5
6
7
8
9
10
11
# 1.关闭mysql
$ service mysqld stop
# 2.屏蔽权限
$ mysqld_safe --skip-grant-table # 屏幕出现: Starting demo from .....
# 3.新开起一个终端输入
$ mysql -uroot mysql
mysql> update user set password=password('新密码') where user='root';
mysql> flush privileges;
mysql> quit;
3、服务上root能用,远程不能登录
1
2
3
4
5
6
7
8
$ mysql -uroot -p
mysql> use mysql;
# 先查看user表host字段,有无通配符'%',若有直接运行flush privileges;
mysql> select host from user where user='root';
mysql> grant all privileges *.* to 'root'@'%' identified by 'root密码';
mysql> flush privileges;
mysql> quit;
4、远程连接提示caching_sha2_password错误
从mysql5.7版本之后,默认采用了caching_sha2_password验证方式
1
2
mysql> use mysql;
mysql> alter user 'root'@'%' identified with mysql_native_password by 'root密码';
5、mysql修改默认数据存放
1
2
3
4
5
6
7
8
9
10
11
$ mysqladmin -u root -p variables | grep datadir # 查看mysql数据库存放目录
$ service mysqld stop
$ mv /var/lib/mysql /路径 # 移动数据库文件
$ vi /etc/my.cnf
# 修改datadir和socket两个字段,并添加以下:
[mysql]
socket=/路径/mysql.sock
$ service mysqld start
凡注有"环球传媒网"或电头为"环球传媒网"的稿件,均为环球传媒网独家版权所有,未经许可不得转载或镜像;授权转载必须注明来源为"环球传媒网",并保留"环球传媒网"的电头。
- 韩式炸鸡多少钱一份 韩国的炸鸡一般多少钱2022-06-15
- 为什么有时候月亮特别大 凌晨四点看到超级2022-06-15
- 北京工体哪个夜店最嗨 三里屯酒吧消费怎么2022-06-15
- 每日热门:热力学第一第二定律是什么?能量2022-06-15
- 每日速读!古船女人和井(篱笆女人狗、辘轳2022-06-15
- 每日讯息!欧美经典摇滚歌曲有哪些?摇滚歌曲2022-06-15
- 每日关注!岗位调动申请书范文 简单的工作2022-06-15
- 【聚看点】岁月如水:岁月如水,醉美流年2022-06-15
- 观焦点:建行密码丢失如何找回?建行手机银2022-06-15
- 观速讯丨怎么安装摄像头?自己安装监控详细2022-06-15
- 今日热搜:德川家康家训是什么?一起看看《2022-06-15
- 今日快讯:皮鞋怎么保养?皮鞋保养的小技巧2022-06-15
- 观察:coat翻译中文是什么意思?coat外套2022-06-15
- 观天下!我国有哪些神话故事?60个中国古代2022-06-15
- 丈夫死了妻子用还钱么 丈夫欠款死亡妻子该2022-06-15
- 美国黄石公园火山喷发 美国黄石国家公园2022-06-15
- 每日看点!含硒第一名的水果是什么?硒含量最2022-06-15
- 看热讯:曾经心痛dj有没有?曾经心痛dj舞曲2022-06-15
- 信息:犀利哥现状怎么样?犀利哥最帅最霸气2022-06-15
- 动态:自己的神话(自己创造一个神话故事)2022-06-15
- 今日热讯:flv电影在哪里可以下载?下载app2022-06-15
- 儿童封口贴能纠正张嘴睡觉吗 孩子张嘴睡觉2022-06-15
- 星海:一站式跨境浏览,探索全球!2022-06-15
- 【海淘狂欢节】鱼GO全球大促季!这些海淘优2022-06-15
- 招商银行存款有风险吗 中国银行非指定账户2022-06-15
- 为什么法官都喜欢调解 实名举报法官有用吗2022-06-15
- 今年全球最高温度可达到多少度 高温低温怎2022-06-15
- 喉咙不痛但又有异物感 咽喉有异物感是怎2022-06-15
- 献血对身体有害吗 献血屋献血流程2022-06-15
- 今日热门!刘彻和卫子夫的关系? 刘彻一生最2022-06-15