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连接] '; ...
随机推荐
- hdu4990 转移矩阵
找了半天错发现m有可能是1.. /* 如果n是奇数,就进行(n/2)次转移,然后取F[2],反之取F[1] */ #include<bits/stdc++.h> using namespa ...
- Java和C冒泡排序
Java 示例代码: public class test { public static void main(String[] args) { String str = "321dca5&q ...
- .tar.xz文件的解压方法
废话不多说: 直接看 方法一: tar -xvJf ***.tar.gz 方法二: 先减压成 .tar 格式的文件, 再解压 .tar #xz是一个工具, 系统中没有安装,需要下载 xz -d *** ...
- 3月9日(用 DBHelper 工具连接 mysql 数据库 实现登录验证)
一. 用DBHelper 与mysql 连接 实现最简单的登录验证. (1)新建 web project ----->选择src导入 DBHelper 工具包-------->选择web ...
- java 多线程中的锁的类别及使用
目前在Java中存在两种锁机制: synchronized Lock Lock接口及其实现类是JDK5增加的内容,其作者是大名鼎鼎的并发专家Doug Lea. 数据同步需要依赖锁,那锁的同步又依赖谁? ...
- IDEA导入JAR的源代码
- 十六进制的ASCII码 "\u6cf0\u56fd" 解码成unicode
转码方法: C#: string a = "\u6cf0\u56fd"; string b = Encoding.UTF8.GetString(Encoding.UTF8.GetB ...
- awk常见用法
awk作为linux字符搜索,结果统计的实用工具,其在linux日常运维中有着很多的巧妙运用.下面就来技术一下刚刚学到的技巧 #awk命令统计文件夹下所有文件大小 ls -l |awk 'BEGIN ...
- net core体系-web应用程序-4net core2.0大白话带你入门-9asp.net core服务的生命周期
asp.net core服务的生命周期 Transient:每一次GetService都会创建一个新的实例 Scoped:在同一个Scope内只初始化一个实例 ,可以理解为( 每一个request ...
- BZOJ4025 二分图 分治 并查集 二分图 带权并查集按秩合并
原文链接http://www.cnblogs.com/zhouzhendong/p/8683831.html 题目传送门 - BZOJ4025 题意 有$n$个点,有$m$条边.有$T$个时间段.其中 ...