- 1、怎麼快速複製千萬級的Mysql資料庫表
- 2、mysql把一個資料庫中的數據複製到另一個資料庫中的表 2個表結構相同
- 3、如何複製mysql資料庫到另一台電腦上?
- 4、怎麼把mysql一個資料庫從一台機器上 拷貝到另外一台
我google了一下大概有一下幾個方法,
1.複製表結構及數據到新表
CREATE TABLE 新表 SELECT * FROM 舊錶
2.只複製表結構到新表
CREATE TABLE 新表 SELECT * FROM 舊錶 WHERE 1=2
即:讓WHERE條件不成立.
3.複製舊錶的數據到新表(假設兩個表結構一樣)
INSERT INTO 新表 SELECT * FROM 舊錶
4.複製舊錶的數據到新表(假設兩個表結構不一樣)
INSERT INTO 新表(欄位1,欄位2,…….) SELECT 欄位1,欄位2,…… FROM 舊錶
1、使用軟體Navicat就可遷移複製資料庫,打開Navicat,右鍵點擊左邊空白的地方,點擊New Connection下的MySQL,創建一個伺服器的連接,下面將演示把本地的數據遷移到伺服器:
2、在彈出的創建新連接的窗口裡,輸入伺服器的IP,資料庫賬號,密碼等,然後就可以連接資料庫了:
3、創建好後們打開本地的資料庫,點擊「Data Transfer」(數據傳輸),接著彈出新的界面:
4、新窗口中在左邊選擇本地資料庫的庫,和需要轉移的表,可以選擇一個,或多個表:
5、然後在右邊的目標里,選擇伺服器的連接,然後選擇伺服器上的資料庫:
6、選擇完成後,就開始進行數據轉移了,數據量不是很大的,很快就會轉移完成的。以上就是mysql中數據複製到另一個資料庫的方法:
這種架構一般用在以下三類場景
1. 備份多台 Server 的數據到一台如果按照數據切分方向來講,那就是垂直切分。比如圖 2,業務 A、B、C、D 是之前拆分好的業務,現在需要把這些拆分好的業務匯總起來備份,那這種需求也很適用於多源複製架構。實現方法我大概描述下:業務 A、B、C、D 分別位於 4 台 Server,每台 Server 分別有一個資料庫來隔離前端的業務數據,那這樣,在從庫就能把四台業務的數據全部匯總起來,而不需要做額外的操作。那沒有多源複製之前,要實現這類需求,只能在匯總機器上搭建多個 MySQL 實例,那這樣勢必會涉及到跨庫關聯的問題,不但性能急劇下降,管理多個實例也沒有單台來的容易。
2. 用來聚合前端多個 Server 的分片數據。
同樣,按照數據切分方向來講,屬於水平切分。比如圖 3,按照年份拆分好的數據,要做一個匯總數據展現,那這種架構也非常合適。實現方法稍微複雜些:比如所有 Server 共享同一資料庫和表,一般為了開發極端透明,前端配置有分庫分表的中間件,比如愛可生的 DBLE。
3. 匯總併合並多個 Server 的數據
第三類和第一種場景類似。不一樣的是不僅僅是數據需要匯總到目標端,還得合併這些數據,這就比第一種來的相對複雜些。比如圖 4,那這樣的需求,是不是也適合多源複製呢?答案是 YES。那具體怎麼做呢?
1、在B機器上裝mysql。
將A機器上的mysql/data下的你的資料庫目錄整個拷貝下來。
將B機器上的mysql服務停止。
找到B機器上的mysql/data目錄,將你拷貝的目錄粘貼進去,然後啟動mysql服務就可以了。
2、使用SQL語句備份和恢復
你可以使用SELECT
INTO
OUTFILE語句備份數據,並用LOAD
DATA
INFILE語句恢複數據。這種方法只能導出數據的內容,不包括表的結構,如果表的結構文件損壞,你必須要先恢復原來的表的結構。
語法:
SELECT
*
INTO
{OUTFILE
|
DUMPFILE}
』file_name』
FROM
tbl_name
LOAD
DATA
[LOW_PRIORITY]
[LOCAL]
INFILE
』file_name.txt』
[REPLACE
|
IGNORE]
INTO
TABLE
tbl_name
SELECT
…
INTO
OUTFILE
』file_name』
原創文章,作者:HLQ3N,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/126564.html