关于mybatis中mapper.xmlSQL语句书写的心得
本文主要针对MySQL
----------------------------------------------------------------------------------------------------------
用generatorConfig.xml工具生成我有总结过:http://www.cnblogs.com/fengchaoLove/p/5790352.html
了解的可以去看看。
本文主要针对纯手写。
-----------------------------------------------------------------------------------------------------------
mapper.xml-->dao接口-->service-->Controller
Entity实体类
增删改查,我们先说查select
select *(要查询的字段)from 表名 where id='',and ...
mapper.xml;
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--客户映射 指定到dao接口 -->
<mapper namespace="com.hebg3.mobiledealer.modules.client.sales.dao.CustomerDao">
<!--id与dao接口的方法名一直,指定结果类型,和参数类型 -->
<select id="get" resultType="TCustomer" paramType="string">
SELECT
*
FROM t_customer a
WHERE a.id = #{id}<!--主键 -->
但在工作中,我们发现其实我们要查的没有那么简单,和我学习时候的几点出入:
1.实体类要用驼峰命名,而数据库中的字段是下划线割开,导致unknown错误。
2.我们往往不是通过一个字段来查询,是好几个字段,甚至还有动态查询(有这个字段就查,没有就忽略)。
3.条件查询中有List,需要循环查找
4.条件中有关模糊查询。
先来解决第一个问题:
<!-- 库存映射 -->
<mapper namespace="com.hebg3.mobiledealer.modules.client.store.order.dao.OrderDao"> <sql id="tOrderColumns">
a.id AS "id",<!-- 主键 -->
a.order_no AS "orderNo",<!-- 订单编号 -->
a.t_customer_id AS "customer.id",<!-- 客户编号 -->
a.sys_office_id AS "companyOffice.id",<!-- 公司编号 -->
a.order_date AS "orderDate",<!-- 订单日期 -->
a.document_status AS "documentStatus",<!-- 订单状态 -->
a.send_date AS "sendDate",<!-- 发送时间 -->
a.open_id AS "openId",<!-- 微信编号 -->
a.create_by AS "createBy.id",<!-- 建立人 -->
a.create_date AS "createDate",<!-- 建立时间 -->
a.update_by AS "updateBy.id",<!-- 更新人 -->
a.update_date AS "updateDate",<!-- 更新时间 -->
a.remarks AS "remarks",<!-- 备注 -->
a.del_flag AS "delFlag",<!-- 删除标志 --> </sql> <!-- 根据条件取得 订单信息列表 -->
<select id="findPageOrder" resultType="TOrder">
SELECT
<!-- refid属性与上面spl标签的Id一致 -->
<include refid="tOrderColumns" />
FROM t_order a
<include refid="tOrderJoins" />
<where> <if test="Id!=null and id!=''">
id=#{Id}
</if> </select>
<if>标签实现动态查询。
如果想再加入一个查询条件;
在if标签 下面加入
<if test="documentStatus!=null and documentStatus!=''">
AND a.document_status =#{documentStatus}
</if>
如果查询条件中有List集合,可以在参数类中加入List类型的属性,比如是List<String> documentStatusList:并生成get,set方法;
<if test="documentStatusList != null"><!-- 根据单据状态查找 -->
AND a.document_status in
<!-- foreach标签需要指定四个属性,item,index下标,collection要与指定的属性名一直,open指定断开符号和结束符号 -->
<foreach item="item" index="index" collection="documentStatusList" open="(" separator="," close=")">
#{item}
</foreach> </if>
当然如果你想排序的话
<choose>
<when test="page !=null and page.orderBy != null and page.orderBy != ''"><!-- 根据 排序字段 排序 -->
ORDER BY ${page.orderBy}
</when>
<otherwise>
ORDER BY a.create_date DESC
</otherwise>
</choose>
几个注意的细节例如

这其中customer都是实体类。
希望对大家有所帮助。。
关于mybatis中mapper.xmlSQL语句书写的心得的更多相关文章
- Mybatis中动态SQL语句中的parameterType不同数据类型的用法
Mybatis中动态SQL语句中的parameterType不同数据类型的用法1. 简单数据类型, 此时#{id,jdbcType=INTEGER}中id可以取任意名字如#{a,jdbcType ...
- MyBatis 中实现SQL语句中in的操作 (11)
MyBatis 中实现SQL语句中in的操作 概括:应用myBatis实现SQL查询中IN的操作 1.数据库结构及其数据 2.mapper.xml文件 <?xml version="1 ...
- mybatis中的查询语句in用法的相关问题
在开发的时候,mybatisl中使用in的时候会遇到一些问题,如果我们传的参数是String类型,以“,”来进行隔开的,例如:参数是0,1,2字符串,mybatis中的语句如下 <select ...
- 逆向工程生成的mybatis中mapper文件。mapper接口,实例化成对象
逆向工程生成的mybatis中mapper文件中,*mapper文件只是接口,而不是类文件.但是却可以通过spring的容器获得实例. 例如: //1.获得mapper代理对象,从spring容器获得 ...
- 控制台输出 mybatis 中的sql语句
控制台输出 mybatis 中的sql语句 在 log4j.xml 文件中 增加如下配置 <!-- mybatis 输出的sql,DEBUG级别 --> <logger name=& ...
- MyBatis中动态SQL语句完成多条件查询
一看这标题,我都感觉到是mybatis在动态SQL语句中的多条件查询是多么的强大,不仅让我们用SQL语句完成了对数据库的操作:还通过一些条件选择语句让我们SQL的多条件.动态查询更加容易.简洁.直观. ...
- MyBatis 中 Mapper 接口的使用原理
MyBatis 中 Mapper 接口的使用原理 MyBatis 3 推荐使用 Mapper 接口的方式来执行 xml 配置中的 SQL,用起来很方便,也很灵活.在方便之余,想了解一下这是如何实现的, ...
- mybatis 中mapper 的namespace有什么用
原文:http://zhidao.baidu.com/link?url=ovFuTn7-02s7Qd40BOnwHImuPxNg8tXJF3nrx1SSngNY5e0CaSP1E4C9E5J6Xv5f ...
- 关于使用mybatis中mapper instrances,通过session另一种操作方式
String resource = "mybatis-config.xml"; InputStream inputStream = null; try { // 获取SqlSess ...
随机推荐
- cookie保存中文登录账号获取时乱码问题
登录成功后写入cookie的代码 Response.Cookies["account"].Value = account;//"管理员" Response.Co ...
- C#开发微信门户及应用(18)-微信企业号的通讯录管理开发之成员管理
在上篇随笔<C#开发微信门户及应用(17)-微信企业号的通讯录管理开发之部门管理>介绍了通讯录的部门的相关操作管理,通讯录管理包括部门管理.成员管理.标签管理三个部分,本篇主要介绍成员的管 ...
- C#开发微信门户及应用(16)-微信企业号的配置和使用
在本系列随笔的前面,主要就是介绍微信公众号的门户应用开发,最近把整个微信框架进行了扩展补充,增加了最新的企业号的API封装和开发,后续主要介绍如何利用C#进行微信企业号的开发工作,本篇作为微信企业号的 ...
- getJson
$.getJSON("<%=basePath%>delivery/auditing.do",{Phones:Phones,currPage:currPage,timst ...
- 如何在VS 2010中使用 VS2013的解决方案(转)
今天要用VS2010打开VS2013,一直觉得VS2010到VS2012只是界面上扁平化的改变,平台工具集有改变但很大程度上可能向上兼容.在网上搜了一些文章,其中有一篇说到一个观点: 从 ...
- 怎样在asp中产生10个0-99的随机数
<% randomize for i=1 to 10 response.write cint(rnd*100) next %> randomize是随机初始化,使用rnd之前必须要先来一句 ...
- ngrok
为什么要使用ngrok?/ngrok 作为一个Web开发者,我们有时候会需要临时地将一个本地的Web网站部署到外网,以供它人体验评价或协助调试等等,通常我们会这么做: 找到一台运行于外网的Web服务器 ...
- JavaScript基本数据类型和引用数据类型
ECMAScript包含两种不同数据类型的值:基本类型值和引用类型值.基本类型值指的是简单的数据段,而引用类型值那些可能有多个值构成的对象. 在进行变量赋值时,解析器必须确定这个值是基本类型值还是引用 ...
- iOS 网络流量统计
在开发中,有时候需要获取流量统计信息.研究发现:通过函数getifaddrs来得到系统网络接口的信息,网络接口的信息,包含在if_data字段中, 有很多信息, 但我现在只关心ifi_ibytes, ...
- android 自定义通知栏
package com.example.mvp; import cn.ljuns.temperature.view.TemperatureView;import presenter.ILoginPre ...