CSV文件導入導mysql資料庫

来源:https://www.cnblogs.com/yuejucai/archive/2018/08/23/9526015.html
-Advertisement-
Play Games

1.導入 導入實例 說明: 第一行就是導入文件; 第二行參看語法就會發現有兩個詞:replace 和 ignore 。replace和ignore關鍵詞控制對現有的唯一鍵記錄的重覆的處理。如果你指定replace,新行將代替有相同的唯一鍵值的現有行。如果你指定ignore,跳過有唯一鍵的現有行的重覆 ...


1.導入

基本語法:
load data [low_priority] [local] infile 'file_name txt' [replace | ignore]
into table tbl_name
[character set gbk]
[fields
[terminated by't']
[OPTIONALLY] enclosed by '']
[escaped by'\' ]]
[lines terminated by'n']
[ignore number lines]
[(col_name, )]

  導入實例

1 load data infile 'csv文件路徑\\test.csv' 
2 replace into table 表名              
3 fields terminated by ',' 
4 optionally enclosed by '"' 
5 lines terminated by '\r\n' 
6 ignore 1 lines(Id,@name,password);

  說明:

         第一行就是導入文件;

         第二行參看語法就會發現有兩個詞:replaceignorereplaceignore關鍵詞控制對現有的唯一鍵記錄的重覆的處理。如果你指定replace,新行將代替有相同的唯一鍵值的現有行。如果你指定ignore,跳過有唯一鍵的現有行的重覆行的輸入。如果你不指定任何一個選項,當找到重覆鍵時,出現一個錯誤,並且文本文件的餘下部分被忽略。

         第三~四行很簡單就是每個具體欄位內容之間是以逗號隔開的,那就以逗號分開。 erminated by描述欄位的分隔符,預設情況下是tab字元(\t) 。enclosed by描述的是欄位的括起字元,就是說欄位中如果有引號,就當做是欄位的一部分。 語法中還有一個是 escaped by, 它描述的是轉義字元。預設的是反斜杠(backslash:\ )

        第五行 lines terminated by是對每行進行分割,這裡要註意一個問題,如果csv文件是在windows下生成,那分割用 ‘\r\n’,linux下用 ‘\n’。

        第六行中 ignore 1 lines 是忽略第一行,因為第一行往往是欄位名,後邊括弧中有個欄位很特別 @name,它是說如果csv文件中有個欄位我不想插進去,那就把對應欄位名變成@name.

具體操作:

step1.準備CSV文件

      1.在資料庫中建test數據表,表屬性如下:

          2.csv文件的存儲內容如下,命名為test1.csv,存儲位置:“C:/ProgramData/MySQL/MySQL Server 5.7/Uploads/test1.csv”:

 

         驗證.csv編碼格式是否正確,務必保證導入數據的編碼格式是ANSI編碼格式

step2.數據導入:

         1.查詢已有資料庫:show databases;

         2.使用這個資料庫,使用命令:use flight_analysis;

         3.查詢我們之前建立的表格test是否在test資料庫中,使用命令:show tables;

         4.導入資料庫:

          

#導入數據中不包含中文
1
  load data infile 'C:/ProgramData/MySQL/MySQL Server 5.7/Uploads/test1.csv' --CSV文件存放路徑 2 3   into test student--要將數據導入的表名 4 5   fields terminated by ',' optionally enclosed by '"' escaped by '"' 6 7   lines terminated by '\r\n';

 

#導入數據中包含中文

load data infile 'C:/ProgramData/MySQL/MySQL Server 5.7/Uploads/test1.csv' --CSV文件存放路徑 into table test character set gb2312 --要將數據導入的表名 fields terminated by ',' optionally enclosed by '"' escaped by '"' lines terminated by '\r\n';
1 #忽略第一行
2 load data infile "C:/ProgramData/MySQL/MySQL Server 5.7/Uploads/datatest1.csv"
3 into table data_test
4 fields terminated by ',' optionally enclosed by '"' escaped by '"'
5 lines terminated by '\r\n'
6 ignore 1 lines;

 

導出

1 select * from 表名
2 into outfile '導出路徑\\test.csv' 
3 fields terminated by ',' 
4 optionally enclosed by '"' 
5 escaped by '"' 
6 lines terminated by '\n';

 

 

 

         

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • C#/WPF/WinForm/.NET程式代碼實現軟體程式開機自動啟動的兩種常用方法函數的示例與實例帶詳細註釋 方法一:將軟體的快捷方式創建到電腦的自動啟動目錄下(不需要管理員許可權) 1.必要引用 2.代碼實現-只需要調用SetMeAutoStart(bool onOff)方法就可以了,參數onO ...
  • 作者:暴王 個人博客:http://www.boydwang.com/2017/12/net core in memory cache/ 這兩天在看.net core的in memory cache,這裡記錄一下用法,主要涉及MemoryCache的Get/Set/Expire/Flush。 首先我 ...
  • All在項目文件裡面,這一行代表引用包,可是有三個子項目,需要說一下:IncludeAssetsExcludeAssetsPrivateAssets這三個是什麼意思?中文翻譯,Assets是資產,反正無法理解說的是什麼鬼。一開始我以為它可以定製引用庫裡面那個類,搞了好久才發覺這是一個部署選項。可以取... ...
  • 筆者在使用Entity Framework中的Scaffolding機制自動創建拓展名為mdf的資料庫及表單時,遇到如下的錯誤: 首先回顧一下創建這個程式的步驟: 1、創建一個Console控制台應用程式,程式集名稱及命名空間為ConsoleApp; 2、使用程式包控制台管理器將Entity Fra ...
  • vscode是一個簡單的開發工具,啟動快,速度快。但是當前1.26版本對多項目支持好像有點問題。命令行有個dotnet sln,但是只能添加新項目,卻沒有創建解決方案的命令。如果強行添加他會提示沒有解決方案文件,莫名其妙!當然可以添加文件夾的方式,在一個項目中看到另一個項目的文件結構,但是這無法等同... ...
  • 突然想起delegate委托是支持+= 和-=操作的,然後研究一下究竟這個是怎麼做到的,好模仿一下。一開始以為是+=的運算符重載,但是在類庫參考中並沒有這個運算符重載,只有!= 和==運算符重載。有點納悶,最終發現,原來+=這些直接就是語法層面的實現,只是針對delegate才有的福利,所以也不存在... ...
  • 1. 安裝 Homebrew2. brew doctor 確認 brew 在正常工作3. brew update 更新包4. brew install mysql 安裝 MySQL​```==> Downloading https://homebrew.bintray.com/bottles/mys... ...
  • 直方圖是表上某個欄位在按照一定百分比和規律採樣後的數據分佈的一種描述,最重要的作用之一就是根據查詢條件,預估符合條件的數據量,為sql執行計劃的生成提供重要的依據在MySQL 8.0之前的版本中,MySQL僅有一個簡單的統計信息卻沒有直方圖,沒有直方圖的統計信息可以說是沒有任何意義的。MySQL 8 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...