mybatis笔记1 基本的配置和操作
mybatis比较轻量,适合开发比较小型的或者业务比较复杂的系统;
相对于hibernate来说可以灵活的写sql,更灵活的处理遇到的业务逻辑;
可以说hibernate是pojo实体对db的orm映射,而mybatis是pojo对sql的映射;
作为入门,先不考虑高级的特性,速度来一个CRUD再从源码和一个具体的业务来研究它的原理和高级特性;
CRUD基本思路:作为一种比较流行的持久层ORM框架,相当于三层架构中的dao层;
最终作为程序员的我们使用的SqlSession对象,先来个思路,再来个实现,最后研究细节;
环境准备,结合springmvc,做一个对博客文章的crud,下面贴出配置文件先;
第一列是依赖文件,都是在仓库中找到的最新的来用,兼容性如何暂且不管,先把简单的例子弄出来是关键;
第二列是web.xml的配置文件,定义一个spring的容器和mvc的url代理servlet;
第三列才是mybatis的使用环境准备,结合上图,上下往上推导定义出SqlSessionFactory,再定义出datasource和mapper配置文件;
第四列是springmvc的配置文件,相当常见,这里不解释;
<dependency> <dependency> <dependency> <dependency> <!-- 数据源和jdbc驱动依赖 start--> <dependency> <dependency> <!--log4j日志框架--> <dependency> |
<?xml version="1.0" encoding="UTF-8"?> <listener> <!--mvc配置--> </web-app> |
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <context:component-scan base-package="com.sz.mybatis.framework.service"> <context:annotation-config /> <tx:annotation-driven /> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean" scope="singleton" > <bean id="sqlSession" factory-bean="sqlSessionFactory" factory-method="openSession" scope="prototype"></bean> |
<context:component-scan base-package="com.sz.mybatis.admin.controller"> <mvc:annotation-driven/> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> |
来一个博客对象的增删改查先;controller先来,这是概要;
然后是url映射:
servic直接略过,主要关注dao的实现,先来个接口先;
实现:
package com.sz.mybatis.framework.service.impl; import com.google.common.collect.ImmutableList; import java.util.List; /** @Autowired private BlogMapper getBlogMapper() { @Override Msg msg=new Msg(); @Override @Override @Override @Override |
配置文件:
<?xml version="1.0" encoding="UTF-8" ?> <select id="list" parameterType="com.sz.mybatis.framework.domain.PageConfig" resultType="com.sz.mybatis.framework.domain.blog.Blog"> <insert id="insertBlog" parameterType="Blog"> <update id="updateBlog" parameterType="Blog"> <delete id="deleteBlog" parameterType="int"> |
一个接口方法对应一条配置,通过id对应起来,据说可以在类的注解上面写sql,那会更简单,有空我改成注解的,敬请期待…
来几张效果图先:
两个图对比标识完成了分页的操作;
两个图对比表示实现了增加的功能;
两个图对比表示实现了编辑的功能;
最后标识实现了删除的功能;
到这里crud的程序算完成了,mybatis成功的入门了…
对了,附上源码...
mybatis笔记1 基本的配置和操作的更多相关文章
- MyBatis笔记二:配置
MyBatis笔记二:配置 1.全局配置 1.properites 这个配置主要是引入我们的 properites 配置文件的: <properties resource="db.pr ...
- 【MyBatis笔记】mapper文件的配置以及说明
<!doctype html>[MyBatis笔记]mapper文件的配置以及说明 figure:last-child { margin-bottom: 0.5rem; } #write ...
- spring+mybatis的多源数据库配置实战
前言: 关于spring+mybatis的多源数据库配置, 其实是个老生常谈的事情. 网上的方案出奇的一致, 都是借助AbstractRoutingDataSource进行动态数据源的切换. 这边再无 ...
- MyBatis笔记一:GettingStart
MyBatis笔记一:GettingStart 1.MyBatis优点 我们的工具和各种框架的作用就是为了我们操作数据库简洁,对于一些数据库的工具能帮我们少写一些处理异常等等的代码,但是他们并不是自动 ...
- 初识Mybatis框架,实现增删改查等操作(动态拼接和动态修改)
此第一次接触Mybatis框架确实是有点不适应,特别是刚从Hibernate框架转转型过来,那么为什么要使用Mybatis框架,Mybatis框架和Hibernate框架又有什么异同呢? 这个问题在我 ...
- MyBatis Generator自动生成的配置及使用
注意:文件名不能有中文字符,不然不能自动生成 找到MyBatis Generator.rar\MyBatis Generator\eclipse里的features和plugins文件,把这两个文件复 ...
- 安卓第十一天笔记-Intent与inter-filter配置
安卓第十一天笔记-Intent与inter-filter配置 Intent与inter-filter配置 1.Intent对象简述 Android应用中有包含三种重要组件:Activity,Servi ...
- 初识Mybatis框架,实现增删改查等操作
此第一次接触Mybatis框架确实是有点不适应,特别是刚从Hibernate框架转转型过来,那么为什么要使用Mybatis框架,Mybatis框架和Hibernate框架又有什么异同呢? 这个问题在我 ...
- thinkphp学习笔记4—眼花缭乱的配置
原文:thinkphp学习笔记4-眼花缭乱的配置 1.配置类别 ThinkPHP提供了灵活的全局配置功能,ThinkPHP会依次加载管理配置>项目配置>调试配置>分组配置>扩展 ...
随机推荐
- 通过微信小程序看前端
前言 2016年9月22日凌晨,微信官方通过“微信公开课”公众号发布了关于微信小程序(微信应用号)的内测通知.整个朋友圈瞬间便像炸开了锅似的,各种揣测.介绍性文章在一夜里诞生.而真正收到内测邀请的公众 ...
- Git分布式版本控制教程
Git分布式版本控制Git 安装配置Linux&Unix平台 Debian/Ubuntu $ apt-get install git Fedora $ ) $ dnf and later) G ...
- java 设计模式
目录: 设计模式六大原则(1):单一职责原则 设计模式六大原则(2):里氏替换原则 设计模式六大原则(3):依赖倒置原则 设计模式六大原则(4):接口隔离原则 设计模式六大原则(5):迪米特法则 设计 ...
- Android 死锁和重入锁
死锁的定义: 1.一般的死锁 一般的死锁是指多个线程的执行必须同时拥有多个资源,由于不同的线程需要的资源被不同的线程占用,最终导致僵持的状态,这就是一般死锁的定义. package com.cxt.t ...
- Android Retrofit 2.0 使用-补充篇
推荐阅读,猛戳: 1.Android MVP 实例 2.Android Retrofit 2.0使用 3.RxJava 4.RxBus 5.Android MVP+Retrofit+RxJava实践小 ...
- iOS之ProtocolBuffer搭建和示例demo
这次搭建iOS的ProtocolBuffer编译器和把*.proto源文件编译成*.pbobjc.h 和 *.pbobjc.m文件时,碰到不少问题! 搭建pb编译器到时没有什么问题,只是在把*.pro ...
- Xamarin.Android-用ZXing实现二维码扫描以及连续扫描
一.前言 本文的内容有两个基础:ZXing.Net和ZXing.Net.Mobile ZXing.Net:ZXing的C#实现,主要封装了各种二维码的编码.解码等跨平台的算法 ZXing.Net.Mo ...
- Fedora 22中的日期和时间配置
Introduction Modern operating systems distinguish between the following two types of clocks: A real- ...
- 游戏编程系列[1]--游戏编程中RPC协议的使用[2]--Aop PostSharp篇
上一篇我们使用了一个通用JSON协议约定来进行达到远程调用的目的.但是从实现上,我们需要不断的在所有的方法上添加拦截,并且判断拦截,然后执行,这就达到了一个比较繁琐的目的. 之前我们尝试过使用代码生成 ...
- python学习 正则表达式
一.re 模块中 1.re.match #从开始位置开始匹配,如果开头没有match()就返回none 语法:re.match(pattern, string, flags=0) pattern 匹配 ...