suchen
HeimDatenbankMySQL-TutorialMySQL 数据导入与导出_MySQL
MySQL 数据导入与导出_MySQLJun 01, 2016 pm 02:04 PM
使用Kann命令导入数据文件

现在使用MySQL的越来越多了,我也用它做了自已的留言板。在使用过程中,慢慢地就要求对它的管理功能需要近一步的掌握,不仅是我,也是很多网友的要求。现在有一些问题是关于如何从MySQL中导出数据,以便用在本地或其它的数据库系统之上;以及将现有数据导入MySQL数据库中。现在就我学习的情况,就这两个问题作一下小结,内容不是很详细。其实MySQL的手册是很详细的,只不过我把有关这两方面的东西提取出来,加上了一点自已的理解,更详细的请参考数据库的相应章节。



数据导出
  数据导出主要有以下几种方法:
  使用select into outfile "filename"语句
  使用mysqldump实用程序
  使用select into outfile "filename"语句
  可以在mysql的命令行下或在php程序中执行它。我下面以在mysql命令行下为例。在php中使用时,将其改成相应的查询进行处理即可。不过在使用这个命令时,要求用户拥有file的权限。如我们有一个库为phptest,其中有一个表为driver。现在要把driver卸成文件。执行命令:
  mysql> use phptest;
  Database Changed
  mysql> select * from driver into outfile "a.txt";
  Query OK, 22 rows affected (0.05 sec)



  上面就可以完成将表driver从数据库中卸到a.txt文件中。注意文件名要加单引号。那么这个文件在哪呢?在mysql目录下有一个data目录,它即是数据库文件所放的地方。每个库在单独占一个子目录,所以phptest的目录为c:\mysql\data\phptest(注意:我的mysql安装在c:\mysql下)。好,现在我们进去,a.txt就是它。打开这个文件,可能是:
  1 Mika Hakinnen 1
  2 David Coulthard 1
  3 Michael Schumacher 2
  4 Rubens Barrichello 2
...
  可能还有很多记录。每个字段之间是用制表符分开的(\t)。那么我们可以修改输出文件名的目录,以便放在指定的位置。如"a.txt"可以改成"./a.txt"或"/a.txt"。其中"./a.txt"放在c:\mysql\data目录下了,
而"/a.txt"文件则放在c:\目录下了。所以select命令认为的当前目录是数据库的存放目录,这里是
c:\mysql\data。
  使用select命令还可以指定卸出文件时,字段之间的分隔字符,转义字符,包括字符,及记录行分隔字符。列在下面:
  FIELDS
  TERMINATED BY "\t"
  [OPTIONALLY] ENCLOSED BY ""
  ESCAPED BY "\\"
  LINES
  TERMINATED BY "\n"



TERMINATED 表示字段分隔
[OPTIONALLY] ENCLOSED 表示字段用什么字符包括起来,如果使用了OPTIONALLY则只有CHAR和VERCHAR被包括ESCAPED 表示当需要转义时用什么作为转义字符LINES TERMINATED 表示每行记录之间用什么分隔
  上面列的是缺省值,而且这些项都是可选的,不选则使用缺省值。可以根据需要进行修改。给出一个例子如下:
  mysql> select * from driver into outfile "a.txt" fields terminated by "," enclosed by """;
  Query OK, 22 rows affected (0.06 sec)
结果可能如下:
  "1","Mika","Hakinnen","1"
  "2","David","Coulthard","1"
  "3","Michael","Schumacher","2"
  "4","Rubens","Barrichello","2"
  ...
  可以看到每个字段都用","进行了分隔,且每个字段都用"""包括了起来。注意,行记录分隔符可以是一个字符串,请大家自行测试。不过,如果输出文件在指定目录下如果存在的话就会报错,先删除再测试即可。



使用mysqldump实用程序
  从上面的select方法可以看出,输出的文件只有数据,而没有表结构。而且,一次只能处理一个表,要处理多个表则不是很容易的。不过可以将select命令写入一个sql 文件(复制文本应该是很容易的吧),然后在命令行下执行即可:mysql 库名  先来个最简单的吧:
mysqldump phptest > a.sql



  可能结果如下:
# MySQL dump 7.1
#
# Host: localhost Database: phptest
#--------------------------------------------------------
# Server version 3.22.32-shareware-debug
#
# Table structure for table "driver"
#
CREATE TABLE driver (
drv_id int(11) DEFAULT "0" NOT NULL auto_increment,
drv_forename varchar(15) DEFAULT "" NOT NULL,
drv_surname varchar(25) DEFAULT "" NOT NULL,
drv_team int(11) DEFAULT "0" NOT NULL,
PRIMARY KEY (drv_id)
);



#
# Dumping data for table "driver"
#



INSERT INTO driver VALUES (1,"Mika","Hakinnen",1);
INSERT INTO driver VALUES (2,"David","Coulthard",1);
INSERT INTO driver VALUES (3,"Michael","Schumacher",2);
INSERT INTO driver VALUES (4,"Rubens","Barrichello",2);
...
  如果有多表,则分别列在下面。可以看到这个文件是一个完整的sql文件,如果要将其导入到其它的数据库中可以通过命令行方式,很方便:mysql phptest


  如果只想卸出建表指令,则命令如下:
mysqldump -d phptest > a.sql



  如果只想卸出插入数据的sql命令,而不需要建表命令,则命令如下:
mysqldump -t phptest > a.sql



  那么如果我只想要数据,而不想要什么sql命令时,应该如何操作呢?
mysqldump -T./ phptest driver



  其中,只有指定了-T参数才可以卸出纯文本文件,表示卸出数据的目录,./表示当前目录,即与
mysqldump同一目录。如果不指定driver表,则将卸出整个数据库的数据。每个表会生成两个文件,一个为.sql文件,包含建表执行。另一个为.txt文件,只包含数据,且没有sql指令。



  对卸出的数据文件,也可以同select方法一样,指定字段分隔符,包括字符,转义字段,行记录分隔符。参数列在下面:
--fields-terminated-by= 字段分隔符
--fields-enclosed-by= 字段包括符
--fields-optionally-enclosed-by= 字段包括符,只用在CHAR和VERCHAR字段上
--fields-escaped-by= 转义字符
--lines-terminated-by= 行记录分隔符
  我想大家应该明白这些参数的意思了吧。一个例子如下:
mysqldump -T./ --fields-terminated-by=, --fields-enclosed-by=\" phptest driver



  输出结果为:
"1","Mika","Hakinnen","1"
"2","David","Coulthard","1"
"3","Michael","Schumacher","2"
"4","Rubens","Barrichello","2"
...
  请注意字符的使用。
小结
  以上为使用select和mysqldump实用程序来卸出文本的方法。select适合利用程序进行处理,而mysqldump则为手工操作,同时提供强大的导出功能,并且可以处理整个库,或库中指定的多表。大家可以根据需求自行决定使用。
  同时还有一些方法,如直接数据库文件拷贝也可以,但是移动后的数据库系统与原系统应一致才行。这里就不再提了。



导入
  同导出相类似,导入也有两种方法:
使用LOAD DATA INFILE "filename"命令
使用mysqlimport实用程序
使用sql文件
  由于前两个处理与导出处理相似,只不过是它们的逆操作,故只给出几种命令使用的例子,不再解释了,大家可以自行查阅手册。



  使用load命令:
  load data infile "driver.txt" into table driver fields terminated by "," enclosed by """;



  使用mysqlimport实用程序:
  mysqlimport --fields-terminated-by=, --fields-enclosed-by=\" phptest driver.txt



  对于第三种,则可以使用由mysqldump导出的sql文件,在命令行下执行mysql 库名


  文章有不详尽的地方,希望大家参考手册。

转载:PHP 技术网

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
网易云音乐本地歌曲怎么导入 本地歌曲导入方法网易云音乐本地歌曲怎么导入 本地歌曲导入方法Mar 13, 2024 am 11:19 AM

  我们在使用这款平台来听歌的时候,应该大部分都是有着你们所想听的一些歌曲的,当然有些事可能因为没有版权而听不了,当然我们也可以直接的使用导入本地的一些歌曲到上面,这样就可以听了。我们可以下载一些歌曲直接的转化为mp3类型的一些格式,这样在手机上面就可以扫描来进行一些导入等情况了。不过对于大多数的用户们来说,导入本地的一些歌曲内容等方面都是并不怎么了解的,所以为了能够很好的解决这些问题,今日小编也会给大家们来好好的讲解一下其中的内容方法,让大家们可以更好的对其进行一些选择都是没问的,有兴趣的话,

如何使用Vue实现Excel导入功能如何使用Vue实现Excel导入功能Jul 22, 2023 pm 07:46 PM

如何使用Vue实现Excel导入功能Vue.js是一款流行的JavaScript框架,用于构建用户界面。它提供了许多方便的功能和易于使用的API,使我们能够快速构建出功能丰富的应用程序。在这篇文章中,我们将介绍如何使用Vue.js实现Excel导入功能。首先,我们需要安装一个名为“xlsx”的库,它是一个解析和提取Excel文件数据的JavaScript库。

openiv怎么导入oiv文件openiv怎么导入oiv文件Feb 21, 2024 pm 11:12 PM

OpenIV是一款十分方便的工具,可用于在GTA游戏中导入OIV文件。OIV文件是一种特定的文件格式,用于将模组或修改文件打包成一个易于安装的格式。本文将介绍如何使用OpenIV导入OIV文件。首先,确保你已经安装了OpenIV软件。如果没有,你可以从官方网站上下载并按照指示进行安装。接下来,从可信赖的来源下载所需的OIV文件。你可以在各种GTA模组社区或M

Oracle导入中文数据时出现乱码怎么解决?Oracle导入中文数据时出现乱码怎么解决?Mar 10, 2024 am 09:54 AM

标题:解决Oracle导入中文数据乱码问题的方法及代码示例在Oracle数据库中导入中文数据时,经常会出现乱码的情况,这可能是由于数据库字符集设置不正确或者导入过程中出现编码转换问题所致。为了解决这个问题,我们可以采取一些方法来保证导入的中文数据能够正确显示。下面是一些解决方案及具体的代码示例:一、检查数据库字符集设置在Oracle数据库中,字符集的设置对于

钉钉怎么导入工资条钉钉怎么导入工资条Mar 01, 2024 pm 09:53 PM

钉钉怎么导入工资条?在钉钉APP中是可以直接导入工资条,但是多数的用户不知道如何导入工资条,接下来就是小便为用户带来的钉钉导入工资条方法图文教程,感兴趣的玩家快来一起看看吧!钉钉怎么导入工资条1、首先打开钉钉APP进入到主页面,最底部【工作台】图标点击进入专区;2、然后在工作台功能页,选择【安心工资条】按钮;3、之后输入初始密码,输入之后进入到修改工资条;4、最后修改完成之后就可以登陆查看到每个月工资情况。

汽水音乐怎么导入外部歌单 汽水音乐导入外部歌单方法汽水音乐怎么导入外部歌单 汽水音乐导入外部歌单方法Mar 22, 2024 pm 03:51 PM

  你们知道在汽水音乐上面是怎么来导入外部歌单的吗?汽水音乐App最新版很多用户们在进行一些歌单导入的时候,是不是都喜欢自己的歌曲导入到歌单里面对不对,这样有限耳时候就能够很好的管理到自己的一些歌曲的分类什么的都可以,所以有想法的朋友们一定要错过了解一番,我相信你们一定会喜欢的,有什么想法都可以。  汽水音乐导入外部歌单步骤教程:  1、汽水音乐app页面,点击选择右下角创建歌单。  2、创建页面,输入歌单名称,点击保存。  3、我的歌单页面,选择添加歌曲。  4、搜索选择喜欢的歌曲,加入播放歌

悟饭游戏厅最新版如何导入本地游戏悟饭游戏厅最新版如何导入本地游戏Mar 20, 2024 pm 12:31 PM

悟饭游戏厅本地游戏怎么导入?悟饭游戏厅除了提供游戏资源下载之外,还能直接导入本地游戏安装包进行体验,部分玩家不清楚具体导入方法,下面小编带来导入本地游戏步骤说明,希望对大家有所帮助。1、下载并安装悟饭游戏厅APP最新版,打开软件进入首页,再点击下方的【启动游戏】图标;2、在全部游戏界面中,点击右上角的三个点按钮,位置如图所示;3、接着我们选择本地检测(大家需要先将本地游戏的安装包放置到Download文件夹中);4、最后系统会扫描出本地文件中的游戏安装包,点击导入到悟饭游戏厅中即可。

Maven进阶教程:深入探索Jar包导入的各种方法Maven进阶教程:深入探索Jar包导入的各种方法Feb 23, 2024 pm 02:57 PM

标题:Maven进阶教程:深入探索Jar包导入的各种方法Maven作为Java项目管理工具,广泛应用于项目的构建、依赖管理等方面。在实际开发过程中,我们经常会用到各种第三方库的Jar包,而如何有效地导入Jar包成为了一个必须掌握的技能。本文将深入探讨Maven中导入Jar包的方法,包括使用本地Jar包、远程仓库Jar包以及自定义Jar包等多种方式,并给出具体

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

Sicherer Prüfungsbrowser

Sicherer Prüfungsbrowser

Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

EditPlus chinesische Crack-Version

EditPlus chinesische Crack-Version

Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

mPDF

mPDF

mPDF ist eine PHP-Bibliothek, die PDF-Dateien aus UTF-8-codiertem HTML generieren kann. Der ursprüngliche Autor, Ian Back, hat mPDF geschrieben, um PDF-Dateien „on the fly“ von seiner Website auszugeben und verschiedene Sprachen zu verarbeiten. Es ist langsamer und erzeugt bei der Verwendung von Unicode-Schriftarten größere Dateien als Originalskripte wie HTML2FPDF, unterstützt aber CSS-Stile usw. und verfügt über viele Verbesserungen. Unterstützt fast alle Sprachen, einschließlich RTL (Arabisch und Hebräisch) und CJK (Chinesisch, Japanisch und Koreanisch). Unterstützt verschachtelte Elemente auf Blockebene (wie P, DIV),