因為 MemSQL 完全兼容 MySQL,因此將數據從 MySQL 遷移到 MemSQL 上是非常直接的,你可以使用標準的 MySQL 工具來遷移。
本例子假設你的 MySQL 和 MemSQL 都跑在同一台機器上,MySQL 在 3306 埠,而 MemSQL 在 3307 埠,同時假設二者都可以通過 root 賬號無需密碼訪問。
mysqldump 是 MySQL 客戶端最常用的數據備份工具之一,它會生成一些列創建表和插入數據的SQL語句,因此用來恢復一個資料庫是最方便的。
當你確定要將數據遷移到 MemSQL 之前,有幾個注意事項:
建議你將資料庫結構定義和數據分開獨立文件存放,這樣就可以在需要的時候來調整表結構,你可以使用下面命令來分別導出資料庫結構和數據文件:
$ 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
然後通過下面方法導入:
$ mysql -h 127.0.0.1 -u root -P 3307 < schema.sql$ mysql -h 127.0.0.1 -u root -P 3307 < data.sql
運行這些步驟時,你可以觀察 memsql_tracelog (同時也輸出到 stderr) 來查看執行過程中被忽略的不被支持的特性。一旦導入完成後,你可以連接到 MemSQL 並查詢結果。
讓應用程序支持 MemSQL 非常簡單,只需要改連接配置即可。
注意
如果你要連接到本機的 MemSQL 應該使用 127.0.0.1 而不是 localhost,多數 MySQL 客戶端可將 localhost 解析並使用 MySQL 的 socket 文件進行連接而忽略埠設置,詳情請看 this page
一旦你開始運行程序,可監控 memsql_tracelog. 一些不支持的SQL語法會在這裡顯示。更多 MemSQL 的 SQL Statements
[火星人 ] 將資料庫從 MySQL 移植到 MemSQL已經有931次圍觀