mysql数据库表的导入导出
MySQL寫入數(shù)據(jù)通常用insert語句,如
復制代碼 代碼如下:
insert into person values(張三,20),(李四,21),(王五,70)…;
但有時為了更快速地插入大批量數(shù)據(jù)或交換數(shù)據(jù),需要從文本中導入數(shù)據(jù)或?qū)С鰯?shù)據(jù)到文本。
一、 建立測試表,準備數(shù)據(jù)
首先建立一個用于測試的表示學生信息的表,字段有id、姓名、年齡、城市、薪水。Id和姓名不
能為空。
復制代碼 代碼如下:
create table person(
id int not null auto_increment,
name varchar(40) not null,
city varchar(20),
salary int,
primary key(id)
)engine=innodb charset=gb2312;
?
接著寫一個用于導入的文本文件:c:\data.txt。
張三 31 北京 3000
李四 25 杭州 4000
王五 45 \N 4500
小明 29 天津 \N
?
每一項之間用Tab鍵進行分隔,如果該字段為NULL,則用\N表示。
二、 導入數(shù)據(jù)
輸入命令,進行導入。
mysql>load data local infile “c:/data.txt”? into table person(name,age,city,salary);?
?
其中l(wèi)ocal表示本地。執(zhí)行后,可以看到NULL數(shù)據(jù)也被正確地導入。
三、 導出數(shù)據(jù)
現(xiàn)在將這個表導出為文本文件:c:\data_out.txt。
復制代碼 代碼如下:
mysql>select name,age,city,salary into outfile “c:/data_out.txt” lines terminated by “\r\n” from person;
?
其中l(wèi)ines terminated by “\r\n”表示每一行(即每一條記錄)用\r\n分隔,\r\n是window系
統(tǒng)的換行符。導出的data_out.txt與data.txt的內(nèi)容完全一樣。
四、 運行環(huán)境
Windows vista home basic
MySQL 5.1.34-community
五、 注意
字段之間的分隔和記錄(行)之間的分隔默認是\t(即Tab)和\n。但可以改變,如:
FIELDS TERMINATED BY ',' --字段用,進行分隔
LINES TERMINATED BY ';' --記錄用; 進行分隔
另外要注意其它操作系統(tǒng)的換行符與windows可能不相同。
詳細出處參考:http://www.jb51.net/article/21117.htm
不過,有可能產(chǎn)生中文亂碼,所以你的數(shù)據(jù)庫txt文件最好是保存成utf8的格式
在運行數(shù)據(jù)庫的時候
mysql> set names utf8;
mysql>load data local infile "~/vote.txt" into table SYSARG_DB.t_sysarg_vote_for_works;
OK
導出數(shù)據(jù)庫的表結(jié)構(gòu):
mysqldump ?-uroot -p123 ?ron globalmarket > globalmarket.sql
mysql中把一個表的數(shù)據(jù)導入到另外一個表中的命令:
insert into table1 select * from table2
總結(jié)
以上是生活随笔為你收集整理的mysql数据库表的导入导出的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 如何使得客户端和服务器端完美配合做IOS
- 下一篇: MYSQL增量备份和全量备份脚本