(有什么问题欢迎指教,企鹅:2172243813 更多资讯尽在通天源码论坛)
假如MySQL中的关键字在查询语句中作为列明或者表名出现,应该怎么处理。
例如
select desc from t;
一脸懵逼。尴尬。
于是乎,自己私下做了一个实验,发现了其中原因,特此分享。
创建t表,包含两个字段,id和desc
插入了三条数据
mysql> use test;
Database changed
mysql> select desc from t;
ERROR 1064 (42000): You have an error in your SQL syntax; check themanual that corresponds to your MySQL server version for the rightsyntax to use near 'desc from t' at line 1
果然出错了,其实出现这个错误的原因是desc这个单词是mysql数据库的关键字,所以sql语句执行到这里的时候觉得语句有问题。
处理方式,在列名字前后加上如下所示的符号
mysql> select `desc` from t;
+--------------+
|desc <div id="sina_keyword_ad_area2" newfont_family"=""> |
+--------------+
|23234 |
| klsadjflkasj |
|你好 |
+--------------+
3 rows in set (0.00 sec)<div newfont_family"="">
<div newfont_family"="">本文来自苦逼IT小子的新浪博客
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。