我们已经讨论了各种MyBatis配置元素,如envronments、typeAlias和typeHandlers,以及如何使用XML配置它们。即使你想使用基于JavaAPI的MyBatis配置,MyBatis的SqlSessionFactory接口除了使用基于XML的配置创建外也可以通过Java API 编程式地被创建。每个在XML中配置的元素,都可以编程式的创建。使用Java API创建SqlSessionFactory,代码如下:

 
 

    public static SqlSessionFactory getSqlSessionFactory()  

    {  

        SqlSessionFactory sqlSessionFactory = null;  

        try  

        {  

            DataSource dataSource = DataSourceFactory.getDataSource();  

            TransactionFactory transactionFactory = new  xJdbcTransactionFactory();  

            Environment environment = new Environment("development",  transactionFactory, dataSource);  

            Configuration configuration = new Configuration(environment);  

            configuration.getTypeAliasRegistry().registerAlias("student",  Student.class);  

            configuration.getTypeHandlerRegistry().register(PhoneNumber. class, PhoneTypeHandler.class);  

            configuration.addMapper(StudentMapper.class);  

            sqlSessionFactory = new SqlSessionFactoryBuilder().  build(configuration);  

        }  

        catch (Exception e)  

        {  

            throw new RuntimeException(e);  

        }  

        
 

  1. 环境配置 environment

    我们需要为想使用MaBatis连接的每一个数据库创建一个 Enviroment对象。为了使用每一个环境,我们需要为每一个环境environment创建一个SqlSessionFactory对象。而创建Environment对象,我们需要java.sql.DataSource和TransactionFactory实例。下面让我们看看如何创建DataSource 和
    TransactionFactory
    对象。

  2. 数据源DataSource

    MyBatis支持三种内建的DataSource类型: UNPOOLED, POOLED, 和JNDI.

  • UNPOOLED类型的数据源dataSource为每一个用户请求创建一个数据库连接。在多用户并发应用中,不建议使用。
  • POOLED类型的数据源dataSource创建了一个数据库连接池,对用户的每一个请求,会使用缓冲池中的一个可用的Connection对象,这样可以提高应用的性能。MyBatis提供了org.apache.ibatis.datasource.pooled.PooledDataSource 实现javax.sql.DataSource来创建连接池。
  • JNDI类型的数据源dataSource使用了应用服务器的数据库连接池,并且使用JNDI查找来获取数据库连接。

让我们看一下怎样通过MyBatis的PooledDataSource获得DataSource对象,如下:

        public class DataSourceFactory  

        {  

            public static DataSource getDataSource()  

            {  

                String driver = "com.mysql.jdbc.Driver";  

                String url = "jdbc:mysql://localhost:3306/mybatisdemo";  

                String username = "root";  

                String password = "admin";  

                PooledDataSource dataSource = new PooledDataSource(driver, url,  

                        username, password);  

                return dataSource;  

            }  

一般在生产环境中,DataSource会被应用服务器配置,并通过JNDI获取DataSource对象,如下所示:

        public class DataSourceFactory  

        {  

            public static DataSource getDataSource()  

            {  

                String jndiName = "java:comp/env/jdbc/MyBatisDemoDS";  

                try  

                {  

                    InitialContext ctx = new InitialContext();  

                    DataSource dataSource = (DataSource) ctx.lookup(jndiName);  

                    return dataSource;  

                }  

                catch (NamingException e)  

                {  

                    throw new RuntimeException(e);  

                }  

            }

}

当前有一些流行的第三方类库,如commons-dbcp和c3p0实现了java.sql.DataSource,你可以使用它们来创建dataSource。

  1. 事务工厂TransactionFactory

    MyBatis支持一下两种TransactionFactory实现:

  • JdbcTransactionFactory
  • ManagedTransactionFactory

如果你的应用程序运行在未托管(non-managed)的环境中,你应该使用JdbcTransactionFactory。

        DataSource dataSource = DataSourceFactory.getDataSource();  

        TransactionFactory txnFactory = new JdbcTransactionFactory();  

        Environment environment = new Environment("development", txnFactory, dataSource);  

如果你的应用程序运行在未托管(non-managed)的环境中,并且使用容器支持的事务管理服务,你应该使用ManagedTransactionFactory。

        DataSource dataSource = DataSourceFactory.getDataSource();  

        TransactionFactory txnFactory = new ManagedTransactionFactory();  

Environment environment = new Environment("development", txnFactory, dataSource); 

  1. 类型别名typeAliases

    MyBatis 提供以下几种通过Configuration对象注册类型别名的方法:

  • 根据默认的别名规则,使用一个类的首字母小写、非完全限定的类名作为别名注册,可使用以下代码:

    configuration.getTypeAliasRegistry().registerAlias(Student.class);  

  • 指定指定别名注册,可使用以下代码:

    configuration.getTypeAliasRegistry().registerAlias("Student",Student.class);  

  • 通过类的完全限定名注册相应类别名,可使用一下代码:

    configuration.getTypeAliasRegistry().registerAlias("Student", "com.mybatis3.domain.Student");

  • 为某一个包中的所有类注册别名,可使用以下代码:

    configuration.getTypeAliasRegistry().registerAliases("com. mybatis3.domain"); 

  • 为在com.mybatis3.domain package包中所有的继承自Identifiable类型的类注册别名,可使用以下代码:

    configuration.getTypeAliasRegistry().registerAliases("com. mybatis3.domain", Identifiable.class);  

  1. 类型处理器typeHandlers

    MyBatis提供了一系列使用Configuration对象注册类型处理器(type handler)的方法。我们可以通过以下方式注册自定义的类处理器:

  • 为某个特定的类注册类处理器:

    configuration.getTypeHandlerRegistry().register(PhoneNumber.class, PhoneTypeHandler.class);

  • 注册一个类处理器:

    configuration.getTypeHandlerRegistry().register(PhoneTypeHandler.class);

  • 注册com.mybatis3.typehandlers包中的所有类型处理器:

    configuration.getTypeHandlerRegistry().register("com.mybatis3.typehandlers");

  1. 全局参数设置Settings

    MyBatis提供了一组默认的,能够很好地适用大部分的应用的全局参数设置。然而,你可以稍微调整这些参数,让它更好地满足你应用的需要。你可以使用下列方法将全局参数设置成想要的值。

            configuration.setCacheEnabled(true);  

            configuration.setLazyLoadingEnabled(false);  

            configuration.setMultipleResultSetsEnabled(true);  

            configuration.setUseColumnLabel(true);  

            configuration.setUseGeneratedKeys(false);  

            configuration.setAutoMappingBehavior(AutoMappingBehavior.PARTIAL);  

            configuration.setDefaultExecutorType(ExecutorType.SIMPLE);  

            configuration.setDefaultStatementTimeout(25);  

            configuration.setSafeRowBoundsEnabled(false);  

            configuration.setMapUnderscoreToCamelCase(false);  

            configuration.setLocalCacheScope(LocalCacheScope.SESSION);  

            configuration.setAggressiveLazyLoading(true);  

            configuration.setJdbcTypeForNull(JdbcType.OTHER);  

            Set<String> lazyLoadTriggerMethods = new HashSet<String>();  

            lazyLoadTriggerMethods.add("equals");  

            lazyLoadTriggerMethods.add("clone");  

            lazyLoadTriggerMethods.add("hashCode");  

            lazyLoadTriggerMethods.add("toString");  

            configuration.setLazyLoadTriggerMethods(lazyLoadTriggerMethods );

  2. Mappers

    MyBatis提供了一些使用Configuration对象注册Mapper XML文件和Mappe接口的方法。

  • 添加一个Mapper接口,可使用以下代码:

    configuration.addMapper(StudentMapper.class);  

  • 添加 com.mybatis3.mappers包中的所有Mapper XML文件或者Mapper接口,可使用以下代码:

    configuration.addMappers("com.mybatis3.mappers");  

  • 添加所有com.mybatis3.mappers包中的拓展了特定Mapper接口的Maper接口,如 aseMapper,可使用如下代码:

    configuration.addMappers("com.mybatis3.mappers", BaseMapper.class);  

笔记:MyBatis 使用 Java API配置的更多相关文章

  1. Mybatis学习--Java API

    学习笔记,选自Mybatis官方中文文档:http://www.mybatis.org/mybatis-3/zh/java-api.html#directoryStructure 既然你已经知道如何配 ...

  2. Hadoop学习笔记1 - 使用Java API访问远程hdfs集群

    转载请标注原链接 http://www.cnblogs.com/xczyd/p/8570437.html 2018年3月从新司重新起航了.之前在某司过了的蛋疼三个月,也算给自己放了个小假了. 第一个小 ...

  3. Elasticsearch Java API 配置测试

    Elasticsearch1.X,2.X,5.X随着版本的迭代,除了系统升级,Java API也做了相对较大的调整,也就是说,1.X的API在2.X以及5.X乃至未来6.X版本都不是通用的. 本例子使 ...

  4. Mybatis的Java API(八)

    使用mybatis的主要Java接口就是SqlSession.可以通过这个接口来执行命令,获取映射器和事务管理. SqlSession是由SqlSessionFactory实例创建,SqlSessio ...

  5. Neo4j学习笔记(1)——使用Java API实现简单的增删改查

    阅读目录 项目的创建及配置 使用嵌入式数据库 创建节点和关系 查询及更新 删除关系和节点 完整代码 参考资料 回到顶部 项目的创建及配置 因为Neo4j依赖的jar包比较多,所以推荐使用Maven来管 ...

  6. mybatis Java API

    既然你已经知道如何配置 MyBatis 和创建映射文件,你就已经准备好来提升技能了. MyBatis 的 Java API 就是你收获你所做的努力的地方.正如你即将看到的,和 JDBC 相比, MyB ...

  7. Java数据持久层框架 MyBatis之API学习八(Java API详解)

    对于MyBatis的学习而言,最好去MyBatis的官方文档:http://www.mybatis.org/mybatis-3/zh/index.html 对于语言的学习而言,马上上手去编程,多多练习 ...

  8. MyBatis——Java API

    Java API 既然你已经知道如何配置 MyBatis 和创建映射文件,你就已经准备好来提升技能了. MyBatis 的 Java API 就是你收获你所做的努力的地方.正如你即将看到的,和 JDB ...

  9. MyBatis(九):Mybatis Java API批量操作(增、删、改、查)

    最近工作中用到了mybatis的Java API方式进行开发,顺便也整理下该功能的用法,接下来会针对基本部分进行学习: 1)Java API处理一对多.多对一的用法: 2)增.删.改.查的用法: 3) ...

随机推荐

  1. H3C单臂路由配置

    Route配置 int g0/0.1 ip add 192.168.10.1 255.255.255.0 vlan-type dot1q vid 10 #子接口封装dot1q并分配给VLAN 10 q ...

  2. csrf

    什么是CSRF: CSRF(Cross-site request forgery),中文名称:跨站请求伪造 攻击者盗用了你的身份,以你的名义发送恶意请求.CSRF能够做的事情包括:以你名义发送邮件,发 ...

  3. 网络基础tcp/ip协议三

    数据链路层:(位于网络层与物理层之间) 数据链路层的功能: 数据链路的建立,维护. 帧包装,帧传输,帧同步. 帧的差错恢复. 流量的控制. 以太网:(工作在数据链路层) CSMA/CD(带冲突检测的载 ...

  4. Android4种网络连接方式HttpClient、HttpURLConnection、OKHttp和Volley优缺点和性能对比

    比较的指标: 1.cpu 2.流量 3.电量 4.内存占用 5.联网时间 功能点: 1.重试机制 2.提供的扩展功能 3.易用性 4.是否https 5.是否支持reflect api,OkHttp有 ...

  5. zTree实现地市县三级级联Service接口测试

    zTree实现地市县三级级联Service接口测试 ProvinceServiceTest.java: /** * @Title:ProvinceServiceTest.java * @Package ...

  6. Direcshow中视频捕捉和参数设置报告

    Direcshow中视频捕捉和参数设置报告 1.      关于视频捕捉(About Video Capture in Dshow) 1视频捕捉Graph的构建 一个能够捕捉音频或者视频的graph图 ...

  7. CF368 D - Persistent Bookcase

    re了20多发 还是我在测试数据上操作最后了10多发才发现的 其实只需要多加一句就好了 真的愚蠢啊,要不都能进前100了 #include<bits/stdc++.h> using nam ...

  8. 在Visual Studio 2012中使用GSL

    1. 下载GSL http://gnuwin32.sourceforge.net/packages/gsl.htm 下载 Complete package, except sources和Source ...

  9. Python--urllib3库详解1

    Python--urllib3库详解1 Urllib3是一个功能强大,条理清晰,用于HTTP客户端的Python库,许多Python的原生系统已经开始使用urllib3.Urllib3提供了很多pyt ...

  10. 在laravel环境下将图片存入MongoDB数据库

    html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,bi ...