使用iBATIS3.0完成增删改查
为什么80%的码农都做不了架构师?>>>
使用iBATIS3.0完成增删改查
iBATIS3.0和以前的版本有一些改变,不过学过以前版本的再学习3.0应该不是太难,3.0要求JDK1.5支持,因为其中增加了注解和泛型,这些都是JDK1.5才有的。好了废话不多说,先来利用iBATIS3做下简单的增删改查吧。
首先到Apache(http://www.apache.org/)网站下载iBATIS3的jar 包,我下载的是ibatis-3-core-3.0.0.227.zip,解压后吧那个jar文件(ibatis-3-core-3.0.0.227.jar)添加到工程就可以了,还有一个文件(ibatis-3-core-src-3.0.0.227.zip)是源代码,可以用来查看源代码的,使用eclipse可以用它来关联源代码。
在MyEclipse新建一个Java Project,结构如下图
在jdbc.properties文件是映射文件要使用的,其内容如下:
Properties代码
- driver=com.mysql.jdbc.Driver
- url=jdbc\:mysql\://localhost\:3306/test
- username=root
- password=123456
SqlMapper.xml是iBATIS的配置文件,其代码如下:
Xml代码
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE configuration
- PUBLIC "-//ibatis.apache.org//DTD Config 3.0//EN"
- "http://ibatis.apache.org/dtd/ibatis-3-config.dtd">
- <configuration>
- <properties resource="jdbc.properties"/>
- <typeAliases>
- <typeAlias type="cn.ibatis3.test.Person" alias="Person"/>
- </typeAliases>
- <environments default="development">
- <environment id="development">
- <transactionManager type="JDBC"/>
- <dataSource type="POOLED">
- <property name="driver" value="${driver}"/>
- <property name="url" value="${url}"/>
- <property name="username" value="${username}"/>
- <property name="password" value="${password}"/>
- </dataSource>
- </environment>
- </environments>
- <mappers>
- <mapper resource="cn/ibatis3/test/person.xml"/>
- </mappers>
- </configuration>
上面文件中的sql映射文件person.xml代码如下:
Xml代码
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE mapper
- PUBLIC "-//ibatis.apache.org//DTD Mapper 3.0//EN"
- "http://ibatis.apache.org/dtd/ibatis-3-mapper.dtd">
- <!-- -->
- <mapper namespace="cn.ibatis3.test.PersonMapper">
- <select id="selectPerson" parameterType="java.lang.Integer"
- resultType="Person">
- select * from person where id = #{id}
- </select>
- <select id="selectAll" resultType="Person">
- select * from person
- </select>
- <select id="selectPersonsByName" resultType="Person" parameterType="String">
- select * from person where name like #{name}
- </select>
- <insert id="insertPerson" parameterType="Person">
- insert into person(name,birthday,sex)
- values(#{name},#{birthday},#{sex})
- </insert>
- <delete id="deletePerson" parameterType="Person">
- delete from person where id=#{id}
- </delete>
- <update id="updatePerson" parameterType="Person">
- update person set name=#{name},birthday=#{birthday},sex=#{sex}
- where id=#{id}
- </update>
- </mapper>
注意:在iBATIS3中,属性parameterMap是不推荐使用的,在以后的版本可能会去掉这个属性。
Person.java的代码如下:
Java代码
- package cn.ibatis3.test;
- import java.util.Date;
- public class Person {
- private int id = 0;
- private String name = "";
- private String sex = "male";
- private Date birthday = null;
- public Person() {
- }
- //省略getter 和 setter 方法
- @Override
- public String toString() {
- return "id=" + id + "\t" + "name=" + name + "\t" + "sex=" + sex + "\t"
- + "birthday=" + new java.sql.Date(birthday.getTime()).toString();
- }
- }
iBATIS官方推荐我们使用单例模式创建一个sessionFactory,我这里也提供一个sessionFactory.java,呵呵,仅供参考:
Java代码
- package cn.ibatis3.test;
- import java.io.IOException;
- import java.io.Reader;
- import org.apache.ibatis.io.Resources;
- import org.apache.ibatis.session.SqlSessionFactory;
- import org.apache.ibatis.session.SqlSessionFactoryBuilder;
- public final class SessionFactory {
- private String resource="cn/ibatis3/test/SqlMapper.xml";
- private SqlSessionFactory sqlSessionFactory=null;
- private static SessionFactory sessionFactory=new SessionFactory();
- private SessionFactory() {
- try {
- Reader reader=Resources.getResourceAsReader(resource);
- sqlSessionFactory=new SqlSessionFactoryBuilder().build(reader);
- } catch (IOException e) {
- System.out.println("#IOException happened in initialising the SessionFactory:"+e.getMessage());
- throw new ExceptionInInitializerError(e);
- }
- }
- public static SessionFactory getInstance() {
- return sessionFactory;
- }
- public SqlSessionFactory getSqlSessionFactory() {
- return sqlSessionFactory;
- }
- }
基于接口的编程(还有就是iBATIS3的注解也是在接口方法上的,关于注解以后有机会再讲,它也是iBATIS3的一个新特性),DAO层的接口PersonMapper.java代码如下:
Java代码
- package cn.ibatis3.test;
- import java.util.List;
- public interface PersonMapper {
- Person selectById(Integer id);
- List<Person> selectAll();
- List<Person> selectPersonsByName(String name);
- void insert(Person person);
- void delete(Person person);
- void update(Person person);
- }
接口的实现类PersonDao.java代码如下:
Java代码
- package cn.ibatis3.test;
- import java.util.ArrayList;
- import java.util.List;
- import org.apache.ibatis.session.SqlSession;
- import org.apache.ibatis.session.SqlSessionFactory;
- public class PersonDao implements PersonMapper {
- private SqlSessionFactory sessionFactory = SessionFactory.getInstance()
- .getSqlSessionFactory();
- public Person selectById(Integer id) {
- Person person = new Person();
- SqlSession session = null;
- try {
- session = sessionFactory.openSession();
- person = (Person) session.selectOne(
- "cn.ibatis3.test.PersonMapper.selectPerson", id);
- } finally {
- session.close();
- }
- return person;
- }
- @SuppressWarnings("unchecked")
- public List<Person> selectAll() {
- List<Person> persons = new ArrayList<Person>();
- SqlSession session = null;
- try {
- session = sessionFactory.openSession();
- persons = session
- .selectList("cn.ibatis3.test.PersonMapper.selectAll");
- } finally {
- session.close();
- }
- return persons;
- }
- public void delete(Person person) {
- SqlSession session = null;
- try {
- session = sessionFactory.openSession();
- session.delete("cn.ibatis3.test.PersonMapper.deletePerson", person);
- session.commit();
- } finally {
- session.close();
- }
- }
- public void insert(Person person) {
- SqlSession session = null;
- try {
- session = sessionFactory.openSession();
- session.insert("cn.ibatis3.test.PersonMapper.insertPerson", person);
- session.commit();
- } finally {
- session.close();
- }
- }
- public void update(Person person) {
- SqlSession session = null;
- try {
- session = sessionFactory.openSession();
- session.insert("cn.ibatis3.test.PersonMapper.updatePerson", person);
- session.commit();
- } finally {
- session.close();
- }
- }
- @SuppressWarnings("unchecked")
- public List<Person> selectPersonsByName(String name) {
- List<Person> persons = new ArrayList<Person>();
- SqlSession session = null;
- try {
- session = sessionFactory.openSession();
- System.out.println(name);
- persons = session.selectList(
- "cn.ibatis3.test.PersonMapper.selectPersonsByName", "%"
- + name + "%");
- session.commit();
- } finally {
- session.close();
- }
- return persons;
- }
- }
最后是表的创建:
Sql代码
- DROP TABLE IF EXISTS `test`.`person`;
- CREATE TABLE `test`.`person` (
- `id` int(10) unsigned NOT NULL auto_increment,
- `name` varchar(20) default NULL,
- `sex` varchar(8) default NULL,
- `birthday` datetime default NULL,
- PRIMARY KEY (`id`)
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
好了,做为一次新技术的体验吧,欢迎大家指出其中的错误或者是不恰当的地方。
- 查看图片附件
17
顶
6
踩
分享到:
iBATIS3.0学习(二)使用iBATIS3.0注解完 ...
- 2010-02-03 13:00
- 浏览 11154
- 评论(14)
- 收藏
- 分类:企业架构
- 相关推荐
评论
14 楼 lyb520320 2012-02-01 引用
ibatis3没有试验过打印sql,ibatis2通过jdk动态代理使用log4j打印sql,估计ibatis3也差不多,看下这个连接,主要看log4j.properties配置,这个文件要放到src目录下
http://winyee.iteye.com/blog/457216
13 楼 grandboy 2012-02-01 引用
这个我在网上搜索了好长时间,也试了网上说的一些办法,就是无法把产生的sql打印出来,不知道各位有没有成功经验?如果有人成功,请告诉详细方法或者给兄弟一个链接。
要亲自实验成功的方法。多谢。
12 楼 lyb520320 2012-01-31 引用
qwj528 写道
楼主<mapper namespace="cn.ibatis3.test.PersonMapper"> namespace这个属性有什么作用吗? 但是必须要有namespace。 从你这个例子来看好像是个接口。
namespace仅仅是为了区分不同的xml的一个名称,至于是什么看你自己的代码习惯
11 楼 qwj528 2012-01-31 引用
楼主<mapper namespace="cn.ibatis3.test.PersonMapper"> namespace这个属性有什么作用吗? 但是必须要有namespace。 从你这个例子来看好像是个接口。
10 楼 fengyie007 2010-06-21 引用
Java代码
- public List<Person> selectAll() {
- List<Person> persons = new ArrayList<Person>();
- SqlSession session = null;
- try {
- session = sessionFactory.openSession();
- persons = session
- .selectList("cn.ibatis3.test.PersonMapper.selectAll");
- } finally {
- session.close();
- }
- return persons;
- }
转载于:https://my.oschina.net/wzzz/blog/206635
使用iBATIS3.0完成增删改查相关推荐
- Mysql —— C语言链接mysql数据库,命令行形式(getopt()函数),用户、用户组增删改查(用户组表内有用户控制的策略字段)
函数说明--getopt(): 函数说明 getopt()用来分析命令行参数.参数argc和argv分别代表参数个数和内容,跟main()函数的命令行参数是一样的. optstring中的指定的内容的 ...
- 【Python数据处理篇——DataFrame数据准备】DataFrame的创建、增删改查、数据导入等
欢迎访问我搞事情的[知乎账号]:Coffee 以及我的[B站漫威剪辑账号]:VideosMan 若我的笔记对你有帮助,请用小小的手指,点一个大大的赞哦. 关于DataFrame的相关知识,我还进行了汇 ...
- 004--Django(定义模型类、数据的增删改查、F和Q对象)
1.创建数据库 mysql -uroot -pmysqlcreate database django_demo charset=utf8; 2.配置mysql数据库 在settings.py 中配置数 ...
- MVC新手教程三:Entity Framework 4.0 来实现MVC的增删改查功能,10分钟搞定
在这一节,我们使用VS2010自带的EF4.0来实现MVC的增删查改功能,为什么用EF呢?因为如果你自己手写sqlhelper之类,或者是用动软,和我们用EF的速度比,太慢太慢··· 当然,新手还是用 ...
- [py]flask从0到1-模板/增删改查
flask知识点 1.后端渲染html到前端render_template 2.后端获取前端数据request.args.get 3.前端获取后端数据模板4.警示消息 flash {{ get_fla ...
- SSH(Struts 2.3.31 + Spring 4.1.6 + Hibernate 5.0.12 + Ajax)框架整合实现简单的增删改查(包含分页,Ajax 无刷新验证该用户是否存在)...
软件152 余建强 该文将以员工.部门两表带领大家进入SSH的整合教程: 源码下载:http://download.csdn.net/detail/qq_35318576/9877235 SSH 整合 ...
- VUE2.0增删改查附编辑添加model(弹框)组件共用
为什么80%的码农都做不了架构师?>>> Vue实战篇(增删改查附编辑添加model(弹框)组件共用) 前言 最近一直在学习Vue,发现一份crud不错的源码 预览链接 https: ...
- mysql8.0增删改查语句_MySQL增删改查语句
/数据表,显示表的结构) l 创建数据库 create database student l 删除数据库 drop database student l 创建数据表 create table admi ...
- 带头节点单链表的增删改查
单链表有很多结构循环单链表,有头节点的单链表,无头节点的单链表,双节点单链表,以下源码是以有一个头节点的单链表为例写的增删改查的各种功能,就是下图 然后各个注释也在函数后面写着,这玩意确实还挺难,源码 ...
最新文章
- 设计模式 - 迭代器模式(iterator pattern) 具体解释
- ai人工智能服务器操作系统,全球首款100%纯国产的AI操作系统来了,但说媲美Windows有意义吗...
- 最讨厌心灵鸡汤 所有失败最终都是人不行
- P4301-[CQOI2013]新Nim游戏【线性基】
- cad在布局怎么调比例_CAD中如何在布局空间调整图形比例?
- php中is null,php中empty(), is_null(), isset()函数区别
- 关于centos启动报错:Failed to start Crash recovery kernel arming的解决方案
- 六部工坊ros启智机器人定点导航技术_【展品抢鲜看】程天科技外骨骼机器人亮相峰会,让每个人享受机器人的服务!...
- 本特利前置器330180-50-00
- 怎样快速熟悉公司产品
- 读懂LaTeX中cls文件
- 南卡和OPPO蓝牙耳机哪个好用?高品质的蓝牙耳机测评
- Tex, LaTex, pdflatex, xelatex, xetex等的区别和关系
- html网址中的各个标签代表什么意思
- 安装Office2010提示无法将数值写入注册表
- JAVA毕设项目甜趣网上蛋糕店订购系统(java+VUE+Mybatis+Maven+Mysql)
- android获取ro._Android群控黑盒调用 - Sekiro食用手册
- Hashmap源码详解
- 数据分析之AB testing实战(附Python代码)
- DP背包问题及优化详解(全)
热门文章
- string相关库函数
- 关闭用playsound函数的WAV文件
- 你是否发现 职业能力危机,请 警惕
- Apache Subversion 1.7.2发布,开源版本控制工具
- 为何大部分人成不了技术专家?
- 264编码基本概念 FFMpeg的解码流程
- 解决 VS Code 保存时候自动格式化
- BZOJ 3329: Xorequ(数位dp+递推)
- Silverlight Blend动画设计系列八:拖放(Drag-Drop)操作与拖放行为(DragBehavior)
- Moving Average