自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

如何將數(shù)據(jù)庫(kù)從MySQL移植MemSQL

數(shù)據(jù)庫(kù) MySQL
因?yàn)镸emSQL完全兼容MySQL,因此將數(shù)據(jù)從MySQL遷移到MemSQL上是非常直接的,你可以使用標(biāo)準(zhǔn)的MySQL工具來(lái)遷移。

本例子假設(shè)你的MySQL和MemSQL都跑在同一臺(tái)機(jī)器上,MySQL 在3306 端口,而MemSQL在 3307端口,同時(shí)假設(shè)二者都可以通過(guò)root賬號(hào)無(wú)需密碼訪問(wèn)。

[[79943]]

使用mysqldump工具移植

mysqldump是MySQL客戶端最常用的數(shù)據(jù)備份工具之一,它會(huì)生成一些列創(chuàng)建表和插入數(shù)據(jù)的SQL語(yǔ)句,因此用來(lái)恢復(fù)一個(gè)數(shù)據(jù)庫(kù)是最方便的。

當(dāng)你確定要將數(shù)據(jù)遷移到MemSQL之前,有幾個(gè)注意事項(xiàng):

大多數(shù)MySQL存儲(chǔ)引擎都是使用 B-tree 來(lái)存儲(chǔ)索引的,而 MemSQL 是使用單向無(wú)鎖的 skip 列表或者無(wú)鎖的哈希表。選擇正確的索引數(shù)據(jù)結(jié)構(gòu)對(duì)應(yīng)用程序的性能會(huì)有顯著的提升。其中哈希表主要適合 key-value 的查找,而 skip 列表特別適合用于復(fù)雜范圍的掃描和排序(ORDER BY)。因此在進(jìn)行遷移之前,你得重新審視你得表定義并確定是否能使用 MemSQL 專有的優(yōu)化。默認(rèn)的 BTREE 符號(hào)將被轉(zhuǎn)成升序的 skip 列表。如果你需要對(duì)某個(gè)列做雙向的范圍掃描,你可以考慮同時(shí)增加升序和降序的索引,更多 MemSQL 的索引信息請(qǐng)看 indexes 

因?yàn)?nbsp;code generation 的緣故,  MemSQL ***加載數(shù)據(jù)庫(kù)結(jié)構(gòu)的速度要比 MySQL 慢,因?yàn)?MemSQL ***加載表結(jié)構(gòu)時(shí),會(huì)生成并編譯代碼來(lái)實(shí)現(xiàn)這個(gè)表的架構(gòu),包括內(nèi)存分配、插入、刪除和迭代方法等等。一旦表被編譯完成,MemSQL 將在整個(gè)運(yùn)行期間直接使用編譯好的代碼。而 mysqldump 生成的 INSERT 語(yǔ)句也將特別編譯一次。

mysqldump 會(huì)生成一些 MemSQL 不支持的 SQL 語(yǔ)句,例如不支持 UNIQUE_CHECKS,為了更好的支持 mysqldump,MemSQL 對(duì)這些不支持的語(yǔ)句只是予以警告,可通過(guò)調(diào)整warn_level 變量來(lái)控制錯(cuò)誤的級(jí)別,詳情請(qǐng)看 Unsupported Features . 某些 CREATE TABLE 語(yǔ)句可能被完全阻止執(zhí)行,如果你遇見(jiàn)這種問(wèn)題,只能手工去修改表的定義SQL。

如果你運(yùn)行 MemSQL 的機(jī)器沒(méi)有足夠的內(nèi)存來(lái)加載數(shù)據(jù),服務(wù)器將會(huì)對(duì) INSERT 語(yǔ)句執(zhí)行報(bào) out-of-memory 的錯(cuò)誤信息,這種情況你只能安裝更多的內(nèi)存。如果你將已有的 memsqlbin 目錄復(fù)制到新的機(jī)器上,那么MemSQL 會(huì)繼續(xù)沿用已編譯的表定義和 INSERT 語(yǔ)句。如果你使用的是 MemSQL 開(kāi)發(fā)版,而且超過(guò)了10G 的限制,那你可以參考 memsql.com/next 來(lái)了解如何升級(jí)。

建議你將數(shù)據(jù)庫(kù)結(jié)構(gòu)定義和數(shù)據(jù)分開(kāi)獨(dú)立文件存放,這樣就可以在需要的時(shí)候來(lái)調(diào)整表結(jié)構(gòu),你可以使用下面命令來(lái)分別導(dǎo)出數(shù)據(jù)庫(kù)結(jié)構(gòu)和數(shù)據(jù)文件:

  1. $ mysqldump -h 127.0.0.1 -u root -B [database name] --no-data > schema.sql$ mysqldump -h 127.0.0.1 -u root -B [database name] --no-create-info > data.sql 

然后通過(guò)下面方法導(dǎo)入:

$ mysql -h 127.0.0.1 -u root -P 3307 < schema.sql$ mysql -h 127.0.0.1 -u root -P 3307 < data.sql

運(yùn)行這些步驟時(shí),你可以觀察 memsql_tracelog (同時(shí)也輸出到 stderr)  來(lái)查看執(zhí)行過(guò)程中被忽略的不被支持的特性。一旦導(dǎo)入完成后,你可以連接到 MemSQL 并查詢結(jié)果。

轉(zhuǎn)換你的應(yīng)用程序

讓?xiě)?yīng)用程序支持 MemSQL 非常簡(jiǎn)單,只需要改連接配置即可。

注意

如果你要連接到本機(jī)的 MemSQL 應(yīng)該使用 127.0.0.1 而不是 localhost,多數(shù) MySQL 客戶端可將 localhost 解析并使用 MySQL 的 socket 文件進(jìn)行連接而忽略端口設(shè)置,詳情請(qǐng)看 this page

一旦你開(kāi)始運(yùn)行程序,可監(jiān)控 memsql_tracelog. 一些不支持的SQL語(yǔ)法會(huì)在這里顯示。更多 MemSQL 的 SQL Statement

原文連接:http://www.linuxeden.com/html/database/20120619/126001.html

【編輯推薦】

  1. SQL數(shù)據(jù)庫(kù)之?dāng)?shù)據(jù)類型BOOL/BOOLEAN與TINYINT測(cè)試總結(jié)
  2. MySQL服務(wù)端編碼設(shè)置
  3. MySQL源碼學(xué)習(xí):MDL字典鎖
  4. MySQL Cluster開(kāi)發(fā)環(huán)境簡(jiǎn)明部署
  5. MySQL的四種不同查詢的分析

責(zé)任編輯:彭凡 來(lái)源: Linuxeden
相關(guān)推薦

2016-12-29 12:24:33

MySQL數(shù)據(jù)庫(kù)移植

2021-01-28 09:00:00

SQL數(shù)據(jù)庫(kù)NoSQL

2011-04-26 13:17:36

AS3MySQL

2011-07-28 18:08:51

SQL Server MySQL

2023-06-07 09:00:00

JavaScript開(kāi)發(fā)TypeScript

2011-05-04 09:29:22

2018-10-15 13:57:38

Hadoop數(shù)據(jù)庫(kù)MySQL

2010-09-30 11:04:47

DB2數(shù)據(jù)庫(kù)卸載

2019-03-20 09:00:00

MySQL數(shù)據(jù)庫(kù)轉(zhuǎn)移數(shù)據(jù)庫(kù)

2011-04-08 10:16:13

文本文件ACCESS數(shù)據(jù)庫(kù)

2017-07-12 09:20:42

SQLite數(shù)據(jù)庫(kù)移植

2011-04-08 10:43:08

mysql數(shù)據(jù)access數(shù)據(jù)庫(kù)

2010-05-13 09:59:50

MySQL數(shù)據(jù)庫(kù)

2010-05-19 17:35:35

2009-10-10 13:54:20

OPhone

2009-01-06 11:31:34

SybaseSQL Server數(shù)據(jù)庫(kù)

2011-03-23 09:54:47

數(shù)據(jù)模型數(shù)據(jù)庫(kù)設(shè)計(jì)

2017-06-28 08:14:57

數(shù)據(jù)庫(kù)區(qū)塊鏈比特幣

2011-07-28 15:53:06

SQL Server數(shù)合并查詢

2011-05-12 13:48:07

MySql數(shù)據(jù)庫(kù)本地移植
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)