【转】mysql4.x版本数据导入5.x版本问题
2016-02-01 16:49
656 查看
转载自:http://blog.csdn.net/yeruby/article/details/44618791
我的机器上mysql编码格式:
打开需要移植的.sql文件,发现在开头和结尾有如下语句:
开头:
[sql] view
plaincopyprint?
<span style="font-size:18px;"><span style="font-size:18px;">/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;</span></span>
结尾:
[sql] view
plaincopyprint?
<span style="font-size:18px;"><span style="font-size:18px;">/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;</span></span>
值得注意的是,.sql中加“#”的才是注释性语句,所以上面这些都是功能性语句。
/* .... */ 在大部分语言中都一样是注释,这个之中的语句是不被执行的。
但是MYSQL中 为了保持兼容,比如从mysqldump 导出的SQL语句能被其它数据库直接使用,它把一些特有的仅在MYSQL上的语句放在 /*! ... */ 中,这样这些语句如果在其它数据库中是不会被执行,但是在MYSQL中它会执行。
以上具体可参见:MySQL 5.1参考手册
1.8.4. MySQL对标准SQL的扩展
MySQL服务器包含一些其他SQL DBMS中不具备的扩展。注意,如果使用了它们,将无法把代码移植到其他SQL服务器。在某些情况下,你可以编写包含MySQL扩展的代码,但仍保持其可移植性,方法是用“/*... */”注释掉这些扩展。在本例中,MySQL服务器能够解析并执行注释中的代码,就像对待其他MySQL语句一样,但其他SQL服务器将忽略这些扩展。例如:
SELECT /*! STRAIGHT_JOIN */ col_name FROM table1,table2 WHERE ...
如果在字符“!”后添加了版本号,仅当MySQL的版本等于或高于指定的版本号时才会执行注释中的语法:
/*!40101 SET NAMES utf8 */;
这意味着,如果你的版本号为4.1.1或更高,MySQL服务器将使用执行上面这句代码。
所以为了避免乱码,我们将开头和结尾的7条语句删除,因为我们mysql的编码格式已经是utf8,且.sql文件中使用的编码格式也是utf8。
我的机器上mysql编码格式:
打开需要移植的.sql文件,发现在开头和结尾有如下语句:
开头:
[sql] view
plaincopyprint?
<span style="font-size:18px;"><span style="font-size:18px;">/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;</span></span>
结尾:
[sql] view
plaincopyprint?
<span style="font-size:18px;"><span style="font-size:18px;">/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;</span></span>
值得注意的是,.sql中加“#”的才是注释性语句,所以上面这些都是功能性语句。
/* .... */ 在大部分语言中都一样是注释,这个之中的语句是不被执行的。
但是MYSQL中 为了保持兼容,比如从mysqldump 导出的SQL语句能被其它数据库直接使用,它把一些特有的仅在MYSQL上的语句放在 /*! ... */ 中,这样这些语句如果在其它数据库中是不会被执行,但是在MYSQL中它会执行。
以上具体可参见:MySQL 5.1参考手册
1.8.4. MySQL对标准SQL的扩展
MySQL服务器包含一些其他SQL DBMS中不具备的扩展。注意,如果使用了它们,将无法把代码移植到其他SQL服务器。在某些情况下,你可以编写包含MySQL扩展的代码,但仍保持其可移植性,方法是用“/*... */”注释掉这些扩展。在本例中,MySQL服务器能够解析并执行注释中的代码,就像对待其他MySQL语句一样,但其他SQL服务器将忽略这些扩展。例如:
SELECT /*! STRAIGHT_JOIN */ col_name FROM table1,table2 WHERE ...
如果在字符“!”后添加了版本号,仅当MySQL的版本等于或高于指定的版本号时才会执行注释中的语法:
/*!40101 SET NAMES utf8 */;
这意味着,如果你的版本号为4.1.1或更高,MySQL服务器将使用执行上面这句代码。
所以为了避免乱码,我们将开头和结尾的7条语句删除,因为我们mysql的编码格式已经是utf8,且.sql文件中使用的编码格式也是utf8。
相关文章推荐
- 【转】mysql发展历程 各分支版本溯源
- MYSQL存储过程 游标 循环等
- MySQL和postgresql的对比
- MySQL建表规范与常见问题
- 取消pppoe后,mysql正常退出!
- mysql binlog_format 适时修改
- mysql中utf-default collation
- 如何知道mysql中sql语句索引是否生效
- MySQL常用操作
- mysql主从复制(超简单)
- mysql中的if条件语句用法
- 将SQL文件导入MySql
- 我良辰有101种MySQL的调节和优化技巧!
- MySql数据库增删改查示例
- mysql-5.7.10免安装版配置
- MySQL 触发器简单实例
- MFC通过ODBC连接Mysql程序
- 使用Navicat for MySQL创建存储过程
- 【MySQL】MySQL的基础知识与常用操作--开发手册
- wdcp后台里mysql的管理用户root密码不对或修改方法介绍