Sql字段动态比较判断

<sql id="getUserInfoList_body">
SELECT * from userinfo
<dynamic prepend="WHERE">
  <isNotNull prepend="AND" property="id"> a.id=#id#</isNotNull>
  <isNotNull prepend="AND" property="userName"> a.userName like concat('%', #userName#, '%') </isNotNull>
  <isNotNull prepend="AND" property="inschoolTimeEnd"> a.inschoolTime &lt; #inschoolTimeEnd# </isNotNull>
  <isNotNull property="roleID">
<isEqual property="roleID" compareValue="3" prepend="AND">
addrProvinceID in (SELECT areaID FROM co_user_area WHERE adminID = #adminID#)</isEqual>
<isEqual property="roleID" compareValue="4" prepend="AND">
addrCityID in (SELECT areaID FROM co_user_area WHERE adminID = #adminID#)</isEqual>
  </isNotNull>
</dynamic>
ORDER BY a.id DESC
</sql>

sql语句返回主键id     

<insert id="">      //注意无需resultClass

  <selectKey resultClass="int" keyProperty="id">
  SELECT @@IDENTITY AS id
  </selectKey>
</insert> public Integer insert(Invoice invoice) throws DAOException {
return (Integer)getSqlMapClientTemplate().insert("insert",invoice);
}

sql时间范围查询条件  

//一
< isNotNull prepend="AND" property="createStartDateStr">
  CONVERT(varchar(100), kb.createDate , 23) &gt;= #createStartDateStr#
</isNotNull>
<isNotNull prepend="AND" property="createEndDateStr">
  CONVERT(varchar(100),kb.createDate,23) &lt;=#createEndDateStr#
</isNotNull> //二
<isNotNull prepend="AND" property="startTime">
  kc.createDate >= #startTime#
</isNotNull>
<isNotNull prepend="AND" property="endTime">
  <![CDATA[kc.createDate <= #endTime#]]>
</isNotNull> //三
<isNotNull prepend="AND" property="startTime">
  CONVERT(varchar(100), kb.createDate , 23) &gt;= #startTime#
</isNotNull>
<isNotNull prepend="AND" property="endTime">
  CONVERT(varchar(100), kb.createDate , 23) &lt;= #endTime#
</isNotNull>

sql每月数据统计  

SELECT
COUNT(DISTINCT kes.userID) AS examCount,
CONVERT(nvarchar(7), kesd.createTime, 120) AS month
FROM kp_out_system kos WITH (NOLOCK)
LEFT JOIN kp_exam_score kes WITH (NOLOCK)
ON kes.outSystemSign = kos.outSystemSign
LEFT JOIN kp_exam_score_detail kesd WITH (NOLOCK)
ON kesd.examScoreID = kes.id AND kesd.valid = 1
< isNotNull prepend="AND" property="startTime"> kesd.createTime &gt;= #startTime# </isNotNull>
<isNotNull prepend="AND" property="endTime"> kesd.createTime &lt;= #endTime# </isNotNull>
WHERE kos.status = 1
<isNotNull prepend="AND" property="outSystemSign"> kos.outSystemSign=#outSystemSign# </isNotNull>
AND kos.outSystemSign IS NOT NULL AND kos.sysAreaID IS NOT NULL AND kesd.createTime IS NOT NULL
GROUP BY CONVERT(nvarchar(7), kesd.createTime, 120)
ORDER BY CONVERT(nvarchar(7), kesd.createTime, 120)

sqlsum()结果判空 

SELECT ISNULL(SUM(myTable.thesisCount),0) AS thesisCount FROM (
  SELECT
COUNT(kuu.id) AS thesisCount,
ISNULL(kos.outSystemName, '无') AS outSystemName
FROM kp_out_system kos WITH (NOLOCK)
LEFT JOIN kp_user_upload_thesis kuu WITH (NOLOCK) ON kuu.outSystemSign = kos.outSystemSign AND kuu.valid = 1
WHERE kos.status = 1
   <isNotNull prepend="AND" property="outSystemSign"> kuu.outSystemSign = #outSystemSign# </isNotNull>
AND kos.outSystemSign IS NOT NULL AND kos.sysAreaID IS NOT NULL
GROUP BY ISNULL(kos.outSystemName, '无')
) AS myTable

验证某个属性是否已存在(修改信息时用)

select COUNT(*) from ... where id != #id# and ... = #...#

sql数组传参(in

//Action代码
if (null != studyID && 2 == studyID.intValue()) {
Integer[] studyIDs = new Integer[] { 2,3, 4 };
userInfo.setStudyIDs(studyIDs);
} else {
userInfo.setStudyID(studyID);
} //Xml文件
<isNotNull prepend="AND" property="studyID">
a.studyID=#studyID#
</isNotNull>
<isNotNull prepend="AND" property="studyIDs">
a.studyID in
<iterate property="studyIDs" open="(" close=")" conjunction=",">
#studyIDs[]#
</iterate>
</isNotNull>

Int类型拼接需要使用cast()  

SELECT (SELECT DISTINCT
CAST(studyID AS varchar) + ','
FROM kp_study_type
WHERE outSystemSign = 'drivingcoach' AND valid = 1
FOR xml PATH (''))
AS studyIDs,
ISNULL(
SUM(CASE
WHEN b.isPass = 1 THEN 1 ELSE 0
END), 0) AS isPassCount,
ISNULL(
SUM(CASE
WHEN b.isOpen = 1 OR b.isOpen = 3 THEN 1 ELSE 0
END), 0) AS isOpenCount,
ISNULL(
SUM(CASE
WHEN b.isOpen = 1 OR b.isOpen = 3 THEN 0 ELSE 1
END), 0) AS isNotOpenCount
FROM kp_study_type a WITH (NOLOCK)
INNER JOIN kp_select_studyType b WITH (NOLOCK)
ON a.studyID = b.studyID AND b.valid = 1
INNER JOIN kp_user_info kui WITH (NOLOCK)
ON kui.ID = b.userID AND kui.valid = 1
LEFT JOIN (SELECT
k.studyID,
k.userID,
SUM(k.studyTimes) studyTimes,
SUM(CASE
WHEN k.studyTimes >= k.studyTime * 60 THEN 1 ELSE 0
END) coursefinishCount,
COUNT(k.courseID) courseCount
FROM (SELECT
r.studyID,
t.userID,
SUM(t.studyTimes) AS studyTimes,
r.courseID,
r.studyTime
FROM kp_studyCourse_relation r WITH (NOLOCK)
LEFT JOIN kp_course c WITH (NOLOCK)
ON r.courseID = c.id
LEFT JOIN kp_study_course_time t WITH (NOLOCK)
ON c.courseNumber = t.courseNumber AND t.studyID = r.studyID
WHERE r.valid = 1 AND c.valid = 1 AND t.id IS NOT NULL
GROUP BY r.studyID,
t.userID,
r.courseID,
r.studyTime) k
GROUP BY k.studyID,
k.userID) e
ON a.studyID = e.studyID AND b.userID = e.userID
WHERE a.valid = 1 AND a.studyID IN (SELECT DISTINCT
studyID
FROM kp_select_studyType
WHERE outerSystemSign = 'drivingcoach' AND valid = 1 AND isOpen = 1)

sql截取字符串 

SELECT DISTINCT
ISNULL(SUBSTRING(areaID, 1, 6), 0) AS areaID
FROM kp_user_info

SELECT
TOP 10
kui.username
FROM kp_user_info kui WITH (NOLOCK)
LEFT JOIN dic_area dc WITH (NOLOCK)
ON RIGHT(kui.areaID, 6) = dc.areaID

地区搜索,传参设置

if(null != provinceID && !"000000".equals(provinceID)){
productOrder.setAreaID(provinceID);
}
if(null!=cityID && cityID != ""){
//数据库存储为110000:110101,依据存储方式设置
productOrder.setAreaID(provinceID+":"+cityID);
} <dynamic prepend="">
<isNotNull prepend="AND" property="areaID">
    kui.areaID like #areaID# + '%'
   </isNotNull>
</dynamic>

以...开头

*
FROM computer
WHERE sex = '男' AND LEFT(name, 1) IN ('李', '陈')

SELECT
*
FROM computer
WHERE sex = '男'
(and name like '李__'or name like '陈__')

跨库复制表数据

//-1-
SET IDENTITY_INSERT cdel_jxjy_flat20171106..op_ip_login_control ON;
//-2-
INSERT INTO cdel_jxjy_flat20171106..op_ip_login_control (id, ip, notes, valid, creator, createTime)
SELECT * FROM cdel_jxjy_flat0725..op_ip_login_control

Mapper查询技巧的更多相关文章

  1. SQL高级查询技巧

    SQL高级查询技巧   1.UNION,EXCEPT,INTERSECT运算符 A,UNION 运算符 UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重 ...

  2. google查询技巧

    技巧一:使用正确的方法 无论你是使用一个简单或是高级的Google搜索,在此都存在你应该使用的某种可靠的方法.遵循适当的方法你就能获得非常准确的结果:要是忽略这条建议的话,你也许就会看到大量不相关的结 ...

  3. MySQL翻页查询技巧

    在查询大量数据库,一般都会采用翻页.自然会想到offset跟limit. 今天知道了一个技巧,用id查询.因为id是主键,查起来很快. 思路是:给id一个区间做where条件,将数据分隔成几份,然后每 ...

  4. SQLServer多条件查询技巧

    2019-10-15  13:31:04 在实际项目开发中,有很多页面都会出现多条件查询功能,类似于这种情况: 牵扯到数据就少不了数据库了.这么多条件的查询,如果要用常规的if else来写判断逻辑的 ...

  5. 2020想进大厂你不得不了解的MySQL意外事件的查询技巧

    导读:数据库是导致应用系统运行缓慢的常见原因.面对数据库引性能问题,很多开发者或者DBA却束手无策.本文作者经过多年的实际经验,整理了一些材料,将Linux环境下MySQL性能突发事件问题排查技巧分享 ...

  6. 【转】sql各种查询技巧

    高级查询在数据库中用得是最频繁的,也是应用最广泛的. Ø 基本常用查询 --select select * from student;   --all 查询所有 select all sex from ...

  7. SQL高级查询技巧(两次JOIN同一个表,自包含JOIN,不等JOIN)

    掌握了这些,就比较高级啦 Using the Same Table Twice 如下面查询中的branch字段 SELECT a.account_id, e.emp_id, b_a.name open ...

  8. Oracle优化查询技巧

    1. WHERE子句中的连接顺序:Oracle采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉最大数量记录的条件必须写在WHERE子句的 ...

  9. hql查询技巧

    要擅于利用对象之间映射的集合去查与其关联的对象,而不是直接在dao层重新写查询的方法,其实,hibernate正是对复杂查询的一种解放,既然有现成的东西,何必再去闭门造车,而且造出来的还是个旧车. 查 ...

随机推荐

  1. Linux嵌入式学习-网络配置-ping外网、主机和域名

    之前用的nfs挂载的文件系统,今天用yaffs2制作的文件系统并写入到nandflash中.但是网络却无法使用了. 首先,我们配置网卡. ifconfig eth0 192.168.1.230 bro ...

  2. MongoDb学习(四)--Repository----语法关键字

    表7.查询方法支持的关键字 关键词 样品 逻辑结果 After findByBirthdateAfter(Date date) {"birthdate" : {"$gt& ...

  3. eclipse下的jetty远程调试设置

    在windows下的jetty远程调试设置1.首先说明的是windows下的jetty是通过命令java  -jar start.jar来启动的,因此要想设置成远程调试模式,则要改用命令java -X ...

  4. 漫画 | 小公司卧薪尝胆三年,意外拿到美团offer

    今天给大家分享一篇,非科班出生的野生前端从业者的励志成长故事,故事的主人公王大拿(化名),在小公司打杂三年后,意外拿到了美团的offer,成功进阶大厂,跳槽到了美团的核心外卖事业部. 事故主人公:王大 ...

  5. ROS开源小车TurtleBot3详情介绍

    您为什么要选择ROS开源智能小车 ROS(Robot Operating System,机器人操作系统)是目前世界上更主流更多人使用的的机器人开源操作系统.它可以提供操作系统应有的服务,包括硬件抽象, ...

  6. phoenix启动报错:org.apache.phoenix.exception.PhoenixIOException: SYSTEM.CATALOG

    错误: org.apache.phoenix.exception.PhoenixIOException: SYSTEM.CATALOG at org.apache.phoenix.util.Serve ...

  7. 在mapper.xml映射文件中添加中文注释报错

    问题描述: 在写mapper.xml文件时,想给操作数据库语句添加一些中文注释,添加后运行报如下错误: 思考 可能是写了中文注释,编译器在解析xml文件时,未能成功转码,从而导致乱码.但是文件开头也采 ...

  8. Flutter 应用入门:计数器

    用Android Studio创建的Flutter应用模板默认是一个简单的计数器示例. // 导入包 import 'package:flutter/material.dart'; // 应用入口,启 ...

  9. Python使用Protobuf&&如何赋值&&如何正反序列化

    前言 使用protobuf主要是两个步骤,序列化和反序列化. 关于Proto有哪些数据类型,然后如何编写,此处就不赘述了,百度一下有很多. 此文主要是总结,python使用protobuf的过程,如何 ...

  10. 【Linux】postfix大坑笔记

    由于需要,想弄一个自动发送邮件的mailx或者sendmail 但是执行 echo "test" | mail -s "Worning mail !" xxxx ...