數(shù)據(jù)庫(kù)管理系統(tǒng)(DBMS)之MariaDB
本文簡(jiǎn)單介紹一款數(shù)據(jù)庫(kù)管理系統(tǒng)(MySQL的兄弟)MariaDB。
如果你有MySQL或其他數(shù)據(jù)的使用經(jīng)驗(yàn),MariaDB使用起來將非常輕松。
本文講解Centos7默認(rèn)的數(shù)據(jù)MariaDB,由于是入門系列文章因此不會(huì)深入講解,后面有機(jī)會(huì)再單獨(dú)深入。
一、MariaDB產(chǎn)生背景
數(shù)據(jù)處理是軟件的核心,軟件的本質(zhì)就是處理數(shù)據(jù),包括輸入輸入、處理、輸出。目前數(shù)據(jù)庫(kù)主要分為關(guān)系型數(shù)據(jù)庫(kù)和非關(guān)系型數(shù)據(jù),關(guān)系型數(shù)據(jù)庫(kù)主要有:SQLServer、Oracle、MySQL、MariaDB等;非關(guān)系型數(shù)據(jù)庫(kù)(NoSQL)包含:Redis、HBase、MongoDB等等。
相信大家都聽過或者用過MySQL數(shù)據(jù)庫(kù),它是一款市場(chǎng)占有率非常高的數(shù)據(jù)庫(kù)管理系統(tǒng),技術(shù)成熟、配置步驟相對(duì)簡(jiǎn)單,而且具有良好的可擴(kuò)展性。
但是由于Oracle公司在2009年收購(gòu)了MySQL的母公司Sun,因此MySQL項(xiàng)目也隨之納入了Oracle。被收購(gòu)后,雖然MySQL仍然保持著開源軟件的身份,但是卻申請(qǐng)了多項(xiàng)商業(yè)專利,這就不禁讓人擔(dān)心其會(huì)被逐漸商業(yè)化。
一方面,MySQL本身是一款開源軟件,是全球極客、程序員等技術(shù)高手在開源社區(qū)的大旗下的公共智慧結(jié)晶,自己的勞動(dòng)成果被其他公司商業(yè)化自然也傷了一大批開源工作者的心,因此由MySQL項(xiàng)目創(chuàng)始者重新研發(fā)了一款名為MariaDB的全新數(shù)據(jù)庫(kù)管理系統(tǒng)。
另一方面,各大公司都會(huì)存在競(jìng)爭(zhēng)或利益關(guān)系,MySQL被收購(gòu)后,谷歌、維基百科等公司決定將MySQL數(shù)據(jù)庫(kù)上的業(yè)務(wù)轉(zhuǎn)移到 MariaDB 數(shù)據(jù)庫(kù),紅帽公司也決定在 RHEL 7、CentOS 7 以及最新的 Fedora 系統(tǒng)中,將 MariaDB 作為默認(rèn)的數(shù)據(jù)庫(kù)管理系統(tǒng)。
這樣一樣,MariaDB也因此快速占據(jù)了市場(chǎng)。MariaDB當(dāng)前由開源社區(qū)進(jìn)行維護(hù),是MySQL的分支產(chǎn)品,而且?guī)缀跬耆嫒?MySQL,并增加了一些新的特性,例如對(duì)微秒級(jí)別的 支持、線程池、子查詢優(yōu)化、進(jìn)程報(bào)告等。
支持windows、linux等不同的操作系統(tǒng),本文演示在Centos7下進(jìn)行安裝。
官網(wǎng):https://mariadb.org/
二、MariaDB安裝
2.1 安裝MariaDB
通過掛載光盤或yum倉(cāng)庫(kù)安裝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 ~]#
安裝完成后,重啟并設(shè)為開機(jī)啟動(dòng),在正式使用之前先按下邊步驟進(jìn)行初始化
2.2 初始化MariaDB
為了確保數(shù)據(jù)庫(kù)的安全性和正常運(yùn)轉(zhuǎn),需要通過mysql_secure_installation對(duì)數(shù)據(jù)庫(kù)程序進(jìn)行初始化操作。
初始化的工作主要用于設(shè)置root的密碼以及刪除一些無關(guān)的賬戶信息,根據(jù)提示一路按y即可完成,主要步驟如下圖所示:
[root@mariadb ~]# mysql_secure_installation
注意:上邊設(shè)置的root密碼為MariaDB數(shù)據(jù)的root賬戶的密碼,而非Centos系統(tǒng)的root賬戶和密碼。
2.3 測(cè)試安裝是否成功
在虛擬機(jī)中通過mysql命令登錄,并用show databases命令查看默認(rèn)有哪些數(shù)據(jù)庫(kù),如果能查看說明安裝成功并能正常連接。
[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ù)用來驗(yàn)證該用戶在數(shù)據(jù)庫(kù)中的密碼值。
注意事項(xiàng):
(1)MariaDB默認(rèn)端口為3306,在防火墻中服務(wù)名稱為mysql。因此MariaDB和MySQL不要同時(shí)使用。
(2)本例中直接禁止了root的遠(yuǎn)程登錄,但實(shí)際上有可能需要遠(yuǎn)程訪問數(shù)據(jù),這可以在上邊的初始化操作中設(shè)置允許root管理員遠(yuǎn)程訪問;然后在設(shè)置防火墻,使其放行對(duì)數(shù)據(jù)庫(kù)服務(wù)的訪問請(qǐng)求。
[root@mariadb ~]# firewall-cmd --permanent --add-service=mysql success [root@mariadb ~]# firewall-cmd --reload success
2.4 修改密碼
通過set密碼可以修改root用戶的密碼,假設(shè)密碼修改為888888
MariaDB [(none)]》 set password=password(‘888888’);Query OK, 0 rows affected (0.00 sec)MariaDB [(none)]》 exitBye[root@mariadb ~]# mysql -uroot -pEnter password: 輸入新密碼登錄
修改密碼后,退出再登錄就只能用剛設(shè)置的新密碼登錄了。
三、MariaDB賬戶管理
為了保障數(shù)據(jù)庫(kù)系統(tǒng)的安全性,以及讓其他用戶協(xié)同管理數(shù)據(jù)庫(kù),生產(chǎn)環(huán)境一般不用root管理員賬戶。一般是以在MariaDB數(shù)據(jù)庫(kù)管理系統(tǒng)中創(chuàng)建多個(gè)專用的數(shù)據(jù)庫(kù)管理賬戶,然后再分配合理的權(quán)限,以滿足工作需求。
3.1 添加賬戶
添加賬戶的語(yǔ)句為:“CREATE USER 用戶名@主機(jī)名 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)建用戶后,存儲(chǔ)在mysql數(shù)據(jù)庫(kù)的user表中,可以進(jìn)行查看。
3.2 賬戶授權(quán)管理
通過上邊的方式創(chuàng)建的heima用戶僅僅是一個(gè)普通用戶,沒有數(shù)據(jù)庫(kù)的任何操作權(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ù)庫(kù),說明該用戶連數(shù)據(jù)庫(kù)查看的權(quán)限都沒有。
3.2.1 賬號(hào)授權(quán)
(1)grant授權(quán)語(yǔ)句
授權(quán)使用grant語(yǔ)句,語(yǔ)法格式為:“grant 權(quán)限 on 數(shù)據(jù)庫(kù)。表名稱 to 賬戶名@主機(jī)名”。
舉幾個(gè)例子:
對(duì)某個(gè)特定數(shù)據(jù)庫(kù)中的特定表單給予授權(quán)
GRANT 權(quán)限ON 數(shù)據(jù)庫(kù)。表單名稱TO 賬戶名@主機(jī)名
對(duì)某個(gè)特定數(shù)據(jù)庫(kù)中的所有表單給予授權(quán)
GRANT 權(quán)限 ON 數(shù)據(jù)庫(kù).*TO 賬戶名@主機(jī)名
對(duì)所有數(shù)據(jù)庫(kù)及所有表單給予授權(quán)
GRANT 權(quán)限 ON.TO 賬戶名@主機(jī)名
對(duì)某個(gè)數(shù)據(jù)庫(kù)中的所有表單給予多個(gè)授權(quán)
GRANT 權(quán)限1,權(quán)限2 ON 數(shù)據(jù)庫(kù).*TO 賬戶名@主機(jī) 名
對(duì)所有數(shù)據(jù)庫(kù)及所有表單給予全部授權(quán)
GRANT ALL PRIVILEGES ON .TO 賬戶名@主機(jī)
(2)對(duì)heima賬戶授權(quán)
用root管理員賬戶登錄,通過grant語(yǔ)句給heima用戶對(duì)msyql數(shù)據(jù)庫(kù)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命令可以看到對(duì)用戶授予了哪些權(quán)限。
授權(quán)完成后,切換到heima用戶,再次查看數(shù)據(jù)庫(kù)就可以看到剛才授權(quán)的mysql數(shù)據(jù)庫(kù)了,并且可以操作mysql數(shù)據(jù)庫(kù)中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)限
當(dāng)員工離職或其他原因需要移除賬戶權(quán)限時(shí),可以使用root管理員登錄,通過revoke語(yǔ)句進(jìn)行移除
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ù)庫(kù)和表管理
4.0 知識(shí)儲(chǔ)備
簡(jiǎn)單列舉幾個(gè)最基礎(chǔ)的命令
創(chuàng)建數(shù)據(jù)庫(kù)
CREATE DATABASE 數(shù)據(jù)庫(kù)名稱 (大小寫不敏感,大小寫都是可以的)
描述表
DESCRIBE 表單名稱
更新表單中的數(shù)據(jù)
UPDATE 表單名稱 SET attribute=新值 WHERE attribute》原始 值
指定使用的數(shù)據(jù)庫(kù)
USE 數(shù)據(jù)庫(kù)名稱
顯示當(dāng)前已有的數(shù)據(jù)庫(kù)
SHOW databases
顯示當(dāng)前數(shù)據(jù)庫(kù)中的表
SHOW tables
從表單中選中某個(gè)記錄值
SELECT * FROM 表單名稱
從表單中刪除某個(gè)記錄值
DELETE FROM 表單名 WHERE attribute=值
4.1 創(chuàng)建數(shù)據(jù)庫(kù)
創(chuàng)建一個(gè)名為 heima的數(shù)據(jù)庫(kù)
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ù)庫(kù)表
切換到剛才創(chuàng)建的heima數(shù)據(jù)庫(kù),在其中創(chuàng)建user表,包含姓名和年齡兩個(gè)字段
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ù)庫(kù)表中數(shù)據(jù)的查找分為CRUD,也就是通常所說的增、刪、改、查。
5.1 添加數(shù)據(jù)
使用insert into語(yǔ)句向heima數(shù)據(jù)庫(kù)的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語(yǔ)句,并可以結(jié)合where、group by、order by等語(yǔ)句進(jìn)行綜合查詢。
在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語(yǔ)句,在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語(yǔ)句,以下分別演示,刪除用戶名為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ù)庫(kù)備份及恢復(fù)
為了保證數(shù)據(jù)的安全性需要定期備份數(shù)據(jù)庫(kù),一旦出現(xiàn)問題可以通過備份文件進(jìn)行恢復(fù)。
6.1 數(shù)據(jù)庫(kù)備份
備份數(shù)據(jù)庫(kù)數(shù)據(jù)使用mysqldump命令,格式為“mysqldump [參數(shù)] [數(shù)據(jù)庫(kù)名稱]”。參數(shù)與mysql命令基本相同,-u參數(shù)用于定義登錄數(shù)據(jù)庫(kù)的賬戶名稱,-p參數(shù)代表密碼提示符。
下面將 之前創(chuàng)建的heima數(shù)據(jù)庫(kù)中的內(nèi)容導(dǎo)出成一個(gè)文件,并保存到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í)模擬數(shù)據(jù)庫(kù)故障,直接用root登錄MariaDB數(shù)據(jù),然后刪除整個(gè)heima數(shù)據(jù)庫(kù)
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ù)庫(kù)恢復(fù)
要恢復(fù)數(shù)據(jù)庫(kù),先用root登錄數(shù)據(jù)庫(kù),再次建一個(gè)空的heima數(shù)據(jù)庫(kù)
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ù)庫(kù)文件導(dǎo)入mysql命令即可恢復(fù)
[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)容的恢復(fù)。
-
數(shù)據(jù)庫(kù)
+關(guān)注
關(guān)注
7文章
3905瀏覽量
65884 -
管理系統(tǒng)
+關(guān)注
關(guān)注
1文章
2752瀏覽量
36853 -
MySQL
+關(guān)注
關(guān)注
1文章
849瀏覽量
27672
發(fā)布評(píng)論請(qǐng)先 登錄
MySQL數(shù)據(jù)庫(kù)是什么
數(shù)據(jù)庫(kù)數(shù)據(jù)恢復(fù)——MongoDB數(shù)據(jù)庫(kù)文件拷貝后服務(wù)無法啟動(dòng)的數(shù)據(jù)恢復(fù)

適用于MySQL和MariaDB的Python連接器:可靠的MySQL數(shù)據(jù)連接器和數(shù)據(jù)庫(kù)

Devart: dbForge Edge——您的終極多元數(shù)據(jù)庫(kù)解決方案

MySQL數(shù)據(jù)庫(kù)的安裝

云數(shù)據(jù)庫(kù)是哪種數(shù)據(jù)庫(kù)類型?
如何使用cmp進(jìn)行數(shù)據(jù)庫(kù)管理的技巧
數(shù)據(jù)庫(kù)事件觸發(fā)的設(shè)置和應(yīng)用
數(shù)據(jù)庫(kù)數(shù)據(jù)恢復(fù)—通過拼接數(shù)據(jù)庫(kù)碎片恢復(fù)SQLserver數(shù)據(jù)庫(kù)

企業(yè)級(jí)數(shù)據(jù)庫(kù)的配置和管理要求匯總
數(shù)據(jù)庫(kù)數(shù)據(jù)恢復(fù)—SQL Server數(shù)據(jù)庫(kù)出現(xiàn)823錯(cuò)誤的數(shù)據(jù)恢復(fù)案例

評(píng)論