數(shù)據(jù)庫管理系統(tǒng)(DBMS)之MariaDB
本文簡單介紹一款數(shù)據(jù)庫管理系統(tǒng)(MySQL的兄弟)MariaDB。
如果你有MySQL或其他數(shù)據(jù)的使用經(jīng)驗,MariaDB使用起來將非常輕松。
本文講解Centos7默認的數(shù)據(jù)MariaDB,由于是入門系列文章因此不會深入講解,后面有機會再單獨深入。
一、MariaDB產(chǎn)生背景
數(shù)據(jù)處理是軟件的核心,軟件的本質(zhì)就是處理數(shù)據(jù),包括輸入輸入、處理、輸出。目前數(shù)據(jù)庫主要分為關系型數(shù)據(jù)庫和非關系型數(shù)據(jù),關系型數(shù)據(jù)庫主要有:SQLServer、Oracle、MySQL、MariaDB等;非關系型數(shù)據(jù)庫(NoSQL)包含:Redis、HBase、MongoDB等等。
相信大家都聽過或者用過MySQL數(shù)據(jù)庫,它是一款市場占有率非常高的數(shù)據(jù)庫管理系統(tǒng),技術(shù)成熟、配置步驟相對簡單,而且具有良好的可擴展性。
但是由于Oracle公司在2009年收購了MySQL的母公司Sun,因此MySQL項目也隨之納入了Oracle。被收購后,雖然MySQL仍然保持著開源軟件的身份,但是卻申請了多項商業(yè)專利,這就不禁讓人擔心其會被逐漸商業(yè)化。
一方面,MySQL本身是一款開源軟件,是全球極客、程序員等技術(shù)高手在開源社區(qū)的大旗下的公共智慧結(jié)晶,自己的勞動成果被其他公司商業(yè)化自然也傷了一大批開源工作者的心,因此由MySQL項目創(chuàng)始者重新研發(fā)了一款名為MariaDB的全新數(shù)據(jù)庫管理系統(tǒng)。
另一方面,各大公司都會存在競爭或利益關系,MySQL被收購后,谷歌、維基百科等公司決定將MySQL數(shù)據(jù)庫上的業(yè)務轉(zhuǎn)移到 MariaDB 數(shù)據(jù)庫,紅帽公司也決定在 RHEL 7、CentOS 7 以及最新的 Fedora 系統(tǒng)中,將 MariaDB 作為默認的數(shù)據(jù)庫管理系統(tǒng)。
這樣一樣,MariaDB也因此快速占據(jù)了市場。MariaDB當前由開源社區(qū)進行維護,是MySQL的分支產(chǎn)品,而且?guī)缀跬耆嫒?MySQL,并增加了一些新的特性,例如對微秒級別的 支持、線程池、子查詢優(yōu)化、進程報告等。
支持windows、linux等不同的操作系統(tǒng),本文演示在Centos7下進行安裝。
官網(wǎng):https://mariadb.org/
二、MariaDB安裝
2.1 安裝MariaDB
通過掛載光盤或yum倉庫安裝MariaDB
[root@mariadb ~]# rpm -q mariadbpackage mariadb is not installed[root@mariadb ~]# yum install mariadb mariadb-serverLoaded plugins: fastestmirror, langpacks.。.省略部分內(nèi)容Dependency Updated: mariadb-libs.x86_64 1:5.5.64-1.el7Complete?。踨oot@mariadb ~]# rpm -q mariadbmariadb-5.5.64-1.el7.x86_64[root@mariadb ~]# rpm -q mariadb-servermariadb-server-5.5.64-1.el7.x86_64[root@mariadb ~]# systemctl start mariadb[root@mariadb ~]# systemctl enable mariadbln -s ‘/usr/lib/systemd/system/mariadb.service’ ‘/etc/systemd/system/multi-user.target.wants/mariadb.service’[root@mariadb ~]#
安裝完成后,重啟并設為開機啟動,在正式使用之前先按下邊步驟進行初始化
2.2 初始化MariaDB
為了確保數(shù)據(jù)庫的安全性和正常運轉(zhuǎn),需要通過mysql_secure_installation對數(shù)據(jù)庫程序進行初始化操作。
初始化的工作主要用于設置root的密碼以及刪除一些無關的賬戶信息,根據(jù)提示一路按y即可完成,主要步驟如下圖所示:
[root@mariadb ~]# mysql_secure_installation
注意:上邊設置的root密碼為MariaDB數(shù)據(jù)的root賬戶的密碼,而非Centos系統(tǒng)的root賬戶和密碼。
2.3 測試安裝是否成功
在虛擬機中通過mysql命令登錄,并用show databases命令查看默認有哪些數(shù)據(jù)庫,如果能查看說明安裝成功并能正常連接。
[root@mariadb ~]# mysql -u root -p Enter password: Welcome to the MariaDB monitor. Commands end with ; or g.Your MariaDB connection id is 11Server version: 5.5.64-MariaDB MariaDB ServerCopyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.Type ‘help;’ or ‘h’ for help. Type ‘c’ to clear the current input statement.MariaDB [(none)]》 show databases;+--------------------+| Database |+--------------------+| information_schema || mysql || performance_schema |+--------------------+3 rows in set (0.00 sec)MariaDB [(none)]》 exitBye[root@mariadb ~]#
mysql命令中,-u參數(shù)用來指定以root管理員的身份登錄,而-p參數(shù)用來驗證該用戶在數(shù)據(jù)庫中的密碼值。
注意事項:
(1)MariaDB默認端口為3306,在防火墻中服務名稱為mysql。因此MariaDB和MySQL不要同時使用。
(2)本例中直接禁止了root的遠程登錄,但實際上有可能需要遠程訪問數(shù)據(jù),這可以在上邊的初始化操作中設置允許root管理員遠程訪問;然后在設置防火墻,使其放行對數(shù)據(jù)庫服務的訪問請求。
[root@mariadb ~]# firewall-cmd --permanent --add-service=mysql success [root@mariadb ~]# firewall-cmd --reload success
2.4 修改密碼
通過set密碼可以修改root用戶的密碼,假設密碼修改為888888
MariaDB [(none)]》 set password=password(‘888888’);Query OK, 0 rows affected (0.00 sec)MariaDB [(none)]》 exitBye[root@mariadb ~]# mysql -uroot -pEnter password: 輸入新密碼登錄
修改密碼后,退出再登錄就只能用剛設置的新密碼登錄了。
三、MariaDB賬戶管理
為了保障數(shù)據(jù)庫系統(tǒng)的安全性,以及讓其他用戶協(xié)同管理數(shù)據(jù)庫,生產(chǎn)環(huán)境一般不用root管理員賬戶。一般是以在MariaDB數(shù)據(jù)庫管理系統(tǒng)中創(chuàng)建多個專用的數(shù)據(jù)庫管理賬戶,然后再分配合理的權(quán)限,以滿足工作需求。
3.1 添加賬戶
添加賬戶的語句為:“CREATE USER 用戶名@主機名 IDENTIFIED BY ‘密碼’; ”
MariaDB [(none)]》 create user heima@localhost identified by ‘heima’;Query OK, 0 rows affected (0.00 sec)MariaDB [(none)]》 use mysqlReading table information for completion of table and column namesYou can turn off this feature to get a quicker startup with -ADatabase changedMariaDB [mysql]》 select host,user,password from user where user=‘heima’;+-----------+-------+-------------------------------------------+| host | user | password |+-----------+-------+-------------------------------------------+| localhost | heima | *58613E96F5518C264EA39AA2A57D3DFEB191E343 |+-----------+-------+-------------------------------------------+1 row in set (0.00 sec)MariaDB [mysql]》exit
創(chuàng)建用戶后,存儲在mysql數(shù)據(jù)庫的user表中,可以進行查看。
3.2 賬戶授權(quán)管理
通過上邊的方式創(chuàng)建的heima用戶僅僅是一個普通用戶,沒有數(shù)據(jù)庫的任何操作權(quán)限。
[root@mariadb ~]# mysql -uheima -pheimaWelcome to the MariaDB monitor. Commands end with ; or g.Your MariaDB connection id is 15Server version: 5.5.64-MariaDB MariaDB ServerCopyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.Type ‘help;’ or ‘h’ for help. Type ‘c’ to clear the current input statement.MariaDB [(none)]》 show databases;+--------------------+| Database |+--------------------+| information_schema |+--------------------+1 row in set (0.00 sec)MariaDB [(none)]》 exitBye[root@mariadb ~]#
我們用heima賬戶登錄,通過查詢看不到mysql數(shù)據(jù)庫,說明該用戶連數(shù)據(jù)庫查看的權(quán)限都沒有。
3.2.1 賬號授權(quán)
(1)grant授權(quán)語句
授權(quán)使用grant語句,語法格式為:“grant 權(quán)限 on 數(shù)據(jù)庫。表名稱 to 賬戶名@主機名”。
舉幾個例子:
對某個特定數(shù)據(jù)庫中的特定表單給予授權(quán)
GRANT 權(quán)限ON 數(shù)據(jù)庫。表單名稱TO 賬戶名@主機名
對某個特定數(shù)據(jù)庫中的所有表單給予授權(quán)
GRANT 權(quán)限 ON 數(shù)據(jù)庫.*TO 賬戶名@主機名
對所有數(shù)據(jù)庫及所有表單給予授權(quán)
GRANT 權(quán)限 ON.TO 賬戶名@主機名
對某個數(shù)據(jù)庫中的所有表單給予多個授權(quán)
GRANT 權(quán)限1,權(quán)限2 ON 數(shù)據(jù)庫.*TO 賬戶名@主機 名
對所有數(shù)據(jù)庫及所有表單給予全部授權(quán)
GRANT ALL PRIVILEGES ON .TO 賬戶名@主機
(2)對heima賬戶授權(quán)
用root管理員賬戶登錄,通過grant語句給heima用戶對msyql數(shù)據(jù)庫user表的增刪改查的授權(quán):
MariaDB [(none)]》 show grants for heima@localhost;+------------------------------+| Grants for heima@localhost |+------------------------------+| GRANT USAGE ON *.* TO ‘heima’@‘localhost’ IDENTIFIED BY PASSWORD ‘*58613E96F5518C264EA39AA2A57D3DFEB191E343’ |+------------------------------+1 row in set (0.01 sec)MariaDB [(none)]》 grant select,update,delete,insert on mysql.user to heima@localhost;Query OK, 0 rows affected (0.00 sec)MariaDB [(none)]》 show grants for heima@localhost; +-----------------+| Grants for heima@localhost |+----------------------------+| GRANT USAGE ON *.* TO ‘heima’@‘localhost’ IDENTIFIED BY PASSWORD ‘*58613E96F5518C264EA39AA2A57D3DFEB191E343’ || GRANT SELECT, INSERT, UPDATE, DELETE ON `mysql`。`user` TO ‘heima’@‘localhost’ |+-------------------------------+2 rows in set (0.00 sec)MariaDB [(none)]》
通過show grants命令可以看到對用戶授予了哪些權(quán)限。
授權(quán)完成后,切換到heima用戶,再次查看數(shù)據(jù)庫就可以看到剛才授權(quán)的mysql數(shù)據(jù)庫了,并且可以操作mysql數(shù)據(jù)庫中user表的內(nèi)容
MariaDB [(none)]》 show databases;+--------------------+| Database |+--------------------+| information_schema || mysql |+--------------------+2 rows in set (0.01 sec)MariaDB [(none)]》 use mysql;Reading table information for completion of table and column namesYou can turn off this feature to get a quicker startup with -ADatabase changedMariaDB [mysql]》 show tables;+-----------------+| Tables_in_mysql |+-----------------+| user |+-----------------+1 row in set (0.00 sec)MariaDB [mysql]》 select host,user,password from user where user=‘heima’;+-----------+-------+-------------------------------------------+| host | user | password |+-----------+-------+-------------------------------------------+| localhost | heima | *58613E96F5518C264EA39AA2A57D3DFEB191E343 |+-----------+-------+-------------------------------------------+1 row in set (0.00 sec)MariaDB [mysql]》 exitBye[root@mariadb ~]#
3.2.2 移除賬戶權(quán)限
當員工離職或其他原因需要移除賬戶權(quán)限時,可以使用root管理員登錄,通過revoke語句進行移除
MariaDB [(none)]》 revoke select,update,delete,insert on mysql.user from heima@localhost;Query OK, 0 rows affected (0.00 sec)MariaDB [(none)]》 show grants for heima@localhost;+------------+| Grants for heima@localhost |+------------+| GRANT USAGE ON *.* TO ‘heima’@‘localhost’ IDENTIFIED BY PASSWORD ‘*58613E96F5518C264EA39AA2A57D3DFEB191E343’ |+-------------+1 row in set (0.00 sec)MariaDB [(none)]》 exit
四、MariaDB數(shù)據(jù)庫和表管理
4.0 知識儲備
簡單列舉幾個最基礎的命令
創(chuàng)建數(shù)據(jù)庫
CREATE DATABASE 數(shù)據(jù)庫名稱 (大小寫不敏感,大小寫都是可以的)
描述表
DESCRIBE 表單名稱
更新表單中的數(shù)據(jù)
UPDATE 表單名稱 SET attribute=新值 WHERE attribute》原始 值
指定使用的數(shù)據(jù)庫
USE 數(shù)據(jù)庫名稱
顯示當前已有的數(shù)據(jù)庫
SHOW databases
顯示當前數(shù)據(jù)庫中的表
SHOW tables
從表單中選中某個記錄值
SELECT * FROM 表單名稱
從表單中刪除某個記錄值
DELETE FROM 表單名 WHERE attribute=值
4.1 創(chuàng)建數(shù)據(jù)庫
創(chuàng)建一個名為 heima的數(shù)據(jù)庫
MariaDB [(none)]》 create database heima;Query OK, 1 row affected (0.00 sec)MariaDB [(none)]》 show databases; +--------------------+| Database |+--------------------+| information_schema || heima || mysql || performance_schema |+--------------------+4 rows in set (0.00 sec)MariaDB [(none)]》
4.2 創(chuàng)建數(shù)據(jù)庫表
切換到剛才創(chuàng)建的heima數(shù)據(jù)庫,在其中創(chuàng)建user表,包含姓名和年齡兩個字段
MariaDB [(none)]》 use heimaDatabase changedMariaDB [heima]》 create table user(name char(15),age int);Query OK, 0 rows affected (0.01 sec)MariaDB [heima]》 show tables;+-----------------+| Tables_in_heima |+-----------------+| user |+-----------------+1 row in set (0.00 sec)MariaDB [heima]》 describe user;+-------+----------+------+-----+---------+-------+| Field | Type | Null | Key | Default | Extra |+-------+----------+------+-----+---------+-------+| name | char(15) | YES | | NULL | || age | int(11) | YES | | NULL | |+-------+----------+------+-----+---------+-------+2 rows in set (0.00 sec)MariaDB [heima]》
五、MariaDB表數(shù)據(jù)管理
數(shù)據(jù)庫表中數(shù)據(jù)的查找分為CRUD,也就是通常所說的增、刪、改、查。
5.1 添加數(shù)據(jù)
使用insert into語句向heima數(shù)據(jù)庫的user表中插入數(shù)據(jù)
MariaDB [heima]》 insert into user(name,age) values(‘heima’,18);Query OK, 1 row affected (0.00 sec)MariaDB [heima]》 select * from user; +-------+------+| name | age |+-------+------+| heima | 18 |+-------+------+1 row in set (0.00 sec)MariaDB [heima]》
5.2 查詢數(shù)據(jù)
查詢使用select語句,并可以結(jié)合where、group by、order by等語句進行綜合查詢。
在user表插入一條數(shù)據(jù),然后根據(jù)年齡查詢小于1歲的用戶
MariaDB [heima]》 insert into user(name,age) values(“l(fā)eo”,1);Query OK, 1 row affected (0.00 sec)MariaDB [heima]》 select * from user where age《2;+------+------+| name | age |+------+------+| leo | 1 |+------+------+1 row in set (0.00 sec)MariaDB [heima]》
5.3 修改數(shù)據(jù)
修改數(shù)據(jù)使用update語句,在user表中將heima用戶的年齡修改為19歲
MariaDB [heima]》 update user set age=19 where name=‘heima’;Query OK, 1 row affected (0.00 sec)Rows matched: 1 Changed: 1 Warnings: 0MariaDB [heima]》 select * from user;+-------+------+| name | age |+-------+------+| heima | 19 |+-------+------+1 row in set (0.00 sec)MariaDB [heima]》
5.4 刪除數(shù)據(jù)
刪除數(shù)據(jù)使用delete語句,以下分別演示,刪除用戶名為leo的用戶和刪除所有用戶
MariaDB [heima]》 delete from user where name=‘leo’;Query OK, 1 row affected (0.00 sec)MariaDB [heima]》 select * from user; +-------+------+| name | age |+-------+------+| heima | 19 |+-------+------+1 row in set (0.00 sec)MariaDB [heima]》 delete from user;Query OK, 1 row affected (0.00 sec)MariaDB [heima]》 select * from user;Empty set (0.00 sec)MariaDB [heima]》
六、MariaDB數(shù)據(jù)庫備份及恢復
為了保證數(shù)據(jù)的安全性需要定期備份數(shù)據(jù)庫,一旦出現(xiàn)問題可以通過備份文件進行恢復。
6.1 數(shù)據(jù)庫備份
備份數(shù)據(jù)庫數(shù)據(jù)使用mysqldump命令,格式為“mysqldump [參數(shù)] [數(shù)據(jù)庫名稱]”。參數(shù)與mysql命令基本相同,-u參數(shù)用于定義登錄數(shù)據(jù)庫的賬戶名稱,-p參數(shù)代表密碼提示符。
下面將 之前創(chuàng)建的heima數(shù)據(jù)庫中的內(nèi)容導出成一個文件,并保存到root管理員的家目錄中:
[root@mariadb ~]# mysqldump -u root -p heima》 /root/heima-db-back.dump Enter password: [root@mariadb ~]# ll heima-db-back.dump -rw-r--r--。 1 root root 1794 Feb 13 12:48 heima-db-back.dump[root@mariadb ~]# pwd/root[root@mariadb ~]#
此時模擬數(shù)據(jù)庫故障,直接用root登錄MariaDB數(shù)據(jù),然后刪除整個heima數(shù)據(jù)庫
MariaDB [(none)]》 drop database heima;Query OK, 1 row affected (0.00 sec)MariaDB [(none)]》 show databases;+--------------------+| Database |+--------------------+| information_schema || mysql || performance_schema |+--------------------+3 rows in set (0.00 sec)MariaDB [(none)]》 exitBye[root@mariadb ~]#
6.2 數(shù)據(jù)庫恢復
要恢復數(shù)據(jù)庫,先用root登錄數(shù)據(jù)庫,再次建一個空的heima數(shù)據(jù)庫
MariaDB [(none)]》 create database heima;Query OK, 1 row affected (0.00 sec)MariaDB [(none)]》 show databases;+--------------------+| Database |+--------------------+| information_schema || heima || mysql || performance_schema |+--------------------+4 rows in set (0.00 sec)MariaDB [(none)]》 exitBye[root@mariadb ~]#
然后再用mysq重定向?qū)倐浞莸臄?shù)據(jù)庫文件導入mysql命令即可恢復
[root@mariadb ~]# mysql -uroot -p heima《/root/heima-db-back.dumpEnter password: [root@mariadb ~]# mysql -uroot -p888888.。.省略部分內(nèi)容MariaDB [(none)]》 use heima;Reading table information for completion of table and column namesYou can turn off this feature to get a quicker startup with -ADatabase changedMariaDB [heima]》 show tables;+-----------------+| Tables_in_heima |+-----------------+| user |+-----------------+1 row in set (0.00 sec)MariaDB [heima]》exit
這樣就完成了數(shù)據(jù)表中內(nèi)容的恢復。
-
數(shù)據(jù)庫
+關注
關注
7文章
4020瀏覽量
68365 -
管理系統(tǒng)
+關注
關注
1文章
2922瀏覽量
38583 -
MySQL
+關注
關注
1文章
906瀏覽量
29553
發(fā)布評論請先 登錄
Oracle數(shù)據(jù)庫ASM實例無法掛載的數(shù)據(jù)恢復案例
恒訊科技解析:如何安裝MySQL并創(chuàng)建數(shù)據(jù)庫
數(shù)據(jù)庫數(shù)據(jù)恢復—服務器異常斷電導致Oracle數(shù)據(jù)庫故障的數(shù)據(jù)恢復案例
三款主流國產(chǎn)數(shù)據(jù)庫的技術(shù)特點
企業(yè)級MySQL數(shù)據(jù)庫管理指南
數(shù)據(jù)庫數(shù)據(jù)恢復—MongoDB數(shù)據(jù)庫文件丟失的數(shù)據(jù)恢復案例
數(shù)據(jù)庫數(shù)據(jù)恢復—SQL Server數(shù)據(jù)庫被加密如何恢復數(shù)據(jù)?
oracle數(shù)據(jù)恢復—oracle數(shù)據(jù)庫誤執(zhí)行錯誤truncate命令如何恢復數(shù)據(jù)?
SQLSERVER數(shù)據(jù)庫是什么
MySQL數(shù)據(jù)庫是什么
數(shù)據(jù)庫數(shù)據(jù)恢復——MongoDB數(shù)據(jù)庫文件拷貝后服務無法啟動的數(shù)據(jù)恢復
MariaDB數(shù)據(jù)庫管理系統(tǒng)如何安裝和使用
評論