zoukankan      html  css  js  c++  java
  • MyBatis入门学习

    所需要jar包:mybatis-3.x.x.jar 、如果需要和spring整合,还需要加入相关的包

    1:看项目目录 红颜色不要关心

    2:按照步骤:

    1:加入jar包

    2:创建数据源(configuration.xml)创建数据库(此处省略)

    [html]view plaincopyprint?

    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. <typeAliases>
    7. <!--给实体类起一个别名 user -->
    8. <typeAlias type="com.forum.po.User" alias="User" />
    9. </typeAliases>
    10. <!--数据源配置  这块用 BD2数据库 -->
    11. <environments default="development">
    12. <environment id="development">
    13. <transactionManager type="jdbc" />
    14. <dataSource type="POOLED">
    15. <property name="driver" value="com.ibm.db2.jcc.DB2Driver" />
    16. <property name="url" value="jdbc:db2://localhost:50000/forum" />
    17. <property name="username" value="DB2ADMIN" />
    18. <property name="password" value="admin" />
    19. </dataSource>
    20. </environment>
    21. </environments>
    22. <mappers>
    23. <!--userMapper.xml装载进来  同等于把“dao”的实现装载进来 -->
    24. <mapper resource="myBatis/userMapper.xml" />
    25. </mappers>
    26. </configuration>

    3:创建实体类USER

    [java]view plaincopyprint?

    1. package com.forum.po; 
    2. /**
    3. * 用户类
    4. *
    5. * @author db2admin
    6. *
    7. */
    8. public class User extends Entity { 
    9. private String name; 
    10. private Integer age; 
    11. public String getName() { 
    12. return name; 
    13.     } 
    14. public void setName(String name) { 
    15. this.name = name; 
    16.     } 
    17. public Integer getAge() { 
    18. return age; 
    19.     } 
    20. public void setAge(Integer age) { 
    21. this.age = age; 
    22.     } 
    23. public User() { 
    24.     } 

    4:创建dao接口、可以说是Mapper接口:UserMapper

    [java]view plaincopyprint?

    1. package com.forum.dao; 
    2. import com.forum.po.User; 
    3. public interface UserMapper { 
    4. public User findById(String Id); 

    5:创建dao的实现,不同于hibernarte的此处的实现为一个xml文件,也就是userMapper.xml

    [html]view plaincopyprint?

    1. <?xml version="1.0" encoding="UTF-8" ?>
    2. <!DOCTYPE mapper PUBLIC  
    3.     "-//mybatis.org//DTD Mapper 3.0//EN" 
    4.     "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    5. <!--这块等于dao接口的实现  namespace必须和接口的类路径一样-->
    6. <mapper namespace="com.forum.dao.UserMapper">
    7. <!-- findById必须和接口中的方法名一样  返回一个User  就是刚才的别名  如果不弄别名要连类路径一起写 麻烦-->
    8. <select id="findById" parameterType="HashMap" resultType="User">
    9.         select 
    10.         * from butone.student where id=#{id} 
    11. </select>
    12. </mapper>


    6:测试类,MyBatisTest

    [java]view plaincopyprint?

    1. package com.forum.test; 
    2. import java.io.IOException; 
    3. import org.apache.ibatis.io.Resources; 
    4. import org.apache.ibatis.session.SqlSession; 
    5. import org.apache.ibatis.session.SqlSessionFactory; 
    6. import org.apache.ibatis.session.SqlSessionFactoryBuilder; 
    7. import com.forum.dao.UserMapper; 
    8. import com.forum.po.User; 
    9. /**
    10. * myBatis数据库连接测试
    11. *
    12. * @author db2admin
    13. *
    14. */
    15. public class MyBatisTest { 
    16. /**
    17.      * 获得MyBatis SqlSessionFactory 
    18.      * SqlSessionFactory负责创建SqlSession,一旦创建成功,就可以用SqlSession实例来执行映射语句,commit,rollback,close等方法。
    19.      * @return
    20.      */
    21. private static SqlSessionFactory getSessionFactory() { 
    22.         SqlSessionFactory sessionFactory = null; 
    23.         String resource = "configuration.xml"; 
    24. try { 
    25.             sessionFactory = new SqlSessionFactoryBuilder().build(Resources 
    26.                     .getResourceAsReader(resource)); 
    27.         } catch (IOException e) { 
    28. // TODO Auto-generated catch block
    29.             e.printStackTrace(); 
    30.         } 
    31. return sessionFactory; 
    32.     } 
    33. public static void main(String[] args) { 
    34.         SqlSession sqlSession = getSessionFactory().openSession(); 
    35.         UserMapper userMapper = sqlSession.getMapper(UserMapper.class); 
    36.         User user = userMapper.findById("1"); 
    37.         System.out.println(user.getName()); 
    38.     } 

    原文地址;http://blog.csdn.net/huzheaccp/article/details/7399124

     

    MyBatis之作用域和生命周期

     

    本文转自:MyBatis3用户指南中文版、入门五,关于这个文档我上传的资源里边有,大家可以去下载!

    http://download.csdn.net/detail/huzheaccp/4177008

    http://download.csdn.net/detail/huzheaccp/4177008

    http://download.csdn.net/detail/huzheaccp/4177008

    对于这些概念性的东西,总怕自己说不清楚,害怕害了看了我博客的人,所以抄书,哈哈...

    理解作用域和生命周期类非常重要,如果使用不当,会造成各种各样的问题。

    1.SqlSessionFactoryBuildeSqlSessionFactoryBuilder

    [plain]view plaincopyprint?

    1. 这个类可以被初始、使用和丢弃,如果你已经创建好了一个SqlSessionFactory 后就不用再保留它。因此, 
    2. SqlSessionFactoryBuilder 的最好作用域是方法体内, 比如说定义一个方法变量。你可以重复使用 
    3. SqlSessionFactoryBuilder 生成多个SqlSessionFactory 实例,但是最好不要强行保留,因为XML 的解析资 
    4. 源要用来做其它更重要的事。 

    2.SqlSessionFactory

    [plain]view plaincopyprint?

    1. 一旦创建,SqlSessionFactory 就会在整个应用过程中始终存在。所以没有理由去销毁和再创建它,一个 
    2. 应用运行中也不建议多次创建SqlSessionFactory。如果真的那样做,会显得很拙劣。因此SqlSessionFactory 
    3. 最好的作用域是Application。可以有多种方法实现。最简单的方法是单例模式或者是静态单例模式。然 
    4. 而这既不是广泛赞成和好用的。反而,使用Google Guice 或Spring 来进行依赖反射会更好。这些框架允 
    5. 许你生成管理器来管理SqlSessionFactory 的单例生命周期。 

    3.SqlSession

    [plain]view plaincopyprint?

    1. 每个线程都有自己的SqlSession 实例,SqlSession 实例是不能被共享,也是不是线程安全的。因此最好 
    2. 使用Request 作用域或者方法体作用域。不要使用类的静态变量来引用一个SqlSession 实例,甚至不要 
    3. 使用类的一个实例变更来引用。永远不要在一个被管理域中引用SqlSession ,比如说在Servlet 中的 
    4. HttpSession 中。如果你正在使用WEB 框架,应该让SqlSession 跟随HTTP 请求的相似作用域。也就是 
    5. 说,在收到一个HTTP 请求过后,打开SqlSession,等返回一个回应以后,立马关掉这个SqlSession。关 
    6. 闭SqlSession 是非常重要的。你必须要确保SqlSession 在finally 方法体中正常关闭。可以使用下面的标 
    7. 准方式来关闭: 
    8. SqlSession session = sqlSessionFactory.openSession(); 
    9. try { 
    10. // do work 
    11. } finally { 
    12. session.close(); 

    使用这种模式来贯穿你的所有代码,以确保所有数据库资源都被完全关闭。[这是假定不是使用你自己的
    数据库连接,而是使用MyBatis 来管理你的数据库连接资源]

    4.Mapper实例

    [plain]view plaincopyprint?

    1. Mapper 是一种你创建的用于绑定映射语句的接口。Mapper 接口的实例是用SqlSession 来获得的。同样, 
    2. 从技术上来说,最广泛的Mapper 实例作用域像SqlSession 一样,使用请求作用域。确切地说,在方法 
    3. 被调用的时候调用Mapper 实例,然后使用后,就自动销毁掉。不需要使用明确的注销。当一个请求执 
    4. 行正确无误的时候,像SqlSession 一样,你可以轻而易举地操控这一切。保持简单性,保持Mapper 在 
    5. 方法体作用域内。下面演示了如果来操作: 
    6. SqlSession session = sqlSessionFactory.openSession(); 
    7. try { 
    8. BlogMapper mapper = session.getMapper(BlogMapper.class); 
    9. // do work 
    10. } finally { 
    11. session.close(); 

    原文地址:http://blog.csdn.net/huzheaccp/article/details/7399286

  • 相关阅读:
    JAVA程序员常用英语
    计算机常用英语汇总
    从一个前端角度来说页面的优化:雅虎35条(转)
    前端学习(五)
    PS常用快捷键(收藏)
    web前端开发规范文档
    前端学习(四)
    Web前端开发面试题
    linux --批量修改文件内容
    git --添加多个文件
  • 原文地址:https://www.cnblogs.com/suizhikuo/p/3590576.html
Copyright © 2011-2022 走看看