[转]mybatis 的简单使用

 

需要用到的包:(这里只是其中一个版本,其他的百度)

mysql-connector-java-5.1.6-bin

mybatis-3.2.2

先看项目目录:

[转]mybatis 的简单使用

配置文件mybatisconfig.xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE configuration
  3. PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-config.dtd">
  5. <configuration>
  6. <!-- 用XML映射的时候必须配此项!指定mappers里面的返回值对应的实体类 -->
  7. <!-- <typeAliases>
  8. <typeAlias alias="User" type="com.miquan.mybatis.bean.User"/>
  9. </typeAliases> -->
  10. <!-- JDBC配置 -->
  11. <environments default="development">
  12. <environment id="development">
  13. <transactionManager type="JDBC"/>
  14. <dataSource type="POOLED">  <!--POOLED指的是:已经缓存的,即使用缓存-->
  15. <property name="driver" value="com.mysql.jdbc.Driver"/>
  16. <property name="url" value="jdbc:mysql://localhost:3306/weixinface"/>
  17. <property name="username" value="root"/>
  18. <property name="password" value=""/>
  19. </dataSource>
  20. </environment>
  21. </environments>
  22. <!-- mappers,每个实体类对应着一个xml -->
  23. <mappers>
  24. <mapper resource="com/miquan/mybatis/bean/User.xml"/>
  25. </mappers>
  26. </configuration>

实体类User.java:

  1. package com.miquan.mybatis.bean;
  2. public class User {
  3. private int id;
  4. private String userName;
  5. private String password;
  6. public User(int id, String userName, String password) {
  7. super();
  8. this.id = id;
  9. this.userName = userName;
  10. this.password = password;
  11. }
  12. public int getId() {
  13. return id;
  14. }
  15. public void setId(int id) {
  16. this.id = id;
  17. }
  18. public String getUserName() {
  19. return userName;
  20. }
  21. public void setUserName(String userName) {
  22. this.userName = userName;
  23. }
  24. public String getPassword() {
  25. return password;
  26. }
  27. public void setPassword(String password) {
  28. this.password = password;
  29. }
  30. }

User.xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE mapper
  3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <!-- namespace对应着接口类 -->
  6. <mapper namespace="com.miquan.mybatis.inter.IUserOperation">
  7. <!-- <select id="selectById" parameterType="int" resultType="User">
  8. select * from User where id = #{id}
  9. </select> -->
  10. </mapper>

IUserOperation.java:

  1. package com.miquan.mybatis.inter;
  2. import java.util.List;
  3. import org.apache.ibatis.annotations.Delete;
  4. import org.apache.ibatis.annotations.Insert;
  5. import org.apache.ibatis.annotations.Select;
  6. import org.apache.ibatis.annotations.Update;
  7. import com.miquan.mybatis.bean.User;
  8. public interface IUserOperation {
  9. @Select("select * from User where id = #{id}")
  10. public User selectById(int id);
  11. @Select("select * from User where userName = #{userName}")
  12. public List<User> selectUsers(String userName);
  13. @Insert("insert into User values(null, #{userName}, #{password})")
  14. public boolean addUser(User user);
  15. @Delete("delete from User where id = #{id}")
  16. public boolean delUser(int id);
  17. @Update("update User "
  18. + "set userName = #{userName}, "
  19. + "password = #{password} "
  20. + "where id = #{id}")
  21. public boolean updateUser(User user);
  22. }

注意:此处接口不支持多态。

(不知道为什么,用着就是不可以。。。方法名不能一样)

最后进行测试:Test.java:

  1. package com.miquan.mybatis.test;
  2. import java.io.InputStream;
  3. import java.util.List;
  4. import org.apache.ibatis.io.Resources;
  5. import org.apache.ibatis.session.SqlSession;
  6. import org.apache.ibatis.session.SqlSessionFactory;
  7. import org.apache.ibatis.session.SqlSessionFactoryBuilder;
  8. import com.miquan.mybatis.bean.User;
  9. import com.miquan.mybatis.inter.IUserOperation;
  10. public class Test {
  11. static SqlSession session;
  12. public static void main(String[] args) {
  13. try {
  14. //获取session
  15. InputStream is = Resources.getResourceAsStream("mybatisconfig.xml");
  16. SqlSessionFactory sqlSessionFactory =
  17. new SqlSessionFactoryBuilder().build(is);
  18. session = sqlSessionFactory.openSession();
  19. //XML配置对应用法
  20. //          User user = session.selectOne("com.miquan.mybatis.bean.UserDB.selectById", 1);
  21. //          System.out.println(user.toString());
  22. //接口调用法
  23. //////注意:insert、delete和update方法调用之后必须commit才能真正的改变数据
  24. IUserOperation userOperation = session.getMapper(IUserOperation.class);
  25. //查
  26. //          User user = userOperation.selectById(1);
  27. //          System.out.println(user.toString());
  28. //查找List
  29. //          List<User> users = userOperation.selectUsers("miquan");
  30. //          System.out.println(users.size());
  31. //增
  32. //          User user = new User();
  33. //          user.setUserName("zhiquan");
  34. //          user.setPassword("999");
  35. //          userOperation.addUser(user);
  36. //          session.commit();
  37. //删
  38. //          userOperation.delUser(7);
  39. //          session.commit();
  40. //改
  41. User user = new User(8, "qiantu", "shaxppp");
  42. userOperation.updateUser(user);
  43. session.commit();
  44. } catch (Exception e) {
  45. e.printStackTrace();
  46. } finally {
  47. try {
  48. session.close();
  49. } catch (Exception e) {
  50. e.printStackTrace();
  51. }
  52. }
  53. }
  54. }

简单的增删查改可以实现了。

上一篇:1017 Queueing at Bank (25 分)


下一篇:PAT 甲级 1040 Longest Symmetric String (25 分)(字符串最长对称字串,遍历)