一:配置MyBaits的开发环境

1.1.核心配置文件

正如hibernate一样,MyBaits也有一个核心的配置文件,它包含着数据源地址,用户名,密码等,还有着各个实体类的配置文件,配置文件是xml类型的,至于文件名,则可以随意写,我这里取名作conf.xml,本文章中,都以这个名字为核心配置文件的名称,下面我们来写一个User类:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- environments的devault有两个值,
一个是development开发模式
一个是work工作模式,一般开发完成后会改为work模式
-->
<environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/mybatis" />
<property name="username" value="root" />
<property name="password" value="zxj65681140" />
</dataSource>
</environment>
</environments> <!-- 这里映射那些实体类的配置文件 -->
<mappers>
<!-- 引入使用配置文件的写法 -->
<mapper resource="zxj/domain/userMapper.xml"/>
<mapper resource="zxj/crud/userMapper.xml"/>
<!-- 引入注解的写法 -->
<mapper class="zxj.annotation.interfac.UserMapper"/>
</mappers>
</configuration>

1.2.实体类与实体类的映射文件

写完核心的配置文件的时候,我们就要准备实体类,也就是一个javabean,同样也是要有着get与set方法,下面我们来写一个简单的bean:

package zxj.domain;

public class User {
private int id;
private String name;
private int age; public User(int id, String name, int age) {
super();
this.id = id;
this.name = name;
this.age = age;
} public User() {
super();
} public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "User [id=" + id + ", name=" + name + ", age=" + age + "]";
} }

这是一个再简单不过的实体类了,然后再来写它的配置文件,配置文件一船会以类的名字+Mapper.xml,例如userMapper.xml,当然你也可以写其它的,下面给出Mybatis的简单的一个映射关系的写法:

<?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">
<mapper namespace="zxj.crud.userMapper">
<!-- crud操作 -->
<!-- 代表着传递过来的类型 -->
<!-- #{}中的值不可以乱写,如果parameterType是一个对象,那就必须写这个对象的属性 -->
<insert id="addUser" parameterType="zxj.domain.User">
insert into users(name,age) value(#{name},#{age})
</insert>
<!-- 删除一条纪录 -->
<delete id="deleteUser" parameterType="int">
delete fm users where id=#{id}
</delete>
<!-- 更新一条纪录 -->
<update id="updateUser" parameterType="zxj.domain.User">
update users set name=#{name},age=#{age} where id=#{id}
</update> <!-- 查询所有,指定返回类型为User对象 -->
<select id="getAllUsers" resultType="zxj.domain.User">
select * from users
</select> <!-- 根据id查询,得到一个User对象 -->
<select id="getUser" parameterType="int" resultType="zxj.domain.User">
select * from users where id=#{id}
</select>
</mapper>

看完上面配置文件的写法,如果懂Hibernate的人就会知道,这和hibernate的配置文件就是有些不同了,因为hibernate是完全的是面向对象的编程,不需要自己写sql,而mybatis需要程序员把sql写好,所以也注定了mybatis要比hibernate要更加灵活。

下面来介绍一下配置文件

(1)这里分别有着四个标签,分别对应增删改查,而每个标签又有一个id,这个Id就是操作数据库时需要引用的一个字符串。

(2)namespace就是这个配置文件的一个名称空间,是为配置文件分类的,就类似于java中的包一样。

(3)parameterType,参数类型,这个类型可以写一个基本数据类型,也可以写一个对象,比如说要增加一条纪录的时候,肯定是传一个对象过去的,然后在下面的占位符中,就可以写这个对象的属性字段。如果要删除一条纪录,则是是传一个id过去,则可以定义为int。

(4)resultType返回的结果类型,就是操作完数据库时返回的结果,它有可能是受影响的行数,也可能是查询完的一个对象,也可能是一个多条的list集合,所以也可以定义为基本数据类型或者是一个对象

1.3.简单的使用mybatis

写完基本的数据类型后,就需要来测试是否可以正常使用了,下面写一个测试类:

/**
* 测试根据id来查找,配置文件的写法
*/
@Test
public void testSelect() {
// 使用类加载器加载Mybaits的配置文件,得到inputstream输入流
InputStream in = TestMybaits.class.getClassLoader().getResourceAsStream("conf.xml");
// 创建sessionFactory
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in);
// 得到session
SqlSession session = factory.openSession();
// 这是userMapping的名称空间加上id
String statement = "zxj.domain.userMapper.getUser";
// 第二个参数是占位符,代表查找Id为2的数据,返回user对象
User user = session.selectOne(statement, 1);
System.out.println(user);
session.close();
}

如上的代码如示,先是根据inputStream流来加载配置文件,然后后面的就是创建工厂,然后创建session,然后用session操作数据库,然后关闭session。

MyBaits学习的更多相关文章

  1. Mybaits学习总结2

    http://www.cnblogs.com/xdp-gacl/p/4262895.html 继续参考这篇文章写Mybaits学习总结 上一章,我修改了编码,统一为UTF8之后,便没有编码错误 < ...

  2. mybaits 学习

    mybaits  学习(一) 注意:如果建的是web项目,run as java application 参考http://www.cnblogs.com/xdp-gacl/p/4261895.htm ...

  3. (原创)mybaits学习三,springMVC和mybatis融合

    上一节,总计了spring和mybaits的融合,这一节,我们来学习springmvc和mybatis融合 最近在弄一个SSM的项目,然后在网上找资料,将资料总结如下 一,开发环境的配置 MyEcli ...

  4. Mybaits学习总结1

    http://www.cnblogs.com/xdp-gacl/p/4261895.html 参考了这篇文章搭建了Mybaits环境,原作者有些地方没有标注使用某种编码,我是自学SQL的,所以深知编码 ...

  5. MyBaits学习03(ResultMap和分页)

    5.ResultMap 5.1 查询为null问题 要解决的问题:属性名和字段名不一致 环境:新建一个项目,将之前的项目拷贝过来 1.数据库里的属性 2.Java中的实体类设计 public clas ...

  6. 原生mybaits学习笔记

    目录 简介 maven引入 核心配置文件 方式一(简单) 配置 操作 方式二(old) 创建接口 配置mapper.xml 实现接口 操作 方式三(常用) 创建接口 配置mapper.xml 操作 配 ...

  7. Mybaits学习总结

    一.Mybatis介绍 邮箱:1727292697 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的 ...

  8. (原创)mybatis学习二,spring和mybatis的融合

    mybatis学习一夯实基础 上文介绍了mybatis的相关知识,这一节主要来介绍mybaits和spring的融合 一,环境搭建 1,jar包下载,下载路径为jar包 2,将包导入到java工程中 ...

  9. mybaits入门学习

    学习了简单的mybatis的配置 Bean层: 这个都会很简单 一个完整的Bean 需要getter和setter方法还需要一个空的构造方法和一个满的构造方法. Dao层: 创建一个接口就ok了 pa ...

随机推荐

  1. Git 的origin和master分析

    首先要明确一点,对git的操作是围绕3个大的步骤来展开的(其实几乎所有的SCM都是这样) 1.     从git取数据(git clone) 2.     改动代码 3.     将改动传回git(g ...

  2. 【原】react-router项目实战

    摘要: react-router相对于flux和redux来说,比较好容易理解一点和容易入门一点.这个是根据我之前的一个项目,然后我用react+react-router+webpack重新写的. 不 ...

  3. Yii2中的零碎知识点

    PHP最佳实践 1 PHP获取时间戳:echo  time(); 时间戳转换 date('Y-m-d H:i:s', $时间戳); 2 linux 显示命令 ls 显示所有文件夹 查看命令:tail ...

  4. MySQL 5.6.17 rpm 文件安装顺序

     Linux系统安装MySQL时,将MySQL-5.6.17-1.el6.x86_64.rpm-bundle.tar包打开,有7个rpm文件,如下: MySQL-client-5.6.17-1.el6 ...

  5. 将SQL SERVER数据库改成MySql

    (www.helpqy.com) 架构在阿里云上,最先想采用SQL SERVER,想大家都是微软家族的嘛.但是发现SQL SERVER需要的配置比较高,需要的银子也比较多,最后在纠结之下换成了MySq ...

  6. asp.net identity 2.2.0 中角色启用和基本使用(二)

    建立模型 第一步:在Models文件夹上点右键 >添加>类     类的名称自定,我用AdminViewModels命名的 因为是讲基本使用,我这里不做任何扩展. 第二步:添加如下命名空间 ...

  7. 使用阿里云负载均衡遭遇的http重定向https的问题

    昨天解决了在阿里云负载均衡上部署https证书的问题(详见一个空行引起的阿里云负载均衡上部署https证书的问题),并完成了部署,负载均衡的监听配置是这样的: 用户与负载均衡之间走https协议,负载 ...

  8. DDD领域驱动设计实践篇之如何提取模型

    需求说明: 省级用户可以登记国家指标 省级用户和市级用户可以登记指标分解 登记国家指标时,需要录入以下数据:指标批次.文号.面积,这里省略其他数据,下同 登记指标分解时,需要录入以下数据:指标批次.文 ...

  9. 据说每个大牛、小牛都应该有自己的库——DOM处理

    这几天整理了一下思路,本来觉得DOM部分会有很多东西,但是忽然发现频繁使用的其实并不太多 class class处理部分主要有四个 hasClass:检查元素是否包含某个class addClass: ...

  10. C++ inline函数

    本文主要记录了C++中的inline函数,也就是内联函数,主要记录了以下几个问题: C++为什么引入inline函数? 为什么inline能很好的取代表达式形式的预定义? inline函数的使用场合 ...