mysql order by 如何自定义列?
SELECT a, b, c, d FROM table ORDER BY a DESC;
order by 是动态的根据传入的 a,b,c,d 带进去的。
我从 orm 插入后是个字符串.....
SELECT a, b, c, d FROM table ORDER BY 'a' DESC;
啥语言 哪个 orm 库
写法取决于你用的 orm 库
入参做了严格检验的话,字段可以用 sql 注入
java mybatis 的话是 ${} 和 #{} 的区别
直接拼接上去,不要用 preparedstatement 噢,注意限制字段
字符串拼接
整个查询语句包裹一层,然后后重新使用 order by 对别名列排序
mybatis 的话 用#{}就会有这个问题
order by 后面的列,只能是拼接 SQL 拼接上去,不能用预编译后再设置参数。
golang 的 gorm,用?拼上去的。
好像看来只能用拼字符串了。会不会出现注入问题啊
从官方文档来看: dev.mysql.com/doc/refman/8.0/en/select.html
[ORDER BY {col_name | expr | position}
[ASC | DESC], ... [WITH ROLLUP]]
这里 order by 只接收 3 种形式:
- 字段名,包含 alias ; 支持用
包裹,例如a`; - expr 表达式,例如 concat(a, b)
- position,数字引用,例如 1,表示第一个 select 字段。
就目前问题描述来看,如果 SQL 是最终执行的语句,会解析为第二种。
即所有行的表达式都是常量 'a',这个 order by 等于无效。
拼一下
注意注入, 不要让外部传入这个拼的东西, 或者内部做校验
哦
表弟今年高考录的广州新华学院,不清楚学校教学水平怎么样,但是根据今年的招聘形式来看,就业是没法指望学校的 我对他的建议是,因为原先英语成绩还行,也有学习兴趣,就继续提高外语能…
大家好,我是长沙林更新,去年 10 月入职了一家外包公司,面试和入职都是在甲方公司,现工作一年多,甲方因明年的外包预算/内部全自研/转内部卡名额等原因退项,在此我也把维权的经历…
需求:有 10 亿左右的数据需要做查询,想在毫秒内返回匹配结果 存入的内容如下 id cardno name short createtime 1 Dkmy48k7afjs…
合速度