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配置文件中的其他属性

别名标签

别名默认使用类名的小写

简单类型 支持自动别名

  

Mybatis--01的更多相关文章

  1. Hello Mybatis 01 第一个CRUD

    What's the Mybatis? MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google c ...

  2. 框架学习-MyBatis(01)

    1.MyBatis是持久层框架 什么是持久化: 狭义:把数据永久性的保存到数据当中 广义:针对于数据库的所有操作都称为持久化操作,CreateReadUpdateDelete操作 2.有哪些持久层框架 ...

  3. MyBatis 01 概述

    官网 http://www.mybatis.org/mybatis-3/zh/index.html GitHub https://github.com/mybatis/mybatis-3 简介 MyB ...

  4. mybatis 01: 静态代理 + jdk动态代理

    背景 有时目标对象不可直接访问,只能通过代理对象访问 图示: 示例1: 房东 ===> 目标对象 房屋中介 ===> 代理对象 你,我 ===> 客户端对象 示例2: 运营商(电信, ...

  5. 01 Mybatis 的配置和使用

    一.Mybatis 是什么 MyBatis 是一个支持普通SQL查询.存储过程和高级映射的优秀持久层框架.MyBatis 消除了几乎所有的 JDBC 代码和参数的手工设置以及对结果集的检索封装.MyB ...

  6. 编程从入门到放弃(Java)

      1.Java入门篇 1.1 基础入门和面向对象 1.1.1 编程基础 [01] Java语言的基本认识 [02] 类和对象 [03] 类的结构和创建对象 [04] 包和访问权限修饰符 [05] 利 ...

  7. Spring 08: AOP面向切面编程 + 手写AOP框架

    核心解读 AOP:Aspect Oriented Programming,面向切面编程 核心1:将公共的,通用的,重复的代码单独开发,在需要时反织回去 核心2:面向接口编程,即设置接口类型的变量,传入 ...

  8. 01.MyBatis入门

        MyBatis入参考文档:http://mybatis.org/mybatis-3/zh/  1.使用MyBatis前的准备 1.增加Maven依赖 <dependency> &l ...

  9. 01 mybatis框架整体概况(2018.7.10)-

    01 mybatis框架整体概况(2018.7.10)- F:\廖雪峰 JavaEE 企业级分布式高级架构师课程\廖雪峰JavaEE一期\第一课(2018.7.10) maven用的是3.39的版本 ...

  10. mybatis第二天01

    MyBatis第二天01 1.高级结果映射 1.1根据视频案例,分析表之间的关系 数据模型分析 1. 明确每张表存储的信息 2. 明确每张表中关键字段(主键.外键.非空) 3. 明确数据库中表与表之间 ...

随机推荐

  1. 【转】Linux C下非特定波特率的配置和使用

    https://blog.csdn.net/jinhongdu/article/details/43413071  对于非标准的任意波特率需要用ioctl(fd, TIOCGSERIAL,  p)和i ...

  2. 产线nginx路径跳转问题

    问题描述 应用在客户产线环境部署时,要求只需要输入域名就可以直接访问到应用,而不用输入完整的应用访问路径. 项目架构 前端使用nginx作为反向代理和负载均衡,后端部署多个tomcat实例. Web应 ...

  3. tomcat源码研究之源码导入eclipse

    版本:8.5.x官网:https://tomcat.apache.org/svn.html1. 下载源码,git镜像:https://github.com/apache/tomcat85 .2. 导入 ...

  4. windows安装mysql示例

    1. 下载mysql安装包,如: mysql-5.6.34-winx64.zip2. 解压安装包到指定目录,如:D盘,即:D:\mysql-5.6.34-winx643. 配置 cd D:\mysql ...

  5. 新萌渗透测试入门DVWA 教程1:环境搭建

    首先欢迎新萌入坑.哈哈.你可能抱着好奇心或者疑问.DVWA 是个啥? DVWA是一款渗透测试的演练系统,在圈子里是很出名的.如果你需要入门,并且找不到合适的靶机,那我就推荐你用DVWA. 我们通常将演 ...

  6. ubuntu18.04下安装mysql后无法用mysqlworkbench访问

    问题描述:我在ubuntu18.04下执行以下命令安装mysql时遇到了mysqlworkbench无法连接root用户的问题.ubuntu18.04下默认安装mysql时是5.7版本的,但是5.7版 ...

  7. 用PHP来获取access_token

    $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".A ...

  8. Utterance-Wise Recurrent Dropout And Iterative Speaker Adaptation For Robust Monaural Speech Recognition

    单声道语音识别的逐句循环Dropout迭代说话人自适应     WRBN(wide residual BLSTM network,宽残差双向长短时记忆网络) [2] J. Heymann, L. Dr ...

  9. Innobackupex(xtrabackup)物理备份

    1. Percona XtraBackup介绍 Percona XtraBackup(简称PXB)是 Percona 公司开发的一个完全开源的用于 MySQL 数据库物理热备的备份工具,在备份过程中不 ...

  10. Python常用模块之json模块

    常用模块: 一个Python文件就是一个模块 import xxx 1. 标准模块,Python自带的,如time/random 2. 第三方模块,如连接mysql,需要安装 3. 自己写的Pytho ...