如何導(dǎo)入.sql文件到mysql中
創(chuàng)新互聯(lián)擁有一支富有激情的企業(yè)網(wǎng)站制作團(tuán)隊(duì),在互聯(lián)網(wǎng)網(wǎng)站建設(shè)行業(yè)深耕十年,專(zhuān)業(yè)且經(jīng)驗(yàn)豐富。十年網(wǎng)站優(yōu)化營(yíng)銷(xiāo)經(jīng)驗(yàn),我們已為千余家中小企業(yè)提供了成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計(jì)解決方案,按需網(wǎng)站建設(shè),設(shè)計(jì)滿意,售后服務(wù)無(wú)憂。所有客戶皆提供一年免費(fèi)網(wǎng)站維護(hù)!
首先:建立數(shù)據(jù)庫(kù),用這個(gè)命令:create
database
dbname;
其中dbname是數(shù)據(jù)庫(kù)名稱(chēng)
C:\mysql\binmysql
-u
用戶名
-p
數(shù)據(jù)庫(kù)名
mysql
-u
root
-p
myrosz
c:/myro.sql
Enter
password:
****
稍等一會(huì),就可以導(dǎo)入數(shù)據(jù)表。
insert into tablename values(value1,value2,...) insert into tablename(fieldname1,fieldname2,...) values(value1,value2,...) insert into tablename(fieldname1,fieldname2) select fieldname1,fieldname2 from tablename1 以上基本上羅列了用insert插入數(shù)據(jù)的方法,當(dāng)然你也可以用insert語(yǔ)句將幾行同時(shí)插入到一個(gè)表中.如下所示: 2.在mysql運(yùn)行環(huán)境下,我們還可以用LOAD DATA 語(yǔ)句把文件里面的數(shù)據(jù)讀取錄入到表里面.一般來(lái)講,因?yàn)榇宋募怯煞?wù)器在主機(jī)上直接讀取的.所以你必須具有file權(quán)限且文件必須是完全可讀.當(dāng)你版本夠新的話,你可以給出local,這樣由于你是從客戶機(jī)上讀取該文件并將內(nèi)容傳送到服務(wù)器,你就不需要file權(quán)限. 如果你沒(méi)有給出local,則服務(wù)器按如下方法對(duì)其進(jìn)行定位: 1)如果你的filename為絕對(duì)路徑,則服務(wù)器從根目錄開(kāi)始查找該文件. 2)如果你的filename為相對(duì)路徑,則服務(wù)器從數(shù)據(jù)庫(kù)的數(shù)據(jù)目錄中開(kāi)始查找該文件. 如果你給出了local,則文件將按以下方式進(jìn)行定位: 1)如果你的filename為絕對(duì)路徑,則客戶機(jī)從根目錄開(kāi)始查找該文件. 2)如果你的filename為相對(duì)路徑,則客戶機(jī)從當(dāng)前目錄開(kāi)始查找該文件. 說(shuō)了半天,也許你還不明白這具體的格式,看下面先: LOAD DATA [LOCAL] INFILE 'filename' into table tablename import_options [(fieldname_list)] import options的語(yǔ)法為:fieldsterminated by 'char' enclosed by 'char' escaped by 'char'linesterminated by 'string' 下面我們對(duì)其進(jìn)行一些說(shuō)明: 1)fields terminated by char 指定分隔列的字符.缺省時(shí)假定列值由制表符分隔. 2)fields enclosed by char 指明列值應(yīng)包括在指定的字符中.通常用引號(hào).缺省時(shí),假定列值不包括在任何字符中. 3)fields escaped by char 表示用于轉(zhuǎn)義特殊字符的轉(zhuǎn)義符.缺省時(shí)表示無(wú)轉(zhuǎn)義符 4)lindes escaped by string 指定結(jié)束輸入行的串(可以是多字符的).缺省時(shí)假定由換行符終止行 需要注意的是轉(zhuǎn)義字符的使用. 如:\' 表示單引號(hào),\" 表示雙引號(hào) 等等.另外還有一些選項(xiàng)這里沒(méi)有具體談到,如 ignore n lines 她可以控制文件的前n行不被讀入數(shù)據(jù)庫(kù).詳細(xì)請(qǐng)看mysql中文參考. 說(shuō)了上面這么多,給一行命令大家具體體會(huì)一下: load data [local] infile "sample.txt" into table sample fields terminated by "," enclosed by "\"" 3.在系統(tǒng)命令行下你可以用mysqlimport實(shí)用程序,她將文本文件的內(nèi)容讀取到已有表中(其實(shí)mysqlimport起的作用就是實(shí)現(xiàn)load data命令行的接口),調(diào)用完mysqlimport后她生成一個(gè)load data 語(yǔ)句.語(yǔ)法基本上和load data差不多: mysqlimport [options] sample_db filename 同樣,給條命令看一下吧:
當(dāng)你建好了數(shù)據(jù)庫(kù)及表時(shí) 你首先想到的就是向數(shù)據(jù)庫(kù)的表中輸入數(shù)據(jù) 這就牽涉到如何向數(shù)據(jù)庫(kù)增加數(shù)據(jù) 下面我們就來(lái)探討一下這個(gè)問(wèn)題: 一般我們常用的方法是insert語(yǔ)句(這里假定各位的版本都不是很低) 她有以下幾種形式:insert into tablename values(value value )insert into tablename(fieldname fieldname ) values(value value )insert into tablename set fieldname =value fieldname =value insert into tablename(fieldname fieldname ) select fieldname fieldname from tablename 以上基本上羅列了用insert插入數(shù)據(jù)的方法 當(dāng)然你也可以用insert語(yǔ)句將幾行同時(shí)插入到一個(gè)表中 如下所示:insert into tablename values( ) ( ) 在mysql運(yùn)行環(huán)境下 我們還可以用LOAD DATA 語(yǔ)句把文件里面的數(shù)據(jù)讀取錄入到表里面 一般來(lái)講 因?yàn)榇宋募怯煞?wù)器在主機(jī)上直接讀取的 所以你必須具有file權(quán)限且文件必須是完全可讀 當(dāng)你版本夠新的話 你可以給出local 這樣由于你是從客戶機(jī)上讀取該文件并將內(nèi)容傳送到服務(wù)器 你就不需要file權(quán)限 如果你沒(méi)有給出local 則服務(wù)器按如下方法對(duì)其進(jìn)行定位: )如果你的filename為絕對(duì)路徑 則服務(wù)器從根目錄開(kāi)始查找該文件 )如果你的filename為相對(duì)路徑 則服務(wù)器從數(shù)據(jù)庫(kù)的數(shù)據(jù)目錄中開(kāi)始查找該文件 如果你給出了local 則文件將按以下方式進(jìn)行定位: )如果你的filename為絕對(duì)路徑 則客戶機(jī)從根目錄開(kāi)始查找該文件 )如果你的filename為相對(duì)路徑 則客戶機(jī)從當(dāng)前目錄開(kāi)始查找該文件 說(shuō)了半天 也許你還不明白這具體的格式 看下面先:LOAD DATA [LOCAL] INFILE filename into table tablename import_options [(fieldname_list)]import options的語(yǔ)法為:fieldsterminated by char enclosed by char escaped by char linesterminated by string 下面我們對(duì)其進(jìn)行一些說(shuō)明: )fields terminated by char 指定分隔列的字符.缺省時(shí)假定列值由制表符分隔. )fields enclosed by char 指明列值應(yīng)包括在指定的字符中.通常用引號(hào).缺省時(shí) 假定列值不包括在任何字符中. )fields escaped by char 表示用于轉(zhuǎn)義特殊字符的轉(zhuǎn)義符.缺省時(shí)表示無(wú)轉(zhuǎn)義符 )lindes escaped by string 指定結(jié)束輸入行的串(可以是多字符的).缺省時(shí)假定由換行符終止行需要注意的是轉(zhuǎn)義字符的使用 如:\ 表示單引號(hào) \ 表示雙引號(hào) 等等 另外還有一些選項(xiàng)這里沒(méi)有具體談到 如 ignore n lines 她可以控制文件的前n行不被讀入數(shù)據(jù)庫(kù) 詳細(xì)請(qǐng)看mysql中文參考 說(shuō)了上面這么多 給一行命令大家具體體會(huì)一下:load data [local] infile sample txt into table sample fields terminated by enclosed by \ 在系統(tǒng)命令行下你可以用mysqlimport實(shí)用程序 她將文本文件的內(nèi)容讀取到已有表中(其實(shí)mysqlimport起的作用就是實(shí)現(xiàn)load data命令行的接口) 調(diào)用完mysqlimport后她生成一個(gè)load data 語(yǔ)句 語(yǔ)法基本上和load data差不多:mysqlimport [options] sample_db filename同樣 給條命令看一下吧:mysqlimport Cu root [ local] Cfields terminated by= fields enclosed by= \ samp_db samp_table txt(REMARK:此語(yǔ)句中samp_db為指定的數(shù)據(jù)庫(kù) 要錄入數(shù)據(jù)的表由文件名參數(shù)確定 文件名去掉其任何擴(kuò)展名 留下的就是表名 所以此語(yǔ)句中錄入數(shù)據(jù)的表名為samp_table 也就是說(shuō)在執(zhí)行這條語(yǔ)句時(shí)首先應(yīng)該肯定表samp_table存在 另外如果你有多個(gè)文件需要裝入同一個(gè)表里 你可以用samp_table n txt來(lái)處理) lishixinzhi/Article/program/MySQL/201311/29349
方法如下:
1、首先打開(kāi)Mysql命令行編輯器,連接Mysql數(shù)據(jù)庫(kù);
2、使用所要操作的數(shù)據(jù)庫(kù),先顯示一下數(shù)據(jù)庫(kù)中的表;
3、顯示一下表結(jié)構(gòu),了解一下表中的列;
4、向表插入數(shù)據(jù),insert into 表名 (列名) values (值);
5、查詢表可以看到所插入的數(shù)據(jù),select * from 表名;
6、可以再插入一個(gè)數(shù)據(jù),顯示一下。
擴(kuò)展資料:
MySQL是一個(gè)關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),由瑞典MySQL AB 公司開(kāi)發(fā),目前屬于?Oracle?旗下產(chǎn)品。MySQL 是最流行的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng)之一,在 WEB 應(yīng)用方面,MySQL是最好的?RDBMS?(Relational Database Management System,關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng)) 應(yīng)用軟件。
MySQL是一種關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng),關(guān)系數(shù)據(jù)庫(kù)將數(shù)據(jù)保存在不同的表中,而不是將所有數(shù)據(jù)放在一個(gè)大倉(cāng)庫(kù)內(nèi),這樣就增加了速度并提高了靈活性。
MySQL所使用的 SQL 語(yǔ)言是用于訪問(wèn)數(shù)據(jù)庫(kù)的最常用標(biāo)準(zhǔn)化語(yǔ)言。MySQL 軟件采用了雙授權(quán)政策,分為社區(qū)版和商業(yè)版,由于其體積小、速度快、總體擁有成本低,尤其是開(kāi)放源碼這一特點(diǎn),一般中小型網(wǎng)站的開(kāi)發(fā)都選擇 MySQL 作為網(wǎng)站數(shù)據(jù)庫(kù)。
由于其社區(qū)版的性能卓越,搭配?PHP?和?Apache?可組成良好的開(kāi)發(fā)環(huán)境。
與其他的大型數(shù)據(jù)庫(kù),例如?Oracle、DB2、SQL Server等相比,MySQL自有它的不足之處,但是這絲毫也沒(méi)有減少它受歡迎的程度。對(duì)于一般的個(gè)人使用者和中小型企業(yè)來(lái)說(shuō),MySQL提供的功能已經(jīng)綽綽有余,而且由于 MySQL是開(kāi)放源碼軟件,因此可以大大降低總體擁有成本。
Linux作為操作系統(tǒng),Apache?或Nginx作為?Web?服務(wù)器,MySQL 作為數(shù)據(jù)庫(kù),PHP/Perl/Python作為服務(wù)器端腳本解釋器。由于這四個(gè)軟件都是免費(fèi)或開(kāi)放源碼軟件(FLOSS),因此使用這種方式不用花一分錢(qián)(除開(kāi)人工成本)就可以建立起一個(gè)穩(wěn)定、免費(fèi)的網(wǎng)站系統(tǒng),被業(yè)界稱(chēng)為“LAMP“或“LNMP”組合。
MyISAMMySQL 5.0 之前的默認(rèn)數(shù)據(jù)庫(kù)引擎,最為常用。擁有較高的插入,查詢速度,但不支持事務(wù)
InnoDB事務(wù)型數(shù)據(jù)庫(kù)的首選引擎,支持ACID事務(wù),支持行級(jí)鎖定, MySQL 5.5 起成為默認(rèn)數(shù)據(jù)庫(kù)引擎
BDB源 自 Berkeley DB,事務(wù)型數(shù)據(jù)庫(kù)的另一種選擇,支持Commit 和Rollback 等其他事務(wù)特性
Memory所有數(shù)據(jù)置于內(nèi)存的存儲(chǔ)引擎,擁有極高的插入,更新和查詢效率。但是會(huì)占用和數(shù)據(jù)量成正比的內(nèi)存空間。并且其內(nèi)容會(huì)在 MySQL 重新啟動(dòng)時(shí)丟失
Merge將一定數(shù)量的 MyISAM 表聯(lián)合而成一個(gè)整體,在超大規(guī)模數(shù)據(jù)存儲(chǔ)時(shí)很有用
Archive非常適合存儲(chǔ)大量的獨(dú)立的,作為歷史記錄的數(shù)據(jù)。因?yàn)樗鼈儾唤?jīng)常被讀取。Archive 擁有高效的插入速度,但其對(duì)查詢的支持相對(duì)較差
Federated將不同的 MySQL 服務(wù)器聯(lián)合起來(lái),邏輯上組成一個(gè)完整的數(shù)據(jù)庫(kù)。非常適合分布式應(yīng)用
Cluster/NDB高冗余的存儲(chǔ)引擎,用多臺(tái)數(shù)據(jù)機(jī)器聯(lián)合提供服務(wù)以提高整體性能和安全性。適合數(shù)據(jù)量大,安全和性能要求高的應(yīng)用
CSV: 邏輯上由逗號(hào)分割數(shù)據(jù)的存儲(chǔ)引擎。它會(huì)在數(shù)據(jù)庫(kù)子目錄里為每個(gè)數(shù)據(jù)表創(chuàng)建一個(gè) .csv 文件。這是一種普通文本文件,每個(gè)數(shù)據(jù)行占用一個(gè)文本行。CSV 存儲(chǔ)引擎不支持索引。
BlackHole:黑洞引擎,寫(xiě)入的任何數(shù)據(jù)都會(huì)消失,一般用于記錄 binlog 做復(fù)制的中繼
EXAMPLE 存儲(chǔ)引擎是一個(gè)不做任何事情的存根引擎。它的目的是作為 MySQL?源代碼中的一個(gè)例子,用來(lái)演示如何開(kāi)始編寫(xiě)一個(gè)新存儲(chǔ)引擎。同樣,它的主要興趣是對(duì)開(kāi)發(fā)者。EXAMPLE 存儲(chǔ)引擎不支持編索引。
另外,MySQL 的存儲(chǔ)引擎接口定義良好。有興趣的開(kāi)發(fā)者可以通過(guò)閱讀文檔編寫(xiě)自己的存儲(chǔ)引擎。
參考資料來(lái)源:百度百科:mySQL