@Override public DataListPage
String mainStoreId = BusinessUtils.getMainStoreId(branchStoreId); String listHql = CONSTRUCTOR + " FROM TCmsLesson cl, TCmsLessonStoreRel r" + " WHERE cl.firstClass = :firstClass" + " AND cl.isValid = 1" + " AND cl.id = r.lessonId" + " AND r.storeId in (:mainStoreId , :branchStoreId , '0000000')"; String countHql = "SELECT COUNT(cl.id) FROM" + " TCmsLesson cl, TCmsLessonStoreRel r" + " WHERE cl.firstClass = :firstClass" + " AND cl.isValid = 1" + " AND cl.id = r.lessonId" + " AND r.storeId in (:mainStoreId , :branchStoreId , '0000000')"; dataListParams.setDateParam("cl.createDate"); return super.getDataListPageByHql(listHql, countHql, dataListParams, firstClass, mainStoreId, branchStoreId); } private List<T> listDataByHql(String hql, DataListParams dataListParams, Object... values) { if (StringUtils.isNotEmpty(dataListParams.getBeginTime()) && StringUtils.isNotEmpty(dataListParams.getEndTime())) { hql = hql + " AND " + dataListParams.getDateParam() + " BETWEEN '" + dataListParams.getBeginTime() + "' AND '" + dataListParams.getEndTime() + "'"; } else if (StringUtils.isNotEmpty(dataListParams.getBeginTime())) { hql = hql + " AND " + dataListParams.getDateParam() + " >= '" + dataListParams.getBeginTime() + "'"; } else if (StringUtils.isNotEmpty(dataListParams.getEndTime())) { hql = hql + " AND " + dataListParams.getDateParam() + " <= '" + dataListParams.getEndTime() + "'"; } if (StringUtils.isNotEmpty(dataListParams.getOrderBy())) { hql = hql + " ORDER BY " + dataListParams.getOrderBy(); } if (dataListParams.isDesc()) { hql = hql + " DESC"; } if (dataListParams.getPage() != null) { return this.listByPage(hql, dataListParams.getPage(), values); } else { return dataListParams.getSize() == 0 ? this.listByParamsAndPosition(hql, dataListParams.getStartPosition(), values) : this.listBySizeAndPosition(hql, dataListParams.getSize(), dataListParams.getStartPosition(), values); } }
1 Kirsk 2020-10-27 12:15:54 +08:00 via Android 罗里八嗦 直接删掉 类型控制应该在逻辑层 dao 只负责执行 |
![]() | 2 chendy 2020-10-27 12:18:28 +08:00 很有毅力 试试 Criteria ? |
![]() | 3 geligaoli 2020-10-27 12:46:24 +08:00 ![]() 用字符串拼 sql 的,直接开 |
![]() | 4 rodrick 2020-10-27 12:52:29 +08:00 虽然很久不搞 java 你要小项目简单 sql 这么搞搞就算了,正规项目这么搞不说别的,写起来不累么,看的都累 |
![]() | 5 EscYezi 2020-10-27 12:52:58 +08:00 via iPhone 以后维护起来很蛋疼 |
6 wilsonWei 2020-10-27 13:26:49 +08:00 字符串拼接有注入风险吧,看起来也不清晰 |
7 THESDZ 2020-10-27 13:41:44 +08:00 如果一段代码让人看下去的欲望都没有,还是算了吧.... |
![]() | 9 Resource 2020-10-27 13:47:14 +08:00 不可取 |
10 zouzou0208 2020-10-27 13:47:38 +08:00 这样拼接并且不做保护的话很容易注入的。在 para 里加个 or 1=1 后面就可以加东西了。 |
12 zouzou0208 2020-10-27 13:51:41 +08:00 @madworks 那样一般都有正则或者其他的保护的。 |
13 THESDZ 2020-10-27 13:53:09 +08:00 @madworks 框架层面的一般是基于反射或者代理等,每一个方法进行封装,查看主体逻辑的时候,配合注释(方法上的 javadoc)看起来并不会难受,而上面的代码,从列名到表名都是手敲的.... |
![]() | 14 supuwoerc 2020-10-27 13:55:42 +08:00 作为前端路过,刚学完预编译 sql,这样拼接字符串是不是会出现 sql 注入的问题,而且看着好累啊 =。=|| |
16 THESDZ 2020-10-27 14:00:52 +08:00 @madworks 是指题目中的代码?hibernate 了解不多,但是据我了解它的目的是让程序员不写 sql,hibernate 应该不会这么写,最起码业务内容和转 sql 是分开考虑的,不会根据逻辑拼接 sql |
![]() | 17 fallinlovewith 2020-10-27 14:18:21 +08:00 见过用 String sql = " "+ " "+ "...."; 也见过 StringBuilder sb = new StringBuilder(); sb.append("") .append("") ...... |
18 fengpan567 2020-10-27 14:31:54 +08:00 这么拼接不怕 sql 注入? |
![]() | 19 buruliu 2020-10-27 14:36:26 +08:00 hql 。 |
![]() | 20 doudou1523102 2020-10-27 14:47:06 +08:00 看的头痛 |
![]() | 21 nxforce 2020-10-27 14:50:34 +08:00 内部小项目这样子搞没太大问题,商业项目这样子,早晚推倒重做。 |
22 lonelymarried 2020-10-27 14:58:35 +08:00 我刚学 java,如果复杂的查询不这样写,那么怎么写呢。学习一下。 |
![]() | 23 la2la 2020-10-27 15:04:10 +08:00 我们公司的项目部分接口就是这么搞得,看的脑壳疼。但是领导都没说什么,我还能做啥呢 |
![]() | 24 somefree 2020-10-27 15:29:19 +08:00 这一看都是上古时期的代码了, 跟我以前的公司代码有的一拼 |
![]() | 25 fatpower 2020-10-27 15:33:41 +08:00 ![]() 这个不是 sql,是 hql 。 上古时期的代码都这样 |
![]() | 26 weizhen199 2020-10-27 16:04:48 +08:00 你们仔细看看,我咋觉得这 sql 参数化了?? |
27 madworks OP @weizhen199 什么叫 sql 参数化 |
![]() | 28 a719031256 2020-10-27 16:21:54 +08:00 人才。。 |
30 aguesuka 2020-10-27 17:45:43 +08:00 via Android 好不好不评价,给几个建议。String hql=前一句加上 // language=HQL (sql jpaql 同理)。参数使用冒号加参数名的格式,然后用 setparammap 或者 setpropsobject 设置参数的值。参数和返回值加上泛型。 java 的 orm 包括不限于 jpa mybatis springtemplate 都不咋地,在面相对象而且自省能力这么弱的语言里发明一种代替 sql 的 dsl 是不可能的。 我能想到的最好办法是整合项目设计的时候不考虑 sql,专门招聘一个实习生来写 dao 层。 |
![]() | 31 meepo3927 2020-10-27 17:59:16 +08:00 嗯…… 这个换行风格,看着好难受 |
![]() | 32 akira 2020-10-27 18:07:00 +08:00 不可取。 现在应该都放弃这种写法了吧。 可维护性不是很好 |
33 jin7 2020-10-28 00:06:34 +08:00 看着麻烦 |
![]() | 34 Joker123456789 2020-11-12 11:15:00 +08:00 首先,你如果问的是把 sql 写在类里面 这种方式可不可取,那我个人认为把 sql 写类里面,和写 xml 里没啥区别, 现在都是 boot 打 jar 包,即使写在 xml 里 也是无法在线上更改的。 无论写哪,只要牵扯到改,都要程序员改完提测 然后重新打包发布,所以写类和写 xml 已经没有本质区别了。 所以,这种写法我个人认为完全没问题,不过肯定会有一些 盲目遵守规范的人 会说不行, 这个就不做争论了。。 其次,如果你问的这你贴出来的这段代码有没有问题,那么其他人已经都告诉你了,你需要让代码分布的更合理一点,然后参数不要拼接,要用占位符。 |
![]() | 35 ly61 2020-11-19 17:13:18 +08:00 自己写爽不爽我不知道,但是后面维护的人肯定很爽 |