MySQL load語句詳細(xì)介紹
load的語法
LOAD DATA [LOW_PRIORITY | CONCURRENT] [LOCAL] INFILE 'file_name.txt'
[REPLACE | IGNORE]
INTO TABLE tbl_name
[FIELDS
[TERMINATED BY 'string']
[[OPTIONALLY] ENCLOSED BY 'char']
[ESCAPED BY 'char' ]
]
[LINES
[STARTING BY 'string']
[TERMINATED BY 'string']
]
[IGNORE number LINES]
[(col_name_or_user_var,...)]
[SET col_name = expr,...)]
LOAD DATA INFILE語句用于高速地從一個(gè)文本文件中讀取行,并裝入一個(gè)表中。文件名稱必須為一個(gè)文字字符串。
由character_set_database系統(tǒng)變量指示的字符集被用于解釋文件中的信息。SET NAMES和character_set_client的設(shè)置不會(huì)影響對(duì)輸入的解釋。
典型的示例
LOAD DATA LOCAL INFILE 'data.txt' INTO TABLE tbl_name
FIELDS TERMINATED BY ','
OPTIONALLY ENCLOSED BY '"'
LINES TERMINATED BY '\n'
如果您只想載入一個(gè)表的部分列,則應(yīng)指定一個(gè)列清單:
LOAD DATA LOCAL INFILE 'persondata.txt' INTO TABLE persondata (col1,col2);
文件的路徑
如果指定了LOCAL,則被認(rèn)為與連接的客戶端有關(guān):
1.如果指定了LOCAL,則文件會(huì)被客戶主機(jī)上的客戶端讀取,并被發(fā)送到服務(wù)器。文件會(huì)被給予一個(gè)完整的路徑名稱,以指定確切的位置。如果給定的是一個(gè)相對(duì)的路徑名稱,則此名稱會(huì)被理解為相對(duì)于啟動(dòng)客戶端時(shí)所在的目錄。
2.如果LOCAL沒有被指定,則文件必須位于服務(wù)器主機(jī)上,并且被服務(wù)器直接讀取。
當(dāng)在服務(wù)器主機(jī)上為文件定位時(shí),服務(wù)器使用以下規(guī)則:
1).如果給定了一個(gè)絕對(duì)的路徑名稱,則服務(wù)器使用此路徑名稱。
2).如果給定了帶有一個(gè)或多個(gè)引導(dǎo)組件的相對(duì)路徑名稱,則服務(wù)器會(huì)搜索相對(duì)于服務(wù)器數(shù)據(jù)目錄的文件。
3).如果給定了一個(gè)不帶引導(dǎo)組件的文件名稱,則服務(wù)器會(huì)在默認(rèn)數(shù)據(jù)庫的數(shù)據(jù)庫目錄中尋找文件。
注意,這些規(guī)則意味著名為./myfile.txt的文件會(huì)從服務(wù)器數(shù)據(jù)目錄中被讀取,而名為myfile.txt的同樣的文件會(huì)從默認(rèn)數(shù)據(jù)庫的數(shù)據(jù)庫目錄中讀取。
從客戶端使用絕對(duì)路徑load數(shù)據(jù)
LOAD DATA LOCAL INFILE '/import/data.txt' INTO TABLE db2.my_table;
從服務(wù)器里使用相對(duì)路徑load數(shù)據(jù)
下面的LOAD DATA語句會(huì)從db1數(shù)據(jù)庫目錄中讀取文件data.txt,因?yàn)閐b1是當(dāng)前數(shù)據(jù)庫。即使語句明確把文件載入到db2數(shù)據(jù)庫中的表里,也會(huì)從db1目錄中讀取。
USE db1;
LOAD DATA INFILE 'data.txt' INTO TABLE db2.my_table;
IGNORE number LINES選項(xiàng)
IGNORE number LINES選項(xiàng)可以被用于在文件的開始處忽略行。
您可以使用IGNORE 1 LINES來跳過一個(gè)包含列名稱的起始標(biāo)題行:
LOAD DATA INFILE '/tmp/test.txt' INTO TABLE test IGNORE 1 LINES;
REPLACE和IGNORE
有些輸入記錄把原有的記錄復(fù)制到唯一關(guān)鍵字值上。REPLACE和IGNORE關(guān)鍵字用于控制這些輸入記錄的操作。
如果您指定了REPLACE,則輸入行會(huì)替換原有行(換句話說,與原有行一樣,對(duì)一個(gè)主索引或唯一索引具有相同值的行)。
如果您指定IGNORE,則把原有行復(fù)制到唯一關(guān)鍵字值的輸入行被跳過。
如果您這兩個(gè)選項(xiàng)都不指定,則運(yùn)行情況根據(jù)LOCAL關(guān)鍵詞是否被指定而定。不使用LOCAL時(shí),當(dāng)出現(xiàn)重復(fù)關(guān)鍵字值時(shí),會(huì)發(fā)生錯(cuò)誤,并且剩下的文本文件被忽略。使用LOCAL時(shí),默認(rèn)的運(yùn)行情況和IGNORE被指定時(shí)的情況相同;這是因?yàn)樵谶\(yùn)行中間,服務(wù)器沒有辦法中止文件的傳輸
索引的影響
如果您對(duì)一個(gè)空的MyISAM表使用LOAD DATA INFILE,則所有的非唯一索引會(huì)被創(chuàng)建在一個(gè)獨(dú)立批中(對(duì)于REPAIR TABLE)。當(dāng)您有許多索引時(shí),這通常會(huì)使LOAD DATA INFILE大大加快。通常,LOAD DATA INFILE的速度會(huì)非??欤窃谀承O端情況下,您可以在把文件載入到表中之前使用ALTER TABLE...DISABLE KEYS關(guān)閉LOAD DATA INFILE,或者在載入文件之后使用ALTER TABLE...ENABLE KEYS再次創(chuàng)建索引,使創(chuàng)建索引的速度更快。
FIELDS和LINES的默認(rèn)值
如果您不指定FIELDS子句,則默認(rèn)值為假設(shè)您寫下如下語句時(shí)的值:
FIELDS TERMINATED BY '\t' ENCLOSED BY '' ESCAPED BY '\\'
如果您不指定LINES子句,則默認(rèn)值為假設(shè)您寫下如下語句時(shí)的值:
LINES TERMINATED BY '\n' STARTING BY ''
換句話說,當(dāng)讀取輸入值時(shí),默認(rèn)值會(huì)使LOAD DATA INFILE按如下方式運(yùn)行:
在新行處尋找行的邊界。
不會(huì)跳過任何行前綴。
在制表符處把行分解為字段。
不希望字段被包含在任何引號(hào)字符之中。
出現(xiàn)制表符、新行、或在‘\'前有‘\'時(shí),理解為作為字段值一部分的文字字符。
相反的,當(dāng)編寫輸出值時(shí),默認(rèn)值會(huì)使SELECT...INTO OUTFILE按如下方式運(yùn)行:
在字段之間寫入制表符。
不把字段包含在任何引號(hào)字符中。
當(dāng)字段值中出現(xiàn)制表符、新行或‘\'時(shí),使用‘\'進(jìn)行轉(zhuǎn)義。
在行的末端寫入新行。
注意,要寫入FIELDS ESCAPED BY ‘\\',您必須為待讀取的值指定兩個(gè)反斜杠,作為一個(gè)單反斜杠使用。
備注:如果您已經(jīng)在Windows系統(tǒng)中生成了文本文件,您可能必須使用LINES TERMINATED BY ‘\r\n'來正確地讀取文件,因?yàn)閃indows程序通常使用兩個(gè)字符作為一個(gè)行終止符。部分程序,當(dāng)編寫文件時(shí),可能會(huì)使用\r作為行終止符。要讀取這樣的文件,應(yīng)使用LINES TERMINATED BY ‘\r'。
STARTING LINES選項(xiàng)
如果所有您希望讀入的行都含有一個(gè)您希望忽略的共用前綴,則您可以使用'prefix_string'來跳過前綴(和前綴前的字符)。如果某行不包括前綴,則整個(gè)行被跳過。注釋:prefix_string會(huì)出現(xiàn)在一行的中間。
以下面的test.txt為文件源
xxx"row",1
something xxx"row",2
使用以下sql導(dǎo)入數(shù)據(jù)
LOAD DATA INFILE '/tmp/test.txt' INTO TABLE test LINES STARTING BY "xxx";
最后并只得到數(shù)據(jù)("row",1)和("row",2)。
TERMINATED LINES選項(xiàng)
如果jokes被由%%組成的行分隔,要讀取包含jokes的文件,您可以這么操作:
LOAD DATA INFILE '/tmp/jokes.txt' INTO TABLE jokes FIELDS TERMINATED BY '' LINES TERMINATED BY '\n%%\n' (joke);
TERMINATED,ENCLOSED,ESCAPED FIELD選項(xiàng)
TERMINATED用于控制字段的分隔符,可以為多個(gè)字符。
ENCLOSED BY用于用于控制字段的引號(hào),必須為單一字符,如果您忽略了詞語OPTIONALLY,則所有的字段都被包含在ENCLOSED BY字符串中,如果您指定了OPTINALLY,則ENCLOSED BY字符只被用于包含具有字符串?dāng)?shù)據(jù)類型(比如CHAR, BINARY, TEXT或ENUM)的列中的值.
SELECT...INTO OUTFILE導(dǎo)出數(shù)據(jù),ENCLOSED BY '"',忽略O(shè)PTIONALLY
"1","a string","100.20"
SELECT...INTO OUTFILE導(dǎo)出數(shù)據(jù),ENCLOSED BY '"',指定OPTIONALLY
1,"a string",100.20
ESCAPED BY用于轉(zhuǎn)義,F(xiàn)IELDS ESCAPED BY值必須為單一字符。
如果FIELDS ESCAPED BY字符為空字符,則沒有字符被轉(zhuǎn)義,并且NULL被作為NULL輸出,而不是\N。去指定一個(gè)空的轉(zhuǎn)義符不是一個(gè)好辦法,特別是如果數(shù)據(jù)的字段值包含任何剛給定的清單中的字符時(shí),更不能這么做。
如果在字段值內(nèi)出現(xiàn)ENCLOSED BY字符,則通過使用ESCAPED BY字符作為前綴,對(duì)ENCLOSED BY字符進(jìn)行轉(zhuǎn)義。
- MySQL中使用load data命令實(shí)現(xiàn)數(shù)據(jù)導(dǎo)入的方法
- mysql中的load命令使用方法
- mysql中Load Data記錄換行問題的解決方法
- mysql load data infile 的用法(40w數(shù)據(jù) 用了3-5秒導(dǎo)進(jìn)mysql)
- mysql中的Load data的使用方法
- PHP Warning: PHP Startup: Unable to load dynamic library \ D:/php5/ext/php_mysqli.dll\
- mysql LOAD語句批量錄入數(shù)據(jù)
- mysql 的load data infile
- mysql Load Data InFile 的用法
- mysql出現(xiàn)Error performing load command的解決方法
相關(guān)文章
關(guān)于mysql數(shù)據(jù)庫格式化簡單介紹
本文將介紹關(guān)于mysql數(shù)據(jù)庫格式化時(shí)需要注意的一些問題,需要的朋友可以參考下2012-11-11MySql 存儲(chǔ)引擎和索引相關(guān)知識(shí)總結(jié)
這篇文章主要介紹了MySql 存儲(chǔ)引擎和索引相關(guān)知識(shí)總結(jié),文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下2020-06-06node連接mysql數(shù)據(jù)庫遇到的問題和解決方案
這篇文章主要介紹了node連接mysql數(shù)據(jù)庫遇到的問題和解決方案,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10MySQL實(shí)現(xiàn)數(shù)據(jù)更新的示例詳解
這篇文章主要為大家詳細(xì)介紹了MySQL實(shí)現(xiàn)數(shù)據(jù)更新的相關(guān)資料,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02Mysql根據(jù)一個(gè)表的數(shù)據(jù)更新另一個(gè)表數(shù)據(jù)的SQL寫法(三種寫法)
這篇文章主要介紹了Mysql根據(jù)一個(gè)表的數(shù)據(jù)更新另一個(gè)表數(shù)據(jù)的SQL寫法,本文給大家分享三種解決方法,需要的朋友可以參考下2023-06-06關(guān)于mysql調(diào)用新手們常犯的11個(gè)錯(cuò)誤總結(jié)
對(duì)于很多新手們來說,使用PHP可以在短短幾個(gè)小時(shí)之內(nèi)輕松地寫出具有特定功能的代碼。但是,構(gòu)建一個(gè)穩(wěn)定可靠的數(shù)據(jù)庫卻需要花上一些時(shí)日和相關(guān)技能。下面這篇文章就來總結(jié)了關(guān)于mysql調(diào)用新手們常犯的十一個(gè)錯(cuò)誤,需要的朋友可以參考學(xué)習(xí)。2017-03-03MySQL數(shù)據(jù)庫Shell import_table數(shù)據(jù)導(dǎo)入
本文我們介紹一款高效的數(shù)據(jù)導(dǎo)入工具,MySQL Shell 工具集中的import_table,該工具的全稱是Parallel Table Import Utility,需要的朋友請(qǐng)參考下文2021-08-08MySQL中存儲(chǔ)的數(shù)據(jù)查詢的時(shí)候如何區(qū)分大小寫
這篇文章主要介紹了MySQL中存儲(chǔ)的數(shù)據(jù)查詢的時(shí)候如何區(qū)分大小寫問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04