Mysql數據庫應用與常見問題

1、安裝mysql

一、CentOS系統

1.)安裝mysqlmysql

下載並安裝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.)啓動/重啓/關閉服務linux

service mysqld start | restart | stop

二、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

2、操做mysql

一、登陸數據庫

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

# 一次性登陸
$ mysql -u用戶 -p密碼

二、操做數據庫

# 查看全部數據庫
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;

三、用戶管理

mysql的user表用來存儲全部用戶權限,其中host字段表示指定ip用戶能使用,同名不一樣host的爲兩個用戶,host常見值以下:sql

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;

四、批量操做

1.)sql腳本批量執行bash

$ 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

3、常見問題

一、root密碼忘記怎麼擦除?

$ mysql –skip-grant-table &
  mysql> use mysql;
  mysql> update user set password=password('新密碼') where user='root';
  mysql> flush privileges;
  mysql> quit;
這裏須要注意的是每句命令須要用分號「;」結尾,執行完以上得操做,root的密碼就被清空。

二、空用戶錯誤

ERROR 1044 (42000): Access denied for user ''@'localhost' to database 'mysql'錯誤:socket

緣由:ide

mysql數據庫的user表裏,存在用戶名爲空的帳戶即匿名帳戶,致使登陸的時候雖然用的是root,但實際是匿名登陸的。

處理方案:ui

# 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;

三、服務上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;

四、遠程鏈接提示caching_sha2_password錯誤

從mysql5.7版本以後,默認採用了caching_sha2_password驗證方式
mysql> use mysql;
mysql> alter user 'root'@'%' identified with mysql_native_password by 'root密碼';

五、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
相關文章
相關標籤/搜索