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 里面结合关联查询 的when()用法
Laravel 5.6 里面的when用法: $name = $request->get('name'); //活动标题 $start_time = $request->get('star ...
- LabView(控件部分)
1.虚拟仪器的概述: 虚拟仪器是基于计算机的的仪器,计算机和仪器的密切结合是目前仪器的一个发展方向,大概有两种结合方式,一种是将计算机装入仪器中,实例就是只能化的仪器,流行的嵌入式系统的仪器,另一种就 ...
- Linux 编程笔记(三)
上一章节对文件的基本属性做了一个笔记,续上次笔记对Linux文件的属性和属性组做一笔记 我安装的是虚拟机操作系统的版本还KaliLinux但是系统启动速度拖延,所以刚开始还是配置Centos 1.Li ...
- linux里面的命令:./和. /(这里有空格)的区别
/ ( 直接/ ) 直接 / 表示: 根目录. ./ ( 点号紧跟/ ) 点号紧跟/ 表示: 当前目录(相对路径的写法). . / ( 点号 空格 / ) 有空格的点号等同于source命令,表示在 ...
- Google C++ 代码规范
Google C++ Style Guide Table of Contents Header Files Self-contained Headers The #define Guard For ...
- 论文阅读笔记七:Structure Inference Network:Object Detection Using Scene-Level Context and Instance-Level Relationships(CVPR2018)
结构推理网络:基于场景级与实例级目标检测 原文链接:https://arxiv.org/abs/1807.00119 代码链接:https://github.com/choasup/SIN Yong ...
- hdfs数据到hive中,以及hdfs数据隐身理解
hdfs数据到hive中: 假设hdfs中已存在好了数据,路径是hdfs:/localhost:9000/user/user_w/hive_g2park/user_center_enterprise_ ...
- 五.hadoop 从mysql中读取数据写到hdfs
目录: 目录见文章1 本文是基于windows下来操作,linux下,mysql-connector-java-5.1.46.jar包的放置有讲究. mr程序 import java.io.DataI ...
- 解开一个疑惑,为什么LVS开放的端口,使用netstat或ss命令,不能查找到其监听的端口呢?
RT, 这个疑问,本周一直在心里,今天找到一个说法. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 另外LVS规则算是内核方法,用netstat -ntulp也显 ...
- 一脸懵逼学习HBase---基于HDFS实现的。(Hadoop的数据库,分布式的,大数据量的,随机的,实时的,非关系型数据库)
1:HBase官网网址:http://hbase.apache.org/ 2:HBase表结构:建表时,不需要指定表中的字段,只需要指定若干个列族,插入数据时,列族中可以存储任意多个列(即KEY-VA ...