您好,欢迎访问一九零五行业门户网

mysql /*! */的含义_MySQL

bitscn.com
mysql /*! */的含义
在mysql的sql语句或sql文件经常看到如下用户:select /*!40001 sql_cache */ * from pre_common_syscache where cname in ('ipbanned')/*!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 */;
这只是一个hint啊。40001 sql_cache, 意味着数据库要缓存整个sql语句。还有sql_no_cache的hint
/* ....  */ 在大部分语言中都一样是注释。这个之中的语句是不被执行的。但mysql中 为了保持兼容,比如从mysqldump 导出的sql语句能被其它数据库直接使用,它把一些特有的仅在mysql上的语句放在 /*! ... */ 中,这样这些语句如果在其它数据库中是不会被执行,但在mysql中它会执行。
1.8.4. mysql对标准sql的扩展mysql服务器包含一些其他sql dbms中不具备的扩展。注意,如果使用了它们,将无法把代码移植到其他sql服务器。在某些情况下,你可以编写包含mysql扩展的代码,但仍保持其可移植性,方法是用“/*... */”注释掉这些扩展。在本例中,mysql服务器能够解析并执行注释中的代码,就像对待其他mysql语句一样,但其他sql服务器将忽略这些扩展。例如: select /*! straight_join */ col_name from table1,table2 where ...如果在字符“!”后添加了版本号,仅当mysql的版本等于或高于指定的版本号时才会执行注释中的语法: create /*!32302 temporary */ table t (a int);这意味着,如果你的版本号为3.23.02或更高,mysql服务器将使用temporary关键字。
bitscn.com
其它类似信息

推荐信息