发布网友 发布时间: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
如果单表查询 那有可能是 列的字段名前面有空格 可以检查下