这里会显示出您选择的修订版和当前版本之间的差别。
note:spoony:mysql导入导出sql文件 [2017/12/14 10:45] Spoony |
note:spoony:mysql导入导出sql文件 [2017/12/14 10:45] |
||
---|---|---|---|
行 1: | 行 1: | ||
- | ====== mysql导入导出sql文件 ====== | ||
- | <code> | ||
- | window下 | ||
- | |||
- | 1.导出整个数据库 | ||
- | mysqldump -u 用户名 -p 数据库名 > 导出的文件名 | ||
- | mysqldump -u dbuser -p dbname > dbname.sql | ||
- | |||
- | 2.导出一个表 | ||
- | mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名 | ||
- | mysqldump -u dbuser -p dbname users> dbname_users.sql | ||
- | |||
- | 3.导出一个数据库结构 | ||
- | mysqldump -u dbuser -p -d --add-drop-table dbname >d:/dbname_db.sql | ||
- | -d 没有数据 --add-drop-table 在每个create语句之前增加一个drop table | ||
- | |||
- | 4.导入数据库 | ||
- | 常用source 命令 | ||
- | 进入mysql数据库控制台,如 | ||
- | mysql -u root -p | ||
- | mysql>use 数据库 | ||
- | 然后使用source命令,后面参数为脚本文件(如这里用到的.sql) | ||
- | mysql>source d:/dbname.sql | ||
- | |||
- | |||
- | |||
- | |||
- | |||
- | 1. 导入数据到数据库 | ||
- | |||
- | mysql -uroot -D数据库名 | ||
- | |||
- | 1. 导入数据到数据库中得某个表 | ||
- | |||
- | mysql -uroot -D数据库名 表名 | ||
- | |||
- | |||
- | |||
- | D:\APMServ5.2.6\MySQL5.1\bin>mysqldump -u root -p erp lightinthebox_tags > ligh | ||
- | tinthebox.sql | ||
- | |||
- | |||
- | |||
- | linux下 | ||
- | |||
- | 一、导出数据库用mysqldump命令(注意mysql的安装路径,即此命令的路径): | ||
- | 1、导出数据和表结构: | ||
- | mysqldump -u用户名 -p密码 数据库名 > 数据库名.sql | ||
- | #/usr/local/mysql/bin/ mysqldump -uroot -p abc > abc.sql | ||
- | 敲回车后会提示输入密码 | ||
- | |||
- | 2、只导出表结构 | ||
- | mysqldump -u用户名 -p密码 -d 数据库名 > 数据库名.sql | ||
- | #/usr/local/mysql/bin/ mysqldump -uroot -p -d abc > abc.sql | ||
- | |||
- | 注:/usr/local/mysql/bin/ ---> mysql的data目录 | ||
- | |||
- | |||
- | 二、导入数据库 | ||
- | 1、首先建空数据库 | ||
- | mysql>create database abc; | ||
- | |||
- | 2、导入数据库 | ||
- | 方法一: | ||
- | (1)选择数据库 | ||
- | mysql>use abc; | ||
- | (2)设置数据库编码 | ||
- | mysql>set names utf8; | ||
- | (3)导入数据(注意sql文件的路径) | ||
- | mysql>source /home/abc/abc.sql; | ||
- | 方法二: | ||
- | mysql -u用户名 -p密码 数据库名 < 数据库名.sql | ||
- | #mysql -uabc_f -p abc < abc.sql | ||
- | </code> | ||
- | |||
- | MySQL插入中文时出现ERROR 1406 (22001): Data too long for column 'name' at row 1 | ||
- | |||
- | <code> | ||
- | 使用命令行方式登陆到MySQL服务器, 建立一个数据库,数据库编码设为UTF-8。此时,如果直接在命令行窗口使用insert语句插入中文,就遇到类似 ERROR 1406 (22001): Data too long for column 'name' at row 1 错误。乍一看,是字段长度引起的问题,但是实际是字符编码的问题。可是尝试以下解决方法: | ||
- | 1、在Linux中,使用终端方式登陆MySQL服务器,运行以下命令: | ||
- | set names utf8; | ||
- | 该命令将终端的字符编码设为了UTF-8。此后再插入数据库中的内容都会按照UTF-8的编码来处理。 | ||
- | 注意:在Linux中,终端方式中直接插入中文内容,可能并不会出现1406错误,但是这时插入的数据是按照系统的默认编码进行处理。因此对编码为UTF-8的数据库,在显示数据的地方可能会出现乱码。 | ||
- | |||
- | 2、在Windows下,命令行窗口不支持UTF-8编码,所以使用“set names utf8;”不会达到转化中文的效果。但是这个问题还是可以解决的: | ||
- | (1)使用默认编码建立数据库。这种情况下就可以直接输入中文了,但是相应的问题,就是会失去UTF-8编码的灵活性。特别是不利于软件的国际化。 | ||
- | (2)放弃命令行窗口登录MySQL,使用图形化客户端。客户端工具可以MySQL的官方网站上找到。 | ||
- | </code> |