mysql如何拷貝數據庫(mysql拷貝數據庫文件)

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

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
HLQ3N的頭像HLQ3N
上一篇 2024-10-03 23:08
下一篇 2024-10-03 23:08

相關推薦

  • 如何修改mysql的端口號

    本文將介紹如何修改mysql的端口號,方便開發者根據實際需求配置對應端口號。 一、為什麼需要修改mysql端口號 默認情況下,mysql使用的端口號是3306。在某些情況下,我們需…

    編程 2025-04-29
  • Python 常用數據庫有哪些?

    在Python編程中,數據庫是不可或缺的一部分。隨着互聯網應用的不斷擴大,處理海量數據已成為一種趨勢。Python有許多成熟的數據庫管理系統,接下來我們將從多個方面介紹Python…

    編程 2025-04-29
  • openeuler安裝數據庫方案

    本文將介紹在openeuler操作系統中安裝數據庫的方案,並提供代碼示例。 一、安裝MariaDB 下面介紹如何在openeuler中安裝MariaDB。 1、更新軟件源 sudo…

    編程 2025-04-29
  • Python操作MySQL

    本文將從以下幾個方面對Python操作MySQL進行詳細闡述: 一、連接MySQL數據庫 在使用Python操作MySQL之前,我們需要先連接MySQL數據庫。在Python中,我…

    編程 2025-04-29
  • 數據庫第三範式會有刪除插入異常

    如果沒有正確設計數據庫,第三範式可能導致刪除和插入異常。以下是詳細解釋: 一、什麼是第三範式和範式理論? 範式理論是關係數據庫中的一個規範化過程。第三範式是範式理論中的一種常見形式…

    編程 2025-04-29
  • MySQL遞歸函數的用法

    本文將從多個方面對MySQL遞歸函數的用法做詳細的闡述,包括函數的定義、使用方法、示例及注意事項。 一、遞歸函數的定義 遞歸函數是指在函數內部調用自身的函數。MySQL提供了CRE…

    編程 2025-04-29
  • leveldb和unqlite:兩個高性能的數據庫存儲引擎

    本文將介紹兩款高性能的數據庫存儲引擎:leveldb和unqlite,並從多個方面對它們進行詳細的闡述。 一、leveldb:輕量級的鍵值存儲引擎 1、leveldb概述: lev…

    編程 2025-04-28
  • Python怎麼導入數據庫

    Python是一種高級編程語言。它具有簡單、易讀的語法和廣泛的庫,讓它成為一個靈活和強大的工具。Python的數據庫連接類型可以多種多樣,其中包括MySQL、Oracle、Post…

    編程 2025-04-28
  • MySQL bigint與long的區別

    本文將從數據類型定義、存儲空間、數據範圍、計算效率、應用場景五個方面詳細闡述MySQL bigint與long的區別。 一、數據類型定義 bigint在MySQL中是一種有符號的整…

    編程 2025-04-28
  • MySQL左連接索引不生效問題解決

    在MySQL數據庫中,經常會使用左連接查詢操作,但是左連接查詢中索引不生效的情況也比較常見。本文將從多個方面探討MySQL左連接索引不生效問題,並給出相應的解決方法。 一、索引的作…

    編程 2025-04-28

發表回復

登錄後才能評論