在MySQL 5.1中,采用二進(jìn)制格式保存DECIMAL列的值,將9個(gè)十進(jìn)制數(shù)字打包在4字節(jié)中。對于每個(gè)值的整數(shù)部分和小數(shù)部分,其存儲要求是分別確定的。每9個(gè)數(shù)字需要4字節(jié),任何剩余的數(shù)字將占用4字節(jié)的一部分。例如,DECIMAL(18,9)列在小數(shù)點(diǎn)的每一側(cè)均有9位數(shù)字,因此,整數(shù)部分和小數(shù)部分均需要4字節(jié)。DECIMAL(20,10)列在小數(shù)點(diǎn)的每一側(cè)均有10位數(shù)字。對于每一部分,9位數(shù)字需要4字節(jié),剩余的1位數(shù)字需要1字節(jié)。
創(chuàng)新互聯(lián)公司長期為成百上千家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為恩平企業(yè)提供專業(yè)的成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、成都外貿(mào)網(wǎng)站建設(shè)公司,恩平網(wǎng)站改版等技術(shù)服務(wù)。擁有十余年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。
通常情況下,應(yīng)將值設(shè)為 1,并將所有SQL結(jié)點(diǎn)設(shè)為 0,以MGM服務(wù)器作為決策程序。可取下述值之一:
0:該結(jié)點(diǎn)永遠(yuǎn)不用作決策。
1:該結(jié)點(diǎn)具有高優(yōu)先級。
2:該結(jié)點(diǎn)具有低有限級。
本來 MariaDB 的描繪初衷之一即是徹底兼容 MySQL,包含 API 和客戶端協(xié)議,使之能輕松變成 MySQL 的代替品,所以由 MySQL 搬遷到
MariaDB 基本上能夠稱之為“晉級”,就如同軟件晉級版別一樣。MariaDB 的技能文檔上是這樣寫的:
若是是一樣的根底版別(如
5.5),能夠直接卸載 MySQL 然后裝置
MariaDB,這樣就能夠用了。乃至不需求備份然后復(fù)原數(shù)據(jù)庫。當(dāng)然,穩(wěn)妥起見,晉級前將一切的數(shù)據(jù)庫都備份一下仍是十分有必要的,以防萬一。
若是
MariaDB 的主版別高,在通過上面的卸載 MySQL 再裝置 MariaDB 操作之后,需求運(yùn)用 mysql_upgrade
晉級一下。是的,乃至連命令行都與運(yùn)用 MySQL 的時(shí)分一樣。
一切原先的客戶端和連接器(PHP、Perl、Python、Java
等)都不需求做任何改動就能正常作業(yè),由于 MariaDB 與 MySQL 運(yùn)用的是一樣的客戶端協(xié)議,而且客戶端庫文件也是二進(jìn)制兼容的。
上面用 *
來匹配刪去一切 mysql 數(shù)據(jù)包(包含因包依靠而刪去的別的包,如 postfix)。由于直接裝置的時(shí)分會呈現(xiàn)抵觸,例如:
file
/usr/share/mysql/ukrainian/errmsg.sys from install of
MariaDB-server-5.5.31-1.i686 conflicts with file from package
mysql-libs-5.5.32-1.el6.remi.i686
嗯,如同由于將 php-mysql 也給刪去了(實(shí)際上這個(gè)不應(yīng)刪去的),所以
phpMyAdmin 也由于依靠聯(lián)系而被刪去了,我沒仔細(xì)看。
所以最佳不要用通配符 *,而是選擇性刪去幾個(gè)首要的,
# yum remove
mysql mysql-server mysql-libs
可是這個(gè)我沒有再測驗(yàn),由于后邊有非常好的辦法。
C. 然后裝置 MARIADB 及相應(yīng)
PHP 拓展。
也是指定幾個(gè)首要的裝置包,剩余的讓 yum 自個(gè)進(jìn)行依靠聯(lián)系查看。
# yum install
MariaDB-server MariaDB-client php-mysql
或許不裝置 MariaDB-server
而改為具有同步多主群集特性(synchronous multi-master cluster)的 MariaDB Galera Cluster:
# yum install MariaDB-Galera-server MariaDB-client galera
這里對比搞笑的是,沒注意前面把
php-mysql 給卸載了,成果運(yùn)轉(zhuǎn)數(shù)據(jù)庫之后拜訪 WordPress,成果遭受下面的過錯(cuò):
Your PHP installation appears
to be missing the MySQL extension which is required by WordPress.
D.
完結(jié),修補(bǔ)
不論版別是不是晉級了,履行一下數(shù)據(jù)庫晉級指令總沒有害處:
# mysql_upgrade -p
看看數(shù)據(jù)庫版別是不是晉級了:
# mysql -u root -p -e 'show global variables like
"version";'
Enter password:
+---------------+----------------+
| Variable_name | Value |
+---------------+----------------+
| version | 5.5.31-MariaDB |
+---------------+----------------+
將 MariaDB 參加隨體系自發(fā)動列表,
# chkconfig --levels 345 mysql on
嗯,曾經(jīng)
MySQL 的時(shí)分是 mysqld,現(xiàn)在是 mysql,就差了一個(gè)字母 d。
發(fā)動它,
# service mysql start
這個(gè)時(shí)分服務(wù)器上的網(wǎng)站大概現(xiàn)已能夠正常作業(yè)了,拜訪數(shù)據(jù)庫沒有疑問。
若是有必要,裝置完 MariaDB 之后能夠重新裝置 postfix。若是發(fā)現(xiàn)
phpMyAdmin 提示無拜訪權(quán)限了,那即是被卸載了,需求重新裝置和裝備 phpMyAdmin。
別的,由于之前進(jìn)行了卸載操作,所以本來的 MySQL
和 phpMyAdmin 的裝備文件都被清除了,也需求重新裝備。特別是 MySQL 的裝備文件 /etc/my.cnf,由于 MariaDB
盡管創(chuàng)建了一個(gè)my.cnf.d 文件夾來存儲自個(gè)的裝備文件,可是它會首要加載 my.cnf,且本來 MySQL 的裝備的 [mysqld]
那一節(jié)的內(nèi)容仍是有用的。
3. 較好的晉級辦法
仍是在上面介紹的體系裝備下,先增加 MariaDB 裝置源,然后直接履行體系晉級,
# yum
update --skip-broken
MariaDB 有關(guān)裝置包會被裝置,不需求的 MySQL
包將被卸載,而且晉級之后不需求對體系進(jìn)行修補(bǔ)了??纯摧敵龅那懊嬉徊糠郑?/p>
mysql在APP商店寫用戶評價(jià)功能。根據(jù)查詢相關(guān)信息顯示,APP商店里可以評價(jià)一款A(yù)PP,評論功能是用戶表達(dá)對某一主題的想法的很好的一種方式,優(yōu)秀的評論系統(tǒng)能很好地提高社區(qū)的活躍度,各大主流網(wǎng)站也都提供了相應(yīng)的評論支持。
PostgreSQL的主要優(yōu)點(diǎn):
1、對事務(wù)的支持與MySQL相比,經(jīng)歷了更為徹底的測試。對于一個(gè)嚴(yán)肅的商業(yè)應(yīng)用來說,事務(wù)的支持是不可或缺的。
2、MySQL對于無事務(wù)的MyISAM表。采用表鎖定,一個(gè)長時(shí)間運(yùn)行的查詢很可能會長時(shí)間地阻礙對表的更新。而PostgreSQL不存在這樣的問題。
3、PostgreSQL支持存儲過程,而目前MySQL不支持,對于一個(gè)嚴(yán)肅的商業(yè)應(yīng)用來說,作為數(shù)據(jù)庫本身,有眾多的商業(yè)邏輯的存在,此時(shí)使用存儲過程可以在較少地增加數(shù)據(jù)庫服務(wù)器的負(fù)擔(dān)的前提下,對這樣的商業(yè)邏輯進(jìn)行封裝,并可以利用數(shù)據(jù)庫服務(wù)器本身的內(nèi)在機(jī)制對存儲過程的執(zhí)行進(jìn)行優(yōu)化。此外存儲過程的存在也避免了在網(wǎng)絡(luò)上大量的原始的SQL語句的傳輸,這樣的優(yōu)勢是顯而易見的。
4、對視圖的支持,視圖的存在同樣可以最大限度地利用數(shù)據(jù)庫服務(wù)器內(nèi)在的優(yōu)化機(jī)制。而且對于視圖權(quán)限的合理使用,事實(shí)上可以提供行級別的權(quán)限,這是MySQL的權(quán)限系統(tǒng)所無法實(shí)現(xiàn)的。
5、對觸發(fā)器的支持,觸發(fā)器的存在不可避免的會影響數(shù)據(jù)庫運(yùn)行的效率,但是與此同時(shí),觸發(fā)器的存在也有利于對商業(yè)邏輯的封裝,可以減少應(yīng)用程序中對同一商業(yè)邏輯的重復(fù)控制。合理地使用觸發(fā)器也有利于保證數(shù)據(jù)的完整性。
6、對約束的支持。約束的作用更多地表現(xiàn)在對數(shù)據(jù)完整性的保證上,合理地使用約束,也可以減少編程的工作量。