• parameterType 和 resultType

parameterType:单个参数用String,多个参数用map

resultType:可以是 Integer、String、Object

   <select id="countGroupMasterByUid" parameterType="String" resultType="Integer">SELECT COUNT(id)FROM t_mc_store_group_masterWHERE u_id = #{uid}</select><select id="countGroupMaster" parameterType="hashmap" resultType="Integer">SELECT COUNT(1)FROM t_mc_store_group_master gm,t_mc_store_group gWHERE gm.id = g.master_idAND gm.u_id = #{uid}AND g.id = #{groupId}</select><select id="queryMasterIdByUid" parameterType="String" resultType="String">SELECT id FROM t_mc_store_group_master WHERE u_id = #{uid}</select><select id="queryMasterByGroupId" parameterType="String" resultType="com.xxx.smart.group.model.GetGroupMember">SELECT gm.u_id mid,gm.u_name mName,1 mTag,1 pb_list,1 pb_view,1 pb_down,1 pb_upload,1 pb_delete,1 pb_rename,1 pb_share,2 isAdmin,1 isMasterFROM t_mc_store_group g,t_mc_store_group_master gmWHERE gm.id = g.master_idAND   g.id = #{groupId}</select>
  • 对应的Java实现接口解析

我们可以基于org.mybatis.spring.SqlSessionTemplate提供的模板类来进行数据库操作的具体实现,例如以下是经过对模板的再封装进行实现的,封装类的过程做了日志记录操作等,在此具体不在细说:

        @Overridepublic int countGroupMasterByUid(String uid) {return getSqlSessionTemplate().selectOne("countGroupMasterByUid", uid);}@Overridepublic int countGroupMaster(String uid, String groupId) {Map<String,String> map = new HashMap<String,String>();map.put("uid", uid);map.put("groupId", groupId);return getSqlSessionTemplate().selectOne("countGroupMaster", map);}@Overridepublic GetGroupMember queryMasterByGroupId(String groupId) {return getSqlSessionTemplate().selectOne("queryMasterByGroupId", groupId);}@Overridepublic String queryMasterIdByUid(String uid) {return getSqlSessionTemplate().selectOne("queryMasterIdByUid", uid);}@Overridepublic List<GroupMaster> queryMasterList(int index, int pageSize) {Map<String,Object> map = new HashMap<String,Object>();map.put("index", (index-1)*pageSize);map.put("pageSize", pageSize);return getSqlSessionTemplate().selectList("queryMasterList",map);}

亦可以参考:http://lydia-fly.iteye.com/blog/2153102


  • 动态SQL参考:http://www.cnblogs.com/ywqbj/p/5707652.html


  • selectKey的使用

<!-- 这里需要说明一下不同的数据库主键的生成,对各自的数据库有不同的方式: -->
<!-- mysql:SELECT LAST_INSERT_ID() AS VALUE -->
<!-- mssql:select @@IDENTITY as value -->
<!-- oracle:SELECT STOCKIDSEQUENCE.NEXTVAL AS VALUE FROM DUAL -->
<!-- 还有一点需要注意的是不同的数据库生产商生成主键的方式不一样,有些是预先生成 (pre-generate)主键的,如Oracle和PostgreSQL。 
有些是事后生成(post-generate)主键的,如MySQL和SQL Server 所以如果是Oracle数据库,则需要将selectKey写在insert之前 -->

注意:插入的时候id可以省略,但masterId必须对应的上AddMaster这个JavaBean的masterId属性。

表结构如下:

MySQL [mcloud]> desc t_mc_store_group_master;

+-------------+--------------+------+-----+-------------------+-----------------------------+

| Field       | Type         | Null | Key | Default           | Extra                       |

+-------------+--------------+------+-----+-------------------+-----------------------------+

| id          | bigint(16)   | NO   | PRI | NULL              | auto_increment              |

| u_id        | varchar(128) | NO   | MUL | NULL              |                             |

| u_name      | varchar(128) | YES  |     | NULL              |                             |

| dept_name   | varchar(128) | YES  |     | NULL              |                             |

| create_time | timestamp    | YES  |     | CURRENT_TIMESTAMP |                             |

| update_time | timestamp    | YES  |     | CURRENT_TIMESTAMP | on update CURRENT_TIMESTAMP |

+-------------+--------------+------+-----+-------------------+-----------------------------+

<insert id="addMaster" parameterType="com.xxx.smart.group.model.AddMaster" >INSERT INTO t_mc_store_group_master (id,u_id,u_name,dept_name)VALUES (#{masterId},#{uid},#{uName},#{deptName})<selectKey resultType="Integer" order="AFTER" keyProperty="masterId">SELECT LAST_INSERT_ID() AS masterId</selectKey></insert>
  • 组合查询设置不存在的列


 <select id="queryUserList" parameterType="hashmap" resultType="com.xxx.smart.group.model.User">SELECTtu.id casualId,tu.name name,tu.expire_time validdate,tu.pb_upload,tu.pb_down,tu.pb_share,tu.pb_rename,tu.pb_view,tu.pb_delete,tu.account,IF(ul.id>0,1,0) statusFROM t_mc_store_casual_user tuJOIN t_mc_store_manage_department md ON tu.dept_id = md.dept_idLEFT JOIN t_mc_store_user_lock ul ON tu.account = ul.accountWHERE md.u_id = #{uid}AND tu.is_delete = 0LIMIT #{index},#{pageSize}
</select>
  • 原生SQL语句

<select id="queryExpireUser" parameterType="hashmap" resultType="com.xxx.smart.group.model.ExpireUser"><![CDATA[
SELECTaccount,passwordFROMt_mc_store_casual_userWHERE expire_time <= #{endTime}AND expire_time > #{beginTime}AND is_delete = 0]]></select>

转载于:https://blog.51cto.com/flash09/1909761

Mybatis 项目开发实际常用SQL笔记总结相关推荐

  1. 项目开发中常用JS表单取值方法

    项目开发中常用JS表单取值方法 一.常用表单基本取值方法(form1为表单名称,TextBox1为控件ID,以文本框为例,html控件与web服务器控件是一样的)         1.form1.Te ...

  2. Android项目开发实战常用知识点

    Android项目开发实战常用知识点 一:启动页延时两秒再跳转到主界面: //执行类 private class SlpashRunnable implements Runnable {@Overri ...

  3. Git码云项目开发中常用分支

    Git码云项目开发中常用分支 master分支,即主分支.任何项目都必须有个这个分支.对项目进行tag或发布版本等操作,都必须在该分支上进行. develop分支,即开发分支,从master分支上检出 ...

  4. 项目开发中常用的git套路

    在项目开发中常用的git套路: 1.在本地文件夹中,(在库名文件夹下)打开git bash 2.如果想在github上新建一个仓库,则 git init  否则略过这一步 3.建立关联  git re ...

  5. Java神鬼莫测之MyBatis注解开发之动态SQL语句(六)

    1.Mybatis注解开发之动态SQL语句 背景:使用mybatis的注解开发动态Sql会比较麻烦, 很不方便, 所以不太推荐使用,该文章以查询作为案例,演示动态sql语句. 注意:Mybatis的动 ...

  6. 开发项目时mysql常用语句_项目开发中常用到的SQL语句

    1.循环示例 循环示例代码: DECLARE @i intDECLARE 10 ) 10 ) 10001200 BEGINSet 110 )), 4 ) @name select @name Loco ...

  7. J2EE项目开发中常用到的公共方法

    在项目IDCM中涉及到多种工单,包括有:服务器|网络设备上下架工单.服务器|网络设备重启工单.服务器光纤网线更换工单.网络设备撤线布线工单.服务器|网络设备替换工单.服务器|网络设备RMA工单.通用原 ...

  8. mybatis项目报Error parsing SQL Mapper Configuration.错误及解决方法

    报错信息 org.apache.ibatis.exceptions.PersistenceException: Error building SqlSession. The error may exi ...

  9. php项目开发中常用的助手函数

    在日常开发中有很多小功能或者函数方法都是复用率极高的,整理成一个助手函数类. <?php /** *助手函数类 */ class Helper {/***密码加密*/public static ...

  10. Mysql学习总结(65)——项目实战中常用SQL实践总结

    (1)负向条件查询不能使用索引 select  x1, x2 from order where status!=0 and stauts!=1 not in/not exists都不是好习惯 可以优化 ...

最新文章

  1. Java中@Override的作用
  2. js和 jquery对象
  3. Reactor构架模式--转载
  4. 我想谈谈关于Android面试那些事,一篇文章帮你解答
  5. c#简单记事本应用程序的快捷方式_Windows 10七月更新又翻车,记事本没了
  6. 修改window窗体的背景色
  7. python大数据处理与分析课程目标_《大数据分析与挖掘》课程教学大纲
  8. 绝大部分博士目前都无法进入大学
  9. VMware系统运维(十一)部署虚拟化桌面 Horizon View 5.2 HTML ACCESS安装
  10. Fish 环境下如何安装 nvm
  11. 基于微信小程序的投票系统源码
  12. 利用css3伪元素实现加号、减号、对号小图标效果
  13. Gitee创建仓库拉人
  14. 关于反向传播算法中几个公式的推导
  15. 软件开发基于JavaScript实现快速转换文本语言(繁体中文和简体中文)_javascript技巧
  16. JQuery 判断访问的浏览器是pc还是手机
  17. 58同城的字体解密(一)
  18. 5.Serializer,ModelSerializer区别
  19. TexturePacker的免费key获取方式
  20. HTML5期末大作业:旅游家乡景点网站设计——河北(8页) HTML+CSS+JavaScript 学生DW网页设计作业成品 html旅游网页 web课程设计网页规划与设计 html景点介绍...

热门文章

  1. WinForm主窗口框架的设计
  2. Linux设备驱动模型-Driver
  3. Android 多媒体开发学习之创建图片的副本
  4. 中断(二)—— x86 APIC
  5. DPDK初始化分析(四)
  6. 通过ODBC连接PostgreSQL和Greenplum
  7. 使用jrtplib(RTP)传输H.264视频文件
  8. python生成器的作用是什么_看完这篇,你就知道Python生成器是什么
  9. 【图论】染色法判定二分图详解
  10. python多任务之——线程简述