sql语句查询出现错误:unknown column,但是语句字段确实存在。很多语句都有这个错误
7个回答
展开全部
是多表查询,其中两个以上的表有同名的字段,在语句中没指明哪个表。
所以是unknowncolumn,SQL不知道是哪个表的字段。
在检查SQL语句完全无误后,可以检查下表中的数据类型设置或者字符编码格式,比如在出现这个错误时,常常因为数据库使用的是gbk格式,但是字段是utf8编码格式的,表中字段编码格式不同,导致了这个错误。
扩展资料:
SQL是操作数据库数据的结构化查询语言,网页的应用数据和后台数据库中的数据进行交互时会采用SQL。而SQL注入是将Web页面的原URL、表单域或数据包输入的参数,修改拼接成SQL语句,传递给Web服务器,进而传给数据库服务器以执行数据库命令。
如Web应用程序的开发人员对用户所输入的数据或cookie等内容不进行过滤或验证(即存在注入点)就直接传输给数据库,就可能导致拼接的SQL被执行,获取对数据库的信息以及提权,发生SQL注入攻击。
参考资料来源:百度百科-sql注入
展开全部
应该是多表查询,其中两个以上的表有同名的字段,在语句中没指明哪个表。
所以是unknown column,SQL不知道是哪个表的字段。
所以是unknown column,SQL不知道是哪个表的字段。
追问
原来是字段多了一个空格。
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
我也遇到了这个问题,已经解决了。
假设你是从3张表中取数据列(这些数据列分散在三张表中,表之间通过这些数据连接),而你select时只打印其中一部分数据(这部分需打印的数据只在3张表中的某2张之中),那么第三张表也必须在from子句中说明,不然就会提示unknow column
假设你是从3张表中取数据列(这些数据列分散在三张表中,表之间通过这些数据连接),而你select时只打印其中一部分数据(这部分需打印的数据只在3张表中的某2张之中),那么第三张表也必须在from子句中说明,不然就会提示unknow column
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
写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";
如写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";
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
如果单表查询 那有可能是 列的字段名前面有空格 可以检查下
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询