首頁  >  文章  >  資料庫  >  一文總結Mysql資料庫應用及常見問題

一文總結Mysql資料庫應用及常見問題

藏色散人
藏色散人轉載
2022-01-07 15:14:262574瀏覽

一、安裝mysql

1、CentOS系統

1.)安裝mysql

#下載並安裝mysql的repo來源
$ wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm
$ sudo rpm -ivh mysql-community-release-el7-5.noarch.rpm
安裝mysql
$ sudo yum install -y mysql-server

2.)啟動/重新啟動/關閉服務

service mysqld start | restart | stop

2、alpine系統

alpine系統中安裝mysql實際上是開源的MariaDB,MariaDB資料庫是MySQL的一個分支/衍生版,完全相容MySQL,並在擴充功能、儲存引擎以及一些新的功能改進方面都強過MySQL,安裝參考
$ 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、登入資料庫

預設初始化直接登入
$ mysql
若提示失敗,說明有密碼,運行:
$ mysql -uroot -p

# 一次性登录
$ mysql -u用户 -p密码

2、操作資料庫

# 查看所有数据库
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'指定,若不指定預設為%

# 切换到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腳本批次執行

$ mysql -uroot -p -Dxxx < ./init.sql    # xxx为数据库

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密碼忘記怎麼擦除?

$ 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.关闭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能用,遠端無法登入

$ 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驗證方式
mysql> use mysql;
mysql> alter user 'root'@'%' identified with mysql_native_password by 'root密码';

5、mysql修改預設資料存放

$ 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

推薦學習:《mysql影片教學

#

以上是一文總結Mysql資料庫應用及常見問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:segmentfault.com。如有侵權,請聯絡admin@php.cn刪除