Mybatis 项目开发实际常用SQL笔记总结
admin
2023-05-26 18:21:15
0
  • parameterType 和 resultType

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

      resultType:可以是 Integer、String、Object


   
    	SELECT 
            COUNT(id)
        FROM 
          t_mc_store_group_master
        WHERE u_id = #{uid}
   
   
   
    	 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 id FROM t_mc_store_group_master WHERE u_id = #{uid}
   
   
   
        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}
   
  • 对应的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 map = new HashMap();
		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 queryMasterList(int index, int pageSize) 
	{
		Map map = new HashMap();
		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的使用





注意:插入的时候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 INTO t_mc_store_group_master (id,u_id,u_name,dept_name)
     
    VALUES (#{masterId},#{uid},#{uName},#{deptName})
     
    
      SELECT LAST_INSERT_ID() AS masterId
    
    

 

  • 组合查询设置不存在的列


 
   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}
  • 原生SQL语句


    #{beginTime}
         AND is_delete = 0
   ]]>
 

 

相关内容

热门资讯

折腾10年后终止合同,美国海岸... 【文/观察者网 山猫】据美国海军学会新闻网(USNI News)当地时间19日报道,美国海岸警卫队本...
布林肯又提“实力”但承认:一对... 【文/观察者网 熊超然】据央视新闻报道,5月15日下午,美国总统特朗普结束对中国的国事访问,乘专机离...
三星电子劳资谈判结束,工会决定... △三星电子(资料图)当地时间20日深夜,当天下午再度重启的三星电子劳资谈判结束。三星电子工会一方表示...
敦促乌克兰给白俄“松绑”,美国... 【文/观察者网 张菁娟】钾肥作为提升农作物产量的关键土壤养分,不仅关乎全球粮食安全,更成为当前大国地...
“AI+金融”的下一站:新场景... 记者 胡艳明 “人工智能落到金融领域,在经历过一段时间的探索之后,未来有哪些重点的方向?”2026年...
阿里发布新一代千问旗舰模型Qw... 撰稿 | 150 克 大模型进入高速迭代的第三年,行业关注的重点正在发生变化。 过去,外界衡量一家...
消息称DeepSeek组建Ha... IT之家 5 月 20 日消息,今天下午,“甲子光年”援引 DeepSeek 相关知情人士消息称,D...
机智局 | 京东将举行首场仿真... 深圳商报·读创客户端首席记者 袁静娴 近日,京东宣布,京东零售今年将助推机器人品牌累计销售破100亿...
2026年618大促,摄影性能... 618大促即将到来,不少朋友都想趁着优惠换一台新。如果你预算在一万左右,又特别看重拍照效果,那么兼具...
原创 罗... 导读:罗峰随混沌城主踏入宇宙海倾峰界外域人族基地时,有五位宇宙之主设宴相迎,他们是彭工之主、幽侯之主...