spring整合mybatis时,要使用mybatis的注解,需要spring-config.xml文件中添加下述配置:  

 <!--下述配置指明了我们的Mapper,即Dao,在相应的包里也就可以使用注解了,同时不用写Dao的实现类了  -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.itszt.dao"></property>
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
</bean>

  UserDao.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">
<!--
保证命名空间,和接口的全类名一致
-->
<mapper namespace="com.itszt.dao.UserDao">
<resultMap id="userMap" type="user">
<id property="uid" column="uid"></id>
<result property="username111" column="username"></result>
</resultMap>
</mapper>

  此时,在与UserDao.xml文件同一包下的UserDao接口可以直接写sql操作语句:

package com.itszt.dao;
import com.itszt.domain.User;
import com.itszt.domain.User2;
import org.apache.ibatis.annotations.*;
import org.springframework.stereotype.Repository;
import java.util.List;
/**
* 我们给接口加@Repository注解,会根据我们的MapperScanner配置,
*将来会自动为该接口构建匿名实现类,然后实例化这个实现类的对象拿去使用
* 而实现类的具体方法功能怎么实现,由两方面决定:
* 1.UserDao.xml 2.interface UserDao中的注解
*/
@Repository
public interface UserDao {
//演示常用查询
@Select("select * from user where uid=#{uid}")
public User findUserByUID(int uid); @Select("select * from user where username=#{username} and userage=#{userage}")
public User findUserByNameAndAge(@Param("username") String username, @Param("userage")int age); @Select("select count(*) from user")
public Integer queryUserCount(); //演示insert ,并且获取自动递增的id赋值
@Insert("insert into user(username,userage,usersalary,regTime) values(#{username},#{userage},#{usersalary},#{regTime})")
@SelectKey(keyProperty = "uid",keyColumn = "uid",resultType = Integer.class,before = false,statement = "select last_insert_id()")
public void testaddUser1(User user); //演示insert ,并且获取自动设置UUID
@Insert("insert into user2(uid,username,userage,usersalary,regTime) values(#{uid},#{username},#{userage},#{usersalary},#{regTime})")
@SelectKey(keyProperty = "uid",keyColumn = "uid",resultType = String.class,before = true,statement = "select uuid()")
public void testaddUser2(User2 user); //演示删除
@Delete("delete from user where uid=#{uid}")
public void testDeleteUser(int uid);
//演示更新某个字段
@Update("update user set username=#{username} where uid=#{uid}")
public void testUpdateUser1(@Param("uid") int uid,@Param("username")String username); //演示ResultMap
@Select("select * from user where uid=#{uid}")
// @ResultMap("userMap")
@Results({@Result(property = "username111",column = "username")})
public User testReusltRM(int uid); //演示list
@Select("<script>" +
"SELECT * FROM user WHERE uid IN\n" +
"<foreach collection=\"list\" open=\"(\" close=\")\" separator=\",\" item=\"uid\">\n" +
" #{uid}\n" +
"</foreach>"+
"</script>")
public List<User> findUsersByIDs(List<Integer> uids); //演示list2,基于自定义SQL来做
@Select("SELECT * FROM user WHERE uid IN list:#{uids}")
@Lang(SelectInLangDriver.class)
public List<User> findUsersByIDs3(@Param("uids") List<Integer> uids); //演示list3,基于自定义SQL来做,能够支持多个集合
@Select("SELECT * FROM user WHERE uid IN list:#{uids} or userage IN list:#{ages}")
@Lang(SelectInLangDriver2.class)
public List<User> findUsersByIDs4(@Param("uids") List<Integer> uids,@Param("ages") List<Integer> ages);
}  

最新文章

  1. 处理xml c#
  2. single单例模式
  3. :after,:before
  4. PHP中常用的正则表达式由哪些元素构成?
  5. 重新想象 Windows 8 Store Apps (43) - 多线程之任务: Task 基础, 多任务并行执行, 并行运算(Parallel)
  6. 李洪强iOS开发之OC[010] - 有参方法的声明实现和调用
  7. hive-安装MySQL(centos6.4)
  8. Heroku 如何上重置 PostgreSQL 数据库
  9. mysql GROUP_CONCAT 查询某个字段(查询结果默认逗号拼接)
  10. nginx——配置 Nginx 防盗链
  11. 本周java 学习进度报告
  12. oracle执行update时卡死问题的解决办法
  13. 【Java】 大话数据结构(9) 树(二叉树、线索二叉树)
  14. virtualbox问题收集
  15. verilog系统函数用法
  16. &lt;转&gt;C++ explicit关键字详解
  17. 利用百度地图API根据地址查询经纬度
  18. 打地鼠游戏iOS源代码项目
  19. php实现安装程序的 安装
  20. Destroy reall destroy ?!

热门文章

  1. [COGS1000]伊吹萃香 最短路
  2. 转:pairwise 代码参考
  3. NOIP2017 宝藏 题解报告【状压dp】
  4. c++多态性详解(转)
  5. restful风格请求及都是 / 的请求及参数也在请求的/中
  6. linux shell 通配符
  7. tp 中 where条件,字段和字段的大小比较
  8. 修改Docker默认镜像和容器的存储位置
  9. oracle导入提示IMP-00013: 只有 DBA 才能导入由其他 DBA 导出的文件
  10. mac activemq