广告
返回顶部
首页 > 资讯 > 数据库 >Mybatis 项目开发实际常用SQL笔记总结
  • 599
分享到

Mybatis 项目开发实际常用SQL笔记总结

2024-04-02 19:04:59 599人浏览 八月长安
摘要

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

  • parameterType 和 resultType

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

      resultType:可以是 Integer、String、Object


   <select id="countGroupMasterByUid" parameterType="String" resultType="Integer">
    	SELECT 
            COUNT(id)
        FROM 
          t_mc_store_group_master
        WHERE 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 g
         WHERE gm.id = g.master_id
         AND 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 isMaster
          FROM 
            t_mc_store_group g,
            t_mc_store_group_master gm
         WHERE gm.id = g.master_id
         AND   g.id = #{groupId}
   </select>
  • 对应的Java实现接口解析

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


        @Override
	public int countGroupMasterByUid(String uid) 
	{
		return getSqlSessionTemplate().selectOne("countGroupMasterByUid", uid);
	}
	
	@Override
	public 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);
	}
	@Override
	public GetGroupMember queryMasterByGroupId(String groupId) 
	{
		return getSqlSessionTemplate().selectOne("queryMasterByGroupId", groupId);
	}
	@Override
	public String queryMasterIdByUid(String uid) 
	{
		return getSqlSessionTemplate().selectOne("queryMasterIdByUid", uid);
	}
	@Override
	public 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)主键的,如mysqlSQL 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">
   SELECT
   tu.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) status
   FROM t_mc_store_casual_user tu
   JOIN t_mc_store_manage_department md ON tu.dept_id = md.dept_id
   LEFT JOIN t_mc_store_user_lock ul ON tu.account = ul.account
   WHERE md.u_id = #{uid}
     AND tu.is_delete = 0
   LIMIT #{index},#{pageSize}
</select>
  • 原生SQL语句

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

 

您可能感兴趣的文档:

--结束END--

本文标题: Mybatis 项目开发实际常用SQL笔记总结

本文链接: https://www.lsjlt.com/news/38249.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作