sql关于对一个字段同时满足多条件判断来筛选查询
表所有数据
查询userName为abc或xyz的
以下为本菜鸟项目中遇到的问题:
背景:
/**
* wangjie 180629
*
* 学生需要查询四种可能的消息
* 1.班级管理员发来的,根据自身的学籍号条件查询
* 2.省级管理员发送区县全部的,根据接收对象地区号作为条件查询
* 3.省级管理员发送全省全部的,根据接收对象类型为"all"查询
* 4.省级管理员发送全市全部的,根据接收对象市id查询
*
* */
例子
问个sql语句问题,比如如何查出
name为小红的
或者
name为小黑并且sex为男的
以上两个条件拼接一条语句写出来
/**
* 接收到的学习纪实--分页
* @param pageNumber
* @param pageSize
* @param map
* @return
*/
@Override
public Pagenate<StudyRecordTableEntity> pageforAcceptStudyTableEntity(
int pageNumber, int pageSize, Map<String, String> map) {
// map传过来的值:{classCode=5051, acceptcode=15040602011, titles2=, role=03, pointId=0482, cityCode=3704, classAdminCode=null, ydrq12=, ydrq22=}
// TODO Auto-generated method stub
String titles2=map.get("titles2"); //标题
String ydrq12=map.get("ydrq12"); //开始日期
String ydrq22=map.get("ydrq22"); //结束日期
String acceptcode=map.get("acceptcode");//接收人编号
/**
* wangjie 180629
*
* 学生需要查询四种可能的消息
* 1.班级管理员发来的,根据自身的学籍号条件查询
* 2.省级管理员发送区县全部的,根据接收对象地区号作为条件查询
* 3.省级管理员发送全省全部的,根据接收对象类型为"all"查询
* 4.省级管理员发送全市全部的,根据接收对象市id查询
*
* */
// 接收区县---区县id
String point_id = map.get("pointId");
// 接收市id
String city_id = map.get("cityCode");
Session session = super.getHibernateTemplate().getSessionFactory().getCurrentSession();
StringBuffer sb=new StringBuffer();
// 学员接收信息
sb.append(" from StudyRecordTableEntity srt,StudyRecAcceptRoleEntity accept,SysAccCount account where srt.id=accept.sturec_code and account.accCode=srt.sendopt ");
sb.append(" and accept.accrole='03' and srt.flag='1' ");
sb.append(" and ( accept.send_type='single' and ( accept.accept_range like '%"+acceptcode+"%' or accept.accept_range like '%"+point_id+"c%' or accept.accept_range like '%"+city_id+"%' ) ");
sb.append(" or accept.send_type='all' ) ");
if(titles2!=null&&!"".equals(titles2)){
sb.append(" and srt.titles like '%"+titles2+"%' ");
}
if(ydrq12!=null&&!"".equals(ydrq12)){
sb.append(" and srt.sdate >= '"+ydrq12+"' ");
}
if(ydrq22!=null&&!"".equals(ydrq22)){
Calendar calendar=new GregorianCalendar();
calendar.setTime(DateUtils.parseDate(ydrq22, "yyyy-MM-dd"));
calendar.add(calendar.DATE, 1);
sb.append(" and srt.sdate < '"+DateUtils.formateDate(calendar.getTime(), "yyyy-MM-dd")+"' ");
}
String hqlCnt="select count(0) "+sb.toString();
String hql="select srt "+sb.toString()+" order by srt.sdate desc,srt.sturec_type asc ";
System.out.println("拼接的sql---->"+hql);
Query queryCnt=session.createQuery(hqlCnt);
Query query=session.createQuery(hql);
return super.findByPage(pageNumber, pageSize, queryCnt, query);
}
后台是hql语句查询的,刚开始没想起来,急的我差点写四个sql分别查询
一个同胞的:
sql关于对一个字段同时满足多条件判断来筛选查询的更多相关文章
- sql server中将一个字段根据某个字符拆分成多个字段显示
sql server 数据库中某张表(Person)的数据信息是: ID Address 1 平山花园-4单元-12幢-203 2 香山花园-3单元-22幢-304 现在有需求是,将地址信息显示形式改 ...
- MYSQL: sql中某一个字段内容为用逗号分割的字符串转换成多条数据
场景: 表名:testsuer id name 1 小红,小李,李红,小法 要结果值为: 1 小红 1 小李 1 李红 1 小法 MYSQL函数解释 ...
- [SQL]SQL中把一个字段的数据分多行显示
其实你完全可以写个自定义函数就OK了 . =================================================================== create func ...
- sql根据某一个字段重复只取第一条数据
比如上图,取3,4行记录的第一行也就是3行,而不返回4行. 使用分析函数row_number() over (partiion by ... order by ...)来进行分组编号,然后取分组标号值 ...
- SQL 批量修改一个字段的值为另一个字段的值
AND create_time BETWEEN '2016-07-25 14:30:00' AND '2016-07-25 15:20:28'; AND create_time BETWEEN '20 ...
- sql中使一个字段升序,一个字段降序
ORDER BY _column1, _column2; /* _column1升序,_column2升序 */ ORDER BY _column1, _column2 DESC; /* _colum ...
- 一个list<Map>里map其中的一个字段的值相同,如何判断这个字段相同,就把这个map的其他字段存入另一个map中
//不建议使用Map保存这些,使用实体bean更好 package com.rxlamo.zhidao; import java.util.*; public class Main { ...
- SQL利用Case When Then Else End 多条件判断
Select Case When a is not null then a When b is not null then b When c is not null then c When d is ...
- And【sql语句之为何用and一个字段两个值得不到表中的数据】
一.[一个表的一个字段的多个条件用and连接] 用and是查不到值的, and是多个条件同时成立, 也就是一个字段是不能同时等于两个值的. '; 二[相同两个表的两个相同字段的查询用and连接] '; ...
随机推荐
- laravel 多对多关联 attach detach sync
用户表和角色表,多对多关联,一个用户有多个角色,一个角色属于多个用户 添加多对多关联 attach: 给1号用户添加1号角色,并把关联表的column字段赋值为$value,后边的数组需要的时候再添加 ...
- Linux基础三:linux目录结构和目录文件的浏览、管理及维护
目录文件的浏览.管理及维护(一) 1.Linux文件系统的层次结构 1)Linux文件系统的树状结构:在Linux或UNIX操作系统中,所有的文件和目录都被组织成一个以根节点开始的倒置的树状结构. 2 ...
- Linux之man命令详解及中文汉化
使用方法 Linux man中的man就是manual的缩写,用来查看系统中自带的各种参考手册 使用方法: man command 示例: [root@VM_0_13_centos ~]# man l ...
- tomcat启动报错 关键字:java.lang.NoClassDefFoundError和 java.lang.ClassNotFoundExceeption
启动tomcat时报错情况如下图所示:实际上就是依赖的bean出错,百度上很多方法都说是tomcat没有部署正确,项目-->右键----->proterties----->Targe ...
- python发送邮件(在邮件中显示HTMLTestRunner生成的报告)
import smtplib from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart f ...
- Django系列(一)
项目引入静态文件 更改settings.py,为项目下面的每个APP应用,建立静态文件,这里如blog,首先在blog下面建立一个静态文件夹名为statics,注意这里为别名 STATICFILES_ ...
- What is base..ctor(); in C#?
I am disassembling some C# applications and I am trying to reconstruct the source code. I am disasse ...
- .NetCore 下开发独立的(RPL)含有界面的组件包 (四)授权过滤
.NetCore 下开发独立的(RPL)含有界面的组件包 (一)准备工作 .NetCore 下开发独立的(RPL)含有界面的组件包 (二)扩展中间件及服 务 .NetCore 下开发独立的(RPL)含 ...
- BETA准备
过去存在的问题 文档问题 未能事先做好设计文档,且小程序与后端数据库接口存在问题 界面问题 原型图设计花的时间较少,小程序设计界面仍相对粗糙,前端成员css元素应用经验不足 小程序界面之间对接存在问题 ...
- request.user哪里来的?
1.登录认证(auth认证登录后login后设置了session等信息包含用户的pk) >>>>> 2.用户再次请求登录的时候,通过 ...