- 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-hk/n/126564.html