sql语句查询出现错误:unknown column,但是语句字段确实存在。很多语句都有这个错误
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql语句查询出现错误:unknown column,但是语句字段确实存在。很多语句都有这个错误相关的知识,希望对你有一定的参考价值。
是多表查询,其中两个以上的表有同名的字段,在语句中没指明哪个表。
所以是unknowncolumn,SQL不知道是哪个表的字段。
在检查SQL语句完全无误后,可以检查下表中的数据类型设置或者字符编码格式,比如在出现这个错误时,常常因为数据库使用的是gbk格式,但是字段是utf8编码格式的,表中字段编码格式不同,导致了这个错误。
扩展资料:
SQL是操作数据库数据的结构化查询语言,网页的应用数据和后台数据库中的数据进行交互时会采用SQL。而SQL注入是将Web页面的原URL、表单域或数据包输入的参数,修改拼接成SQL语句,传递给Web服务器,进而传给数据库服务器以执行数据库命令。
如Web应用程序的开发人员对用户所输入的数据或cookie等内容不进行过滤或验证(即存在注入点)就直接传输给数据库,就可能导致拼接的SQL被执行,获取对数据库的信息以及提权,发生SQL注入攻击。
参考资料来源:百度百科-sql注入
参考技术A 应该是多表查询,其中两个以上的表有同名的字段,在语句中没指明哪个表。所以是unknown column,SQL不知道是哪个表的字段。追问
原来是字段多了一个空格。
本回答被提问者和网友采纳 参考技术B 我也遇到了这个问题,已经解决了。假设你是从3张表中取数据列(这些数据列分散在三张表中,表之间通过这些数据连接),而你select时只打印其中一部分数据(这部分需打印的数据只在3张表中的某2张之中),那么第三张表也必须在from子句中说明,不然就会提示unknow column 参考技术C 写sql语句时语句里面没有空格或多了空格导致的。
如写sql的时候正常是这样:
"select student_id,student_name,student_age,student_gender from student";
如果你在idea里sql语句有换行:
"select student_id,student_name,student_age,student_gender" +
"from student";
写成这样是不对的,会导致gender和from之间没有了空格,误认为一块了。正确写法是在gender后面或者from前面加一个空格:
"select student_id,student_name,student_age,student_gender " +
"from student"; 参考技术D 如果单表查询 那有可能是 列的字段名前面有空格 可以检查下
mysql查询语句提示Unknown column 'zp' in 'where clause',求解!
adm表中username、password两个字段中,分别插入('zp','111')和('111','zp')两条数据,运行查询语句select * from adm where username=zp;和select * from adm where password=zp;都会出现如题所示错误。而where条件查询'111’却不会出现错误。也就是说只能查询数值型的,不能查询字符串型的。请高人指点一二,不甚感激!书写的时候数据库表名、字段名、查询的值都是正确的,且与引号什么的都无关。
这两个字段都是varchar类型的,后来改为char类型,也是同样错误。貌似与字段类型无关。郁闷!
这个改为
select * from adm where username=’zp‘
就可以了,这样才是查询字符串型的本回答被提问者和网友采纳
以上是关于sql语句查询出现错误:unknown column,但是语句字段确实存在。很多语句都有这个错误的主要内容,如果未能解决你的问题,请参考以下文章
MySQLjava.sql.SQLException:Unknown column ‘****‘ in ‘where clause‘错误问题原因以及如何解决?
MySQLjava.sql.SQLException:Unknown column ‘****‘ in ‘where clause‘错误问题原因以及如何解决?
使用 AS 语句的 Google App 脚本中的多行查询 SQL 出现“<ID>”错误
mysql 的 Unknown column '6' in 'order clause' 这是啥错误啊!! 高手们帮个忙啊!!!