Mybatis--01

mybatis 封装jdbc访问代码的一个框架 (hibernate)  ORM对象关系映射

SpringMVC:用来封装servlet的框架 (struts)

Spring:体系整合框架,其他框架的粘合剂

框架:整个或者部分系统的可重用设计,

优点:1、灵活可配置:将写死的代码放到配置文件中

2、复用性高:将反复使用的代码抽取封装

3、对底层细节进行封装,提供了方便调用的api

主要内容:

1 mybatis 介绍

2 入门 :使用jdbc操作数据库存在的问题

    Mybatis的架构

    Mybatis的入门程序

3 Dao的开发

    原始dao的开发

    动态代理方式

4 SqlMapConfig.xml文件说明

一。介绍

持久层框架,对jdbc的操作进行封装,只需关注sql本身,不用处理加载驱动、创建连接、创建语句等过程

通过xml过着注解的方式将要执行的各种statement(statement、preparedStatement、CallableStatement)配置起来,并且通过java对象和statement中的sql进行映射生成最终执行的sql语句,最后油mybatis框架执行sql语句,并将结果映射成java对象并且返回。

二、

2.1使用jdbc的问题总结:

  导入jar

  创建工程

  步骤:

    1、加载驱动

    2、获取连接

    3、创建语句对象

    4、设置sql语句

    5、设置sql参数(preparedStatement)

    6、执行sql

    7、关闭资源

  缺点:资源浪费、硬编码不容易维护、preparedStatement占位符不移维护、结果集的解析硬编码

实例:

1、配置数据库jdbc

2、配置mybatis的配置文件

3、创建entity类 User

4、为User配置user。xml文件

其中的id使用#{id} or #{value}

5、测试数据库连接和数据获取

控制台提示logger 需要打印日志

Mybatis的增删改查

    模糊查询:

     

    在运行的java类中调用 session.selectList方法获取 List<User>

     添加对象:

      

使用标签实现插入数据后返回主键的值 主键回填

    

修改记录:

session.udpate commit

      删除用户:

      

        session.delete

Mybatis 工作原理以及流程:

    

优点:

1 节省资源

2 sql语句在xml文件中和java‘代码分离

3 将对象自动映射到sql语句 通过parameterType定义输入参数类型

4 将sql执行结果映射到java对象 通过stateme 的resultType定义输出结果的类型

使用反射机制

mybatis两种方式:

1.原始的dao方法

2.使用mapper代理进行开发

(1)namespace和Dao接口的名称保持一致(原本是实体类的名称)

代理实现类的流程

总结:mybatis是基于动态代理实现的,cglib.jar   

原始Dao开发中的问题:

  重复代码 SQLSession

  不存在硬编码问题(方法和id之类的东西)

使用mapper代理,不需要创建DaoImpl就可以实现

mapper动态代理的开发规范:

  只需要编写mapper接口(Dao 接口)

    1、mapper.xml文件中的namespace与mapper接口的类路径相同

    2、mapper接口方法名和mapper.xml文件中的每个sql的id

    3、parameterType

    4、resultType

mapper.xml映射文件:

  内容同user.xml文件 修改namespace的值为UserMapper接口路径,并将UserMapper.xml文件放大classpath下的mapper目录

当mapper文件特别多的时候 可以再mybatis的配置文件中批量扫描

mybatis配置文件中的其他属性

别名标签

别名默认使用类名的小写

简单类型 支持自动别名

  

原文地址:https://www.cnblogs.com/zhy-study/p/9247294.html

时间: 2025-01-16 20:38:40

Mybatis--01的相关文章

【maven系列】:maven构建模块化项目之SpringMVC整合Mybatis (01)

一.整合所需jar包 <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>${spring-version}</version> </dependency> <!-- 整合mybatis所需jar包 --> <dependency> <gr

我喜欢减肥我们来减肥吧

http://www.ebay.com/cln/honus.jyw4mvptb/cars/158313278016/2015.01.28.html http://www.ebay.com/cln/honus.jyw4mvptb/cars/158313282016/2015.01.28.html http://www.ebay.com/cln/honus.jyw4mvptb/cars/158313289016/2015.01.28.html http://www.ebay.com/cln/usli

百度回家看沙发沙发是减肥了卡斯加积分卡拉是减肥

http://www.ebay.com/cln/hpryu-caw8ke/cars/158056866019/2015.01.31 http://www.ebay.com/cln/xub.50x2l7cj/cars/158445650015/2015.01.31 http://www.ebay.com/cln/xub.50x2l7cj/cars/158445674015/2015.01.31 http://www.ebay.com/cln/xub.50x2l7cj/cars/1584456790

巢哑偕倥乇椭煞谙暗逞帕俸

IEEE Spectrum 杂志发布了一年一度的编程语言排行榜,这也是他们发布的第四届编程语言 Top 榜. 据介绍,IEEE Spectrum 的排序是来自 10 个重要线上数据源的综合,例如 Stack Overflow.Twitter.Reddit.IEEE Xplore.GitHub.CareerBuilder 等,对 48 种语言进行排行. 与其他排行榜不同的是,IEEE Spectrum 可以让读者自己选择参数组合时的权重,得到不同的排序结果.考虑到典型的 Spectrum 读者需求

我国第三代移动通信研究开发进展-尤肖虎200106

众所周知,数据科学是这几年才火起来的概念,而应运而生的数据科学家(data scientist)明显缺乏清晰的录取标准和工作内容.此次课程以<星际争霸II>回放文件分析为例,集中在IBM Cloud相关数据分析服务的应用.面对星际游戏爱好者希望提升技能的要求,我们使用IBM Data Science Experience中的jJupyter Notebooks来实现数据的可视化以及对数据进行深度分析,并最终存储到IBM Cloudant中.这是个介绍+动手实践的教程,参会者不仅将和讲师一起在线

pl/sql学习1——标量变量psahnh6S

为类型.不能用于表列的数据类型.范围为的子类型.自然数.为的子类型.具有约束为单精度浮点数.为变量赋值时.后面要加为双精度浮点数.为变量赋值时.后面要加.为数字总位数.为小数位数是的子类型.最大精度位是的子类型.最大精度位单精度浮点型是的子类型.最大精度位双精度浮点型定义精度为位的实数..定义为位的整数.变长字符串.最长测试变量数据!.定长字符串.最长测试变长二进制字符串物理存储的为类型...固定长度.个字节使用定义数据类型那个最小值:最大值:最小值:最大值:最小值:最大值:最小值:最大值:最小

01 Mybatis 整体架构

01 Mybatis 简介 Mybatis 整体架构分为三层,分别是基础层.核心处理层.和接口层.如下图: 基础支持层 基础支持层包含整个 Mybatis 的基础模块,这些模块为核心处理层的功能提供了良好的支撑下面简单描述各个模块的功能. 反射模块 MyBatis 中专门提供了反射模块,该模块对Java 原生的反射进行了良好的封装,提供了更加简洁易用的 API, 方便上层使调用,并且对反射操作进行了一系列优化,例如缓存了类的元数据,提高了反射操作的性能. 类型转换模块 MyBatis 为简化配置

02—mybatis的基本用法01

深入mybatis的配置文件(mybatis-config.xml) MyBatis的配置文档结构 顶层configuration 配置 properties 属性 settings 设置 typeAliases 类型命名 typeHandlers 类型处理器 objectFactory 对象工厂 plugins 插件 environments 环境 |-environment 环境变量 |-transactionManager 事务管理器 |-dataSource 数据源 databaseId

MyBatis 学习总结 01 快速入门 OLD

一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录.mybatis提供一种“半自动化”的ORM实现.这里的“半自动化”,是相对Hibernate等提供了全面的数据库封装机制的“全自动化”ORM实

MyBatis 教程01

<!-- \src\com\java1234\mappers\AddressMapper.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"&