java框架mybatis_java框架之MyBatis

主流框架的介绍

Struts2

1、MVC设计模式的实现

2、拦截器

3、可变和可重用的标签

主要用于Web应用的

HiberNate(对数据JDBC)

1、ORM,简化数据库操作,对象关系映射

2、DAO层

Spring框架

1、依赖注入容器、AOP实现

2、声明式事务

3、简化JavaEE应用

4、黏合剂,将大家组装到一起

Spring MVC框架(Spring框架的一部分,web层)

1、结构最清晰的MVC Model2实现

2、高度可配置,支持多种视图技术

3、定制化开发

MyBatis框架

1、半自动化的ORM实现

2.DAO层

3、动态SQL

4、小巧灵活、简单易学

持久化是程序数据在瞬时状态和持久状态间转换的过程

内存到存储设备或者数据库保存的过程。

ORM(Object Relational Mapping)

1、编写程序的时候,以面向对象的方式处理数据

2、保存数据的时候,却以关系型数据库的方式存储

ORM解决方案包含下面四个部分

1、在持久化对象上执行基本的增、删、改、查操作

2、对持久化对象提供一种查询语言或者API

3、对象关系映射工具

4、提供事务对象交互、执行检查、延迟加载以及其他优化功能

框架(Framework)

1、提供重用的公共结构的应用程序半成品

2、优点

专注于业务逻辑实现,不再考虑公共问题

结构统一,易于学习、维护

主流框架技术

MyBatis、Hibernate

Spring

Spring MVC struts2

ORM

对象、关系映射,数据持久化技术

MyBatis、Hibernate

理解MyBatis的概念以及优点特性

搭建MyBatis开发环境

了解MyBatis与JDBC的区别

MyBatis前身是iBatis,本是Apache的一个开源的项目

http://mybatis.org   Github网站

ORM框架

实体类与SQL语句之间建立映射关系

特点

基于SQL语法,简单易学

能了解底层封装过程

SQL语句封装在配置文件中,便于统一管理与维护,降低程序的耦合度

方便程序代码调试

使用MyBatis的开发步骤

1、下载mybatis-3.2.2.jar包并导入工程

2、编写MyBatis核心配置文件(configuration.xml)

3、创建实体类-POJO

4、DAO层——SQL映射文件(mapper.xml)

5、创建测试类

1)、读取全局配置文件mybatis-config.xml

2)、创建SqlSessionFactory对象,读取配置文件

3)、创建SqlSession对象

4)、调用mapper文件进行数据操作

String resource = "mybatis-config.xml";

int count = 0;

SqlSession sqlSession = null;

//获取mybatis-config.xml的输入流

InputStream is = Resources.getResourceAsStream(resource);

//创建SqlSessionFactory对象,此对象可以完成对配置文件的读取

SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);

//创建sqlSession

sqlSession = factory.openSession();

//调用mapper文件来对数据进行操作,必须将Mapper文件引进到

count = sqlSession.selectOne("cn.smbms.dao.user.UserMapper.count");

System.out.println(count);

java中提供了Properties类来读取配置文件

String getProperty(String key) 用指定的键在此属性列表中搜索属性。通过参数key得到其对应的值

Object setProperty(String key,String value)调用Hashtable的方法Put.通过调用基类put()方法来设置键—值对

void load(InputStream inStream)从输入流中读取属性列表()键和元素对)。通过对指定文件进行装载获取该文件中所有键—值对

void clear()  清除所装载的键—值对,该方法由基类Hashtable提供

MyBatis框架优缺点

优点:

1、与JDBC相比,减少了50%以上的代码量

2、最简单的持久化框架、小巧并简单易学

3、SQL代码从程序代码中分离、可重用

4、提供XML标签,支持编写动态SQL

5、提供映射标签,支持对象与数据库的ORM字段关系映射

缺点:

1、SQL语句编写工作量大,对开发人员有一定要求

2、数据库移植性差

MyBatis专注于SQL本身,是一个足够灵活的DAO层解决方案,适用于性能要求较高或者需求多变的互联网项目

SqlSessionFactoryBuilder

1、用过即丢,其生命周期只存在于方法体内

2、可重用其来创建多个SqlSessionFactory实例

3、负责构建SqlSessinoFactory,并提供多个bulid方法的重载

String resource = "mybatis-config.xml";

InputStream is = Resources.getResourceAsStream(resource);

//创建SqlSessionFactory对象,此对象可以完成对配置文件的读取

SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);

SqlSessionFactory

1、SqlSessionFactory是每个MyBatis应用的核心

2、作用创建SqlSession实例

SqlSession sqlSession = SqlSessionfactory.openSession(boolean autoCommit);true:关闭事务控制(默认),false:开启事务

3、作用域、Application

4/生命周期与应用的生命周期相同

单例

存在于整个应用运行时,并且同时只存在一个对象实例

静态代码块,以保证SqlSessionFactory只被创建一次

SqlSession

1、包含了执行SQL所需的所有方法

2、对应一次数据库会话(可以多次执行SQL语句,关闭了救药重新创建SqlSession对象),会话结束必须关闭

3、线程级别,不能共享(最近作用域request)

SqlSession sqlSession = SqlSessionfactory.openSession(boolean autoCommit)

SqlSession的两种使用方式

1、通过SqlSession实例直接运行映射的SQL语句

select count(1) as count from smbms_user

//调用mapper文件来对数据进行操作,必须将Mapper文件引进到

count = sqlSession.selectOne("cn.smbms.dao.user.UserMapper.count");

2、基于Mapper接口方式操作数据

userList = sqlSession.getMapper(UserMapper.class).getUserList();

非集成环境下的最佳实践

SqlSessionFactoryBuilder

用过即丢,推荐作用域在方法体内

SqlSessionFactory

最佳作用域范围:应用的全局作用域

生命周期应与应用的生命周期相同

3、SqlSession

线程级

一个request请求期间

MyBatis的基本元素——核心配置文件config.xml

configuration配置

1、properties 可以配置在Java属性配置文件中

2、settings 修改MyBatis在运行时的行为方式

3、typeAliases 为Java类型命名一个别名(简称))

4、typeHandlers 类型处理器

5、objectFactory 对象工厂

6、plugins 插件

7、environments 环境

8、environment 环境变量

transactionManager 事务管理

dataSource 数据源

9、mappers 映射器

properties 可以配置在Java属性配置文件中

1、可通过外部指定的方式,即配置典型的Java属性配置文件中(如database.properties),并使用这些属性对配置实现动态配置

database.properties文件内容:

driver=com.mysql.jdbc.Driver

url=jdbc:mysql://localhost:3306/smbms

user=root

password=@lazy

config.xml文件引用

2、直接配置为xml,并使用这些属性对配置项实现动态配置

settings元素

用来修改MyBatis运行时的行为方式

主要是MyBatis的一些全局配置属性的设置

typeAliases元素

作用是配置类型别名

在Mapper.xml中

未使用typeAliases元素时

使用了typeAliases元素

第二中方式,直接引入包

在Mapper.xml中,类型直接使用类的名称

environments元素

1、表示配置MyBatis的多套运行环境,将SQL映射到多个不同的数据库上

2、子元素节点:environment,但是必须知道其中一个默认运行环境(通过default指定)

//默认的运行环境ID

//运行环境ID

//运行环境ID

.....

transactionManager事务管理器

//MANAGED托管

dataSource元素使用基本JDBC数据源接口配置JDBC连接对象的资源

mappers元素

mappers:映射器,定义SQL映射语句

需在配置中引用mapper映射文件

方式一:使用类资源路径获取资源

方式2:使用URL获取资源

mapper配置

select count(*) from smbms_user

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值