MySQL數據導入導出(一)

来源:https://www.cnblogs.com/TianSuoMuLong/archive/2018/05/25/9084912.html
-Advertisement-
Play Games

簡單介紹 MySQL 的 SELECT INTO OUTFILE 和 LOAD DATA LOCAL INFILE ...


今天遇到一個需求,要用自動任務將一張表的數據導入另一張表。具體場景及限制:將資料庫A表A的數據導入到資料庫B表B中(增量數據或全量數據兩種方式)體系1體系2只能分別訪問資料庫A資料庫B。附圖:

實現方式:體系1將表A的數據導出成文件,存入MongoDB,成功後通知體系2,體系2進行數據導入。

重點來啦:在數據導出和數據導入的時候,有幾下幾種方式,此處具體介紹方法三

方法一:mysqldump,但是mysqldump是在操作系統命令行下運行的,並不滿足這種場景

方法二:通過sql進行查詢,再通過io寫成文件。此方式不做評價...ps:各種工具的導入導出就算了,有興趣的自行瞭解

方法三:導出==》SELECT語句 INTO OUTFILE 路徑+目標文件 [option]
    導入==》LOAD DATA LOCAL INFILE 路徑+目標文件 INTO TABLE 表名 [option]

    其中option參數常用的5個選項:
    FIELDS TERMINATED BY '字元串':設置字元串為欄位的分割符,預設值為 \t;
    FIELDS ENCLOSED BY '字元':設置字元串括上欄位的值,預設值為 無任何符號;
    FIELDS OPTIONALLY ENCLOSED BY '字元':設置字元串括上char varchar text等字元型欄位,預設值為 無任何符號;
    LINES STARTING BY '字元串':設置每一行開頭的字元,預設值為 無任何字元;
    FIELDS ESCAPED BY '字元':設置轉義字元,預設值為 \;
    LINES TERMINATED BY '字元串':設置每行結束符,預設值為 \n;

註意:1.導入的時候數據文件要和導入的表的結構相對應(欄位長度、類型、列等等)

   2.導出的文件不是sql,不包含表結構,只是純數據文件,且每一條數據占一行

   3.路徑問題:有時候隨便選擇一個路徑並不能導出數據文件,會報錯
    如:The MySQL server is running with the --secure-file-priv option so it cannot execute this statement
解決方式:
  a)先通過SHOW VARIABLES LIKE '%secure%' 查詢出預設的路徑,使用預設路徑進行導出,執行結果如下圖

  b)修改 mysql 的 my.ini 配置文件中secure_file_priv來進行管理,
    i.不允許MySQL進行導入導出
      # Secure File Priv.
      secure-file-priv = null
    ii.只允許MySQL在指定的目錄下進行導入導出操作
      # Secure File Priv.
      secure-file-priv = /目錄/
    iii.不對MySQL的導入導出進行限制(註釋或刪除secure-file-priv配置)
      # Secure File Priv.
      #secure-file-priv="C:/ProgramData/MySQL/MySQL Server 5.7/Uploads"

 最後附上eg:

SELECT * FROM pub_parameter INTO OUTFILE 'C:\\ProgramData\\MySQL\\MySQL Server 5.7\\Uploads\\test8.sql' 
SELECT * FROM pub_parameter INTO OUTFILE 'C:\\ProgramData\\MySQL\\MySQL Server 5.7\\Uploads\\test5.sql' FIELDS TERMINATED BY '|'              
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、實驗拓撲圖: 二、實驗目標:部署標準交換機和分散式交換機 三、實驗步驟: 標準交換機的配置 1、分別在兩台esxi主機中添加6塊物理網卡,橋接到vmnet1。 通過宿主機連接到sql-vcenter 2、分別在兩台esxi主機配置標準交換機,將vSwitch0交換機添加一個物理網卡,實現負載均衡 ...
  • Mac編譯安裝swfToolsMac編譯安裝swfTools下載源碼解壓源碼安裝依賴項./configure執行配置或者執行如下配置命令:需要註意這裡存在部分代碼錯誤,需要修改解決後執行一、char * 和 int比較導致的錯誤, 需要修為文件二、存在一些變數沒有定義的錯誤三、存在一些方法參數數量錯... ...
  • 前面給大家介紹了很多在Linux安裝軟體的知識,這些軟體往往依賴了很多第三方的工具或者軟體,如果在Linux伺服器有外網的情況,咱們可以通過yum install這樣的命令直接去安裝這些相關的工具或者軟體,比如: 但是我們在平時的項目開發和運維當中,伺服器為了安全是不一定會開放外網的,對於部署在內網 ...
  • 我們知道用linux命令rz/sz可以通過一些終端軟體如secureCRT等在linux伺服器與本地windows之間傳文件。在伺服器上rz一下,在本地windows下就跳出一個視窗,選擇文件後就傳到了伺服器上;而在伺服器上用sz命令sz一個文件,在本地電腦硬碟上就有了這個文件。用起來是很方便,但是 ...
  • ##/proc的意義在linux查看各種狀態,其實質是查看內核中相關進程的數據結構中的項通過工具將其格式化後輸出出來。但是內核的數據是絕對不能隨意查看或更改的,至少不能直接去修改。所以,在linux上出現了偽文件系統/proc,它是內核中各屬性或狀態向外提供訪問和修改的介面。##查看進程信息 pst ...
  • 今天淺談一下三大操作系統(Operation System): Windows , MacOS , Linux。 適合碼農使用的操作系統是:MacOS 和 Linux。 簡答做了一個思維導圖如下(僅供參考) 1.操作系統的作用 通過提供系統調用,控制和管理硬體。(應用軟體 --> 操作系統 系統調用 ...
  • 資料庫操作前的準備 -- 創建資料庫 -- create database python_test_1 charset=utf8; -- 使用資料庫 -- use python_test_1; -- students表 -- create table students( -- id int unsi ...
  • 一直用Navicat來對MySQL資料庫進行操作,今天突然想試試用DOS控制台來操作,特記錄自己第一次使用經歷,若有錯誤之處,還望大佬們指點。 首先打開控制台,win+R鍵,輸入cmd,確定 輸入mysql -uroot -p123456 其中root表示你的用戶名,123456是你的資料庫密碼 若 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...