2018年1月 mybatis+ 动态sql连续日期
2018-01-111 、 如何在项目中快速查找对应的mapper.xml文件
从Controller入手,使用(Ctrl+鼠标左键)找到Service调用的方法,再找到底层方法,就能找到对应mapper.或者。还有一个比较偷懒的方法,如果@RequestMapping/@GetMapping/@PostMapping等注解的方法名与bean的id一样,可以使用IDEA中Ctrl+h进行项目内搜索,这个方法不建议,被前辈批评过。- 2、.xml文件中特殊字符>、<、>=、<=、"、‘会报错。
- 贴一个技术文档: 建议经常查阅 http://www.w3school.com.cn
解决:
(1)、使用转移字符:
< 可以使用 & lt ; 进行替换
例如:
<age> age < 30 </age>
上面这种写法会报错,应该这样写:
<age> age & lt ; 30 </age>

(2)、使用CDATA区:以"<![CDATA[ "开始,以" ]]>" 结束,在两者之间嵌入不想被解析程序解析的原始数据,解析器不对CDATA区中的内容进行解析。
例如:
rownum <=1 可以使用 rownum<![CDATA[<=1 ]]> (1可以放在外面) 进行替换
细致详解链接:
https://www.cnblogs.com/o-andy-o/p/3586159.html
http://blog.csdn.net/jihuanliang/article/details/7980844
http://blog.csdn.net/qq_28587263/article/details/54138998
3、在项目中我们会遇见根据时间去查找记录,有时候一年中只有个别几个月有数据的情况,而我们又希望看到连续的年、月、日可以使用以下方法。
将自己查询的select SQL与以下查询合并(使用union all的速度要比union快):
Oracle中常用的函数:
TO_CHAR 是把日期或数字转换为字符串;
TO_DATE 是把字符串转换为数据库中得日期类型转换函数;
TO_NUMBER 将字符转化为数字;
(1)、年份
select '2016'+rownum-1 as A(用个别名)
from dual
connect by rownum <= (2018 - 2016)+1 ;
一般日期是从前台传过来可以使用:
select #{begintime} + rownum-1 as A(用个别名)
from dual
connect by rownum <= ( #{endtime} - #{begintime})+1 ;
其中:SELECT ROWNUM FROM DUAL CONNECT BY ROWNUM <= N 可以生成1到N的整数序列,N是想要生成的序列的个数,可以是整数,也可以是查询得出的整 数,例如:
SELECT TO_CHAR(ADD_MONTHS(TO_DATE('201710', 'yyyyMM'), ROWNUM - 1), 'yyyyMM') as A
FROM DUAL
CONNECT BY ROWNUM <= months_between(to_date('201806', 'yyyyMM'), to_date('201710', 'yyyyMM')) + 1;
(3)、日
显示8位:
SELECT TO_CHAR(TO_DATE('20141001', 'yyyyMMdd') + ROWNUM - 1, 'yyyyMMdd') as A
FROM DUAL
CONNECT BY ROWNUM <= runc(to_date('20150601', 'yyyyMMdd') - to_date('20141001', 'yyyyMMdd')) + 1;
(只截取日)显示2位:
(表1包含tjr字段,该字段只有两位的日期)
select tjr from 表1 union all
SELECT tjr from (select TO_CHAR( TRUNC( to_date('20160701', 'yyyyMMdd' ), 'MM' ) + ROWNUM - 1, 'yyyyMMdd' ) AS tjr
FROM DUAL CONNECT BY
ROWNUM <=TO_NUMBER(TO_CHAR( LAST_DAY( TO_DATE('201607', 'yyyyMM' )), 'dd' )))
(4)、小时
SELECT to_date('2013-07-01 12', 'yyyy-mm-dd hh24') + (ROWNUM - 1) / 24 sdate
FROM dual
CONNECT BY ROWNUM <= (to_date('2013-07-02 22', 'yyyy-mm-dd hh24') - to_date('2013-07-01 12', 'yyyy-mm-dd hh24')) * 24 + 1
参考:
https://www.2cto.com/database/201506/404733.html
http://blog.csdn.net/itx2000/article/details/56846121
http://blog.csdn.net/ld422586546/article/details/9626921/
2018年1月 mybatis+ 动态sql连续日期的更多相关文章
- mybatis实战教程(mybatis in action)之八:mybatis 动态sql语句
mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类:1. if 语句 (简单的条件判断)2. c ...
- 9.mybatis动态SQL标签的用法
mybatis动态SQL标签的用法 动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么 ...
- 自己动手实现mybatis动态sql
发现要坚持写博客真的是一件很困难的事情,各种原因都会导致顾不上博客.本来打算写自己动手实现orm,看看时间,还是先实现一个动态sql,下次有时间再补上orm完整的实现吧. 用过mybatis的人,估计 ...
- Mybatis动态SQL单一基础类型参数用if标签
Mybatis动态SQL单一基础类型参数用if标签时,test中应该用 _parameter,如: 1 2 3 4 5 6 <select id="selectByName" ...
- 超全MyBatis动态SQL详解!( 看完SQL爽多了)
MyBatis 令人喜欢的一大特性就是动态 SQL. 在使用 JDBC 的过程中, 根据条件进行 SQL 的拼接是很麻烦且很容易出错的. MyBatis 动态 SQL 的出现, 解决了这个麻烦. My ...
- Mybatis动态SQL简单了解 Mybatis简介(四)
动态SQL概况 MyBatis 的强大特性之一便是它的动态 SQL 在Java开发中经常遇到条件判断,比如: if(x>0){ //执行一些逻辑........ } Mybatis应用中,S ...
- mybatis原理分析学习记录,mybatis动态sql学习记录
以下个人学习笔记,仅供参考,欢迎指正. MyBatis 是支持定制化 SQL.存储过程以及高级映射的持久层框架,其主要就完成2件事情: 封装JDBC操作 利用反射打通Java类与SQL语句之间的相互转 ...
- mybatis 动态sql和参数
mybatis 动态sql 名词解析 OGNL表达式 OGNL,全称为Object-Graph Navigation Language,它是一个功能强大的表达式语言,用来获取和设置Java对象的属性, ...
- MyBatis动态SQL之一使用 if 标签和 choose标签
bootstrap react https://segmentfault.com/a/1190000010383464 xml 中 < 转义 to thi tha <if test=&qu ...
随机推荐
- 不同ios系统下mainscreen的applicationFrame和bounds值測试
打印结果(横屏,3.5寸.若4寸则最后一项对应添加) ios6: 2014-04-26 10:57:12.300 testAccount[18525:907] applicationFrame: {{ ...
- [hdu 4869](14年多校I题)Turn the pokers 找规律+拓欧逆元
Turn the pokers Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- 给新手--安装tomcat后username和password设置以及项目怎么部署在tomcatserver上
安装后tomcatserver后.登陆首先就是让输入username和password.但是我们在安装tomcat的过程中好像没有让设置username和password,这时候可能有人就抓狂了.还有 ...
- 资深实践篇 | 基于Kubernetes 1.61的Kubernetes Scheduler 调度详解
欢迎大家前往腾讯云技术社区,获取更多腾讯海量技术实践干货哦~ 作者:腾讯云容器服务团队 源码为 k8s v1.6.1 版本,github 上对应的 commit id 为 b0b7a323cc5a4a ...
- 基于低代码平台(Low Code Platform)开发中小企业信息化项目
前言:中小企业信息化需求强烈,对于开发中小企业信息化项目的软件工作和程序员来说,如何根据中小企业的特点,快速理解其信息化项目的需求并及时交付项目,是一个值得关注和研讨的话题. 最近几年来,随着全球经济 ...
- 项目实战12.1—企业级监控工具应用实战-zabbix安装与基础操作
无监控,不运维.好了,废话不多说,下面都是干货. 警告:流量党勿入,图片太多!!! 项目实战系列,总架构图 http://www.cnblogs.com/along21/p/8000812.html ...
- 查看SQL Server当前会话的隔离级别
查看SQL Server当前会话的隔离级别 DBCC USEROPTIONS
- 学习Git的最佳资料
1. ProGit中文版:https://git-scm.com/book/zh/v2 2. 廖雪峰的Git教程: http://www.liaoxuefeng.com/wiki/0013739516 ...
- css:background-position > 精灵技术
background-position : length || length background-position : position || position 取值: length : 百分数 ...
- C#生成缩略图 (通用模式)
用数据库保存图片的路径和文件名称,把文件保存在文件夹中.//保存在数据库中的文件路径ArrayList arrFilePath=new ArrayList();arrFilePath=myCommon ...