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

 我来答
帐号已注销
2020-11-07 · TA获得超过77.1万个赞
知道小有建树答主
回答量:4168
采纳率:93%
帮助的人:168万
展开全部

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

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

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

扩展资料:

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

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

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

gongjiaxiang50
推荐于2017-12-16 · TA获得超过3171个赞
知道大有可为答主
回答量:2432
采纳率:50%
帮助的人:1109万
展开全部
应该是多表查询,其中两个以上的表有同名的字段,在语句中没指明哪个表。
所以是unknown column,SQL不知道是哪个表的字段。
追问
原来是字段多了一个空格。
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友58bcdb123
2019-01-14
知道答主
回答量:16
采纳率:0%
帮助的人:6.1万
展开全部
我也遇到了这个问题,已经解决了。
假设你是从3张表中取数据列(这些数据列分散在三张表中,表之间通过这些数据连接),而你select时只打印其中一部分数据(这部分需打印的数据只在3张表中的某2张之中),那么第三张表也必须在from子句中说明,不然就会提示unknow column
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
无聊才来于此
2021-10-14
知道答主
回答量:2
采纳率:0%
帮助的人:1061
展开全部
写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";
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
p游乐d
2021-03-18 · TA获得超过178个赞
知道答主
回答量:4
采纳率:0%
帮助的人:2257
展开全部
如果单表查询 那有可能是 列的字段名前面有空格 可以检查下
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 3条折叠回答
收起 更多回答(5)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式