本文目录一览:
1、mysql使用问题
2、mysql怎样将一个数据库中的数据导入到另一个数据库中
3、如何用MySQL命令对数据库进行导出/导入/技巧
4、mysql导入数据库文件出错,求高手指点
5、MySQL两个数据表的字段不一样,如何把其中的一列数据导入到另一个表?
mysql使用问题
恢复整个数据库 首先,如果要恢复的数据库是含有授权表的mysql数据库,将需要使用--skip-grant-tables
选项运行服务器。否则,服务器将抱怨无法找到授权表。在恢复表之后,执行mysqladmin flush-privileges
来告诉服务器加载授权表,并用它们启动。将原数据库目录的内容拷贝到其他的地方。例如,您可能会在稍后用它们进行崩溃表的事后分析检查(post-mortem examination)。用最新的备份文件重新加载数据库。如果您打算使用由mysqldump加载的文件,则需要将它们作为mysql的输入。如果打算使用从数据库中直接拷贝的文件(如,用tar或cp),则将它们直接拷贝回到该数据库目录中。但是,在这种情况下,应该在拷贝这些文件之前关闭服务器,然后再重新启动它。用更新日志重做在进行备份后又修改了数据库表的查询。对于所有可用的更新日志,可使用它作为mysql的输入。指定--one-database
选项,使mysql只对想要恢复的数据库执行查询。如果您知道需要使用所有的更新日志文件,可在包含日志的目录中使用下列命令:
% ls -t -r -l update.(0-9)* | xargs cat | mysql --one-database db_name
ls
命令产生更新日志文件的单列列表,更新日志文件根据服务器生成的顺序进行排序(要知道,如果您修改了其中的任何文件,排序的顺序都将改变,这将导致更新日志按错误的顺序使用)。您很可能必须使用某些更新日志。例如,如果自备份以来所产生的日志命名为update.392
、update.393
等等,可以重新运行它们中的命令:
% mysql --one-database db_name update.392
% mysql --one-database db_name update.393
...
如果您正在运行恢复并打算使用更新日志恢复由于失策的DROP DATABASE
、DROP TABLE
或DELETE
语句而丢失的信息,应确保先从更新日志中删除这些语句。
恢复单个的表
恢复单个表是很困难的。如果有通过mysqldump生成的备份文件并且它恰好不包含您想要的表数据,则需要抽取相关的行并用它们作为mysql的输入,这部分较容易。困难的是抽取应用于该表的更新日志的片段。您会发现:mysql_find_rows
实用程序对这方面有帮助,它可以从更新日志中抽取多行查询。另一种可能性是用另一个服务器恢复整个数据库,然后将所要的该表的文件拷贝到原始数据库中。这实际很容易!在将文件拷贝回数据库目录时,应确保原始数据库的服务器关闭。
mysql怎样将一个数据库中的数据导入到另一个数据库中
- 启动该工具,设置好数据链接。
- 先看下SQL SERVER中的数据,现在需要将这些数据导入到MySQL中。
- 在MySQL中也建有同样的表,但在该表中做了点区别,
age
这个字段命名跟SQL SERVER中不一样,其余的都一样。 - 点击工具栏中的下列按钮开始数据导入。
- 根据提示操作。
- 选择文件数据源。
- 选择第一项。
- 导入完成。
如何用MySQL命令对数据库进行导出/导入/技巧
info:
1.txt
zhangsan wuhan
lishi wuhan
把1.txt文件插入到mysql数据库中
mysql -u root -p 数据库名 /文件路径(在bin下就直接加文件名)
mysqlimport
的语法介绍:mysqlimport
位于mysql/bin目录中,是mysql的一个载入(或者说导入)数据的一个非常有效的工具。这是一个命令行工具。有两个参数以及大量的选项可供选择。这个工具把一个文本文件(text file)导入到你指定的数据库和表中。比方说我们要从文件Customers.txt
中把数据导入到数据库Meet_A_Geek
中的表Customers
中:
mysqlimport Meet_A_Geek Customers.txt
注意:这里Customers.txt
是我们要导入数据的文本文件,而Meet_A_Geek
是我们要操作的数据库,数据库中的表名是Customers
,这里文本文件的数据格式必须与Customers
表中的记录格式一致,否则mysqlimport
命令将会出错。
其中表的名字是导入文件的第一个句号(.
)前面文件字符串,另外一个例子:
mysqlimport Meet_A_Geek Cus.to.mers.txt
那么我们将把文件中的内容导入到数据库Meet_A_Geek
中的Cus
表中。上面的例子中,都只用到两个参数,并没有用到更多的选项,下面介绍mysqlimport
的选项:
选项 | 功能 |
---|---|
-d or --delete |
新数据导入数据表中之前删除数据数据表中的所有信息 |
-f or --force |
不管是否遇到错误,mysqlimport 将强制继续插入数据 |
-i or --ignore |
mysqlimport 跳过或者忽略那些有相同唯一关键字的行,导入文件中的数据将被忽略 |
-l or --lock-tables |
数据被插入之前锁住表,这样就防止了,你在更新数据库时,用户的查询和更新受到影响 |
-r or --replace |
这个选项与-i 选项的作用相反;此选项将替代表中有相同唯一关键字的记录 |
--fields-enclosed-by=char |
指定文本文件中数据的记录时以什么括起的,很多情况下数据以双引号括起。默认的情况下数据是没有被字符括起的 |
--fields-terminated-by=char |
指定各个数据的值之间的分隔符,在句号分隔的文件中,分隔符是句号。您可以用此选项指定数据之间的分隔符。默认的分隔符是跳格符(Tab) |
--lines-terminated-by=str |
此选项指定文本文件中行与行之间数据的分隔字符串或者字符。默认的情况下mysqlimport 以newline为行分隔符。您可以选择用一个字符串来替代一个单个的字符:一个新行或者一个回车 |
mysqlimport 命令常用的选项还有-v 显示版本(version),-p 提示输入密码(password)等。 |
|
例子: 导入一个以逗号为分隔符的文件,文件中行的记录格式是这样的: |
"1", "ORD89876", "1 Dozen Roses", "19991226"
我们的任务是要把这个文件里面的数据导入到数据库Meet_A_Geek
中的表格Orders
中,我们使用这个命令:
bin/mysqlimport -prl --fields-enclosed-by=" --fields-terminated-by=, Meet_A_Geek Orders.txt
3.mysql数据库常用导出导入命令的几个用例
几个常用用例:
- 导出整个数据库
示例:mysqldump -u 用户名 -p 数据库名 导出的文件名
mysqldump -u wcnc -p smgp_apps_wcnc wcnc.sql
- 导出一个表
示例:mysqldump -u 用户名 -p 数据库名 表名 导出的文件名
mysqldump -u wcnc -p smgp_apps_wcnc users wcnc_users.sql
- 导出一个数据库结构
mysqldump -u wcnc -p -d --add-drop-table smgp_apps_wcnc d:\wcnc_db.sql
-d
没有数据--add-drop-table
在每个create语句之前增加一个drop table
- 导入数据库
常用
source
命令。进入mysql数据库控制台,如:
然后使用mysql -u root -p
source
命令,后面参数为脚本文件(如这里用到的.sql
):use 数据库; source d:\wcnc_db.sql
- 可参看 MySQL数据的导出和导入工具:mysqldump
批处理是一种非交互式运行mysql程序的方法,如同您在mysql中使用的命令一样,你仍然将使用这些命令。为了实现批处理,您重定向一个文件到mysql程序中,首先我们需要一个文本文件,这个文本文件包含有与我们在mysql中输入的命令相同的文本。比如我们要插入一些数据,使用包含下面文本的文件(文件名为
New_Data.sql
,当然我们也可以取名为New_Data.txt
及任何其他的合法名字,并不一定要以后缀sql结尾):
USE Meet_A_Geek;
INSERT INTO Customers (Customer_ID, Last_Name) VALUES(NULL, "Block");
INSERT INTO Customers (Customer_ID, Last_Name) VALUES(NULL, "Newton");
INSERT INTO Customers (Customer_ID, Last_Name) VALUES(NULL, "Simmons");
注意上面的这些句子的语法都必须是正确的,并且每个句子以分号结束。上面的USE
命令选择数据库,INSERT
命令插入数据。
下面我们要把上面的文件导入到数据库中,导入之前要确认数据库已经在运行,即是mysqld
进程(或者说服务,Windows NT下面称为“服务”,Unix下面为“进程”)已经在运行。然后运行下面的命令:
bin/mysql -p /home/mark/New_Data.sql
接着按提示输入密码,如果上面的文件中的语句没有错误,那么这些数据就被导入到了数据库中。
命令行中使用LOAD DATA INFILE 从文件中导入数据到数据库:
现在您可能会问自己,“究竟为什么我要输入所有的这些SQL语句到文件中,然后通过程序运行它们呢?”这样看起来好像需要大量的工作。很好,你这样想很可能就对了。但是假如你有从所有这些命令中产生的log记录呢?现在这样就很棒,嗯,大多数数据库都会自动产生数据库中的事件记录的log。而大部分log都包含有用过的原始的SQL命令。因此,如果您不能从您现在的数据库中导出数据到新的mysql数据库中使用,那么您可以使用log和mysql的批处理特性,来快速且方便地导入您地数据。当然,这样就省去了打字的麻烦。
LOAD DATA INFILE
这是我们要介绍的最后一个导入数据到MySQL数据库中的方法。这个命令与mysqlimport
非常相似,但这个方法可以在mysql命令行中使用。也就是说您可以在所有使用API的程序中使用这个命令。使用这种方法,您就可以在应用程序中导入您想要导入的数据。
使用这个命令之前,mysqld
进程(服务)必须已经在运行。启动mysql命令行:
bin/mysql -p
按提示输入密码,成功进入mysql命令行之后,输入下面的命令:
USE Meet_A_Geek;
LOAD DATA INFILE "/home/mark/data.sql" INTO TABLE Orders;
简单的讲,这样将会把文件data.sql
中的内容导入到表Orders
中,如mysqlimport
工具一样,这个命令也有一些可以选择的参数。比如您需要把自己的电脑上的数据导入到远程的数据库服务器中,您可以使用下面的命令:
LOAD DATA LOCAL INFILE "C:\MyDocs\SQL.txt" INTO TABLE Orders;
上面的LOCAL
参数表示文件是本地的文件,服务器是您所登陆的服务器。这样就省去了使用ftp来上传文件到服务器,MySQL替你完成了。
您也可以设置插入语句的优先级,如果您要把它标记为低优先级(LOW_PRIORITY
),那么MySQL将会等到没有其他人读这个表的时候,才把插入数据。可以使用如下的命令:
LOAD DATA LOW_PRIORITY INFILE "/home/mark/data.sql" INTO TABLE Orders;
您也可以指定是否在插入数据的时候,取代或者忽略文件与数据表中重复的键值。替代重复的键值的语法:
LOAD DATA LOW_PRIORITY INFILE "/home/mark/data.sql" REPLACE INTO TABLE Orders;
上面的句子看起来有点笨拙,但却把关键字放在了让您的剖析器可以理解的地方。
下面的一对选项描述了文件的记录格式,这些选项也是在mysqlimport
工具中可以用的。他们在这里看起来有点不同。首先,要用到FIELDS
关键字,如果用到这个关键字,MySQL剖析器希望看到至少有下面的一个选项:
TERMINATED BY character
ENCLOSED BY character
ESCAPED BY character
这些关键字与它们的参数跟mysqlimport
中的用法是一样的。TERMINATED BY
描述字段的分隔符,默认情况下是tab字符(\t
)ENCLOSED BY
描述的是字段的括起字符。比方以引号括起每一个字段。ESCAPED BY
描述的转义字符。默认的是反斜杠(backslash:\
) 下面仍然使用前面的mysqlimport
命令的例子,用LOAD DATA INFILE
语句把同样的文件导入到数据库中:
LOAD DATA INFILE "/home/mark/Orders.txt" REPLACE INTO TABLE Orders FIELDS TERMINATED BY ',' ENCLOSED BY '"';
LOAD DATA INFILE
语句中有一个mysqlimport
工具中没有特点:LOAD DATA INFILE
可以按指定的列把文件导入到数据库中。
当我们要把数据的一部分内容导入的时候,这个特点就很重要。比方说,我们要从Access数据库升级到MySQL数据库的时候,需要加入一些栏目(列/字段/field)到MySQL数据库中,以适应一些额外的需要。这个时候,我们的Access数据库中的数据仍然是可用的,但是因为这些数据的栏目(field)与MySQL中的不再匹配,因此而无法再使用mysqlimport
工具。尽管如此,我们仍然可以使用LOAD DATA INFILE
,下面的例子显示了如何向指定的栏目(fields)中导入数据:
LOAD DATA INFILE "/home/Order.txt" INTO TABLE Orders(Order_Number, Order_Date, Customer_ID);
如您所见,我们可以指定需要的栏目(fields)。这些指定的字段依然是以括号括起,由逗号分隔的,如果您遗漏了其中任何一个,MySQL将会提醒您^_^。
mysql导入数据库文件出错,求高手指点
如果从库上表 t
数据与主库不一致,导致复制错误,整个库的数据量很大,重做从库很慢,如何单独恢复这张表的数据?通常认为是不能修复单表数据的,因为涉及到各表状态不一致的问题。下面就列举备份单表恢复到从库会面临的问题以及解决办法:
场景 1
如果复制报错后,没有使用跳过错误、复制过滤等方法修复主从复制。主库数据一直在更新,从库数据停滞在报错状态(假设 GTID 为 aaaa:1-100
)。
修复步骤:
- 在主库上备份表
t
(假设备份快照 GTID 为aaaa:1-10000
); - 恢复到从库;
- 启动复制。
这里的问题是复制起始位点是
aaaa:101
,从库上表t
的数据状态是领先其他表的。aaaa:101-10000
这些事务中只要有修改表t
数据的事务,就会导致复制报错,比如主键冲突、记录不存在(而aaaa:101
这个之前复制报错的事务必定是修改表t
的事务)
解决办法:
启动复制时跳过 aaaa:101-10000
这些事务中修改表 t
的事务。
正确的修复步骤:
- 在主库上备份表
t
(假设备份快照 GTID 为aaaa:1-10000
),恢复到从库; - 设置复制过滤,过滤表
t
:CHANGE REPLICATION FILTER REPLICATE_WILD_IGNORE_TABLE = ('db_name.t');
- 启动复制,回放到
aaaa:10000
时停止复制(此时从库上所有表的数据都在同一状态,是一致的):START SLAVE UNTIL SQL_AFTER_GTIDS = 'aaaa:10000';
- 删除复制过滤,正常启动复制。
注意事项:
这里要用 mysqldump --single-transaction --master-data=2
,记录备份快照对应的 GTID。
场景 2
如果复制报错后,使用跳过错误、复制过滤等办法修复了主从复制。主、从库数据一直在更新。
修复步骤:
- 在主库上备份表
t
(假设备份快照 GTID为aaaa:1-10000
); - 停止从库复制,GTID为
aaaa:1-20000
; - 恢复表
t
到从库; - 启动复制。
这里的问题是复制起始位点是
aaaa:20001
,aaaa:10000-20000
这些事务将不会在从库上回放,如果这里面有修改表t
数据的事务,从库上将丢失这部分数据。
解决办法:
从备份开始到启动复制,锁定表 t
,保证 aaaa:10000-20000
中没有修改表 t
的事务。
正确修复步骤:
- 对表
t
加读锁; - 在主库上备份表
t
; - 停止从库复制,恢复表
t
; - 启动复制;
- 解锁表
t
。 如果是大表,这里可以用可传输表空间方式备份、恢复表,减少锁表时间。
MySQL两个数据表的字段不一样,如何把其中的一列数据导入到另一个表?
db1
为原数据库,db2
为要导出到的数据库,fromtable
是要导出的表名
1. 方法一:
登录导出到的数据库,执行:
CREATE TABLE fromtable SELECT * FROM db1.fromtable;
2. 方法二:
在cmd下执行:
mysqldump -u root -p db1 fromtable > d:/fromtable.sql
输入密码,root
为用户名
登录db2
执行:
SOURCE d:/fromtable.sql;
3. 方法三:
登录db1
执行:
SELECT * FROM fromtable INTO OUTFILE "d:/fromtable.txt";
导出纯数据格式
登录db2
执行:
LOAD DATA INFILE "d:/fromtable.txt" INTO TABLE fromtable;
需要先建一张和原表结构一样的空表。