首页 热点资讯 义务教育 高等教育 出国留学 考研考公

sql语句查询出现错误:unknown column,但是语句字段确实存在。很多语句都有这个错误

发布网友 发布时间:2022-04-26 18:40

我来回答

5个回答

热心网友 时间:2023-10-21 12:37

是多表查询,其中两个以上的表有同名的字段,在语句中没指明哪个表。

所以是unknowncolumn,SQL不知道是哪个表的字段。

在检查SQL语句完全无误后,可以检查下表中的数据类型设置或者字符编码格式,比如在出现这个错误时,常常因为数据库使用的是gbk格式,但是字段是utf8编码格式的,表中字段编码格式不同,导致了这个错误。

扩展资料:

SQL是操作数据库数据的结构化查询语言,网页的应用数据和后台数据库中的数据进行交互时会采用SQL。而SQL注入是将Web页面的原URL、表单域或数据包输入的参数,修改拼接成SQL语句,传递给Web服务器,进而传给数据库服务器以执行数据库命令。

如Web应用程序的开发人员对用户所输入的数据或cookie等内容不进行过滤或验证(即存在注入点)就直接传输给数据库,就可能导致拼接的SQL被执行,获取对数据库的信息以及提权,发生SQL注入攻击。

参考资料来源:百度百科-sql注入

热心网友 时间:2023-10-21 12:37

应该是多表查询,其中两个以上的表有同名的字段,在语句中没指明哪个表。
所以是unknown column,SQL不知道是哪个表的字段。追问原来是字段多了一个空格。

热心网友 时间:2023-10-21 12:38

我也遇到了这个问题,已经解决了。
假设你是从3张表中取数据列(这些数据列分散在三张表中,表之间通过这些数据连接),而你select时只打印其中一部分数据(这部分需打印的数据只在3张表中的某2张之中),那么第三张表也必须在from子句中说明,不然就会提示unknow column

热心网友 时间:2023-10-21 12:38

写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";

热心网友 时间:2023-10-21 12:39

如果单表查询 那有可能是 列的字段名前面有空格 可以检查下

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com