任何一个软件都要和数据库关联,软件需要的数据都存储在数据库中。

对于经常使用的数据库相关的代码就出现了很多冗余的代码,持久层框架也随之出现。

目前使用比较流程的持久层框架有hibernate和mybatis等。这次介绍下如何搭建使用mybatis框架。

工具介绍

  • IDEA开发工具
  • maven开发工具
  • MariaDB数据库

首先创建Maven项目配置pom.xml添加Mybatis依赖包

作者在此使用的数据库是MariaDB,所有也需要添加依赖包

 mybatis数据库配置。对于mybatis框架来说,首先需要配置的就是数据库的数据源配置以及

采用何种开发模式的配置,对于mavne项目来说这些资源信息都需要配置在src/main/resources下面,

对于普通的java项目则只需要配置在src下即可。

mybatis-config.xml的配置。在src/main/resources/下创建一个名为mybatis-config的文件。

在文件中需要配置resources数据库资源文件,

数据库链接需要的driver驱动、url连接串、username数据库用户名、password数据库密码等。

 数据库信息的配置。根据mybatis-config配置中的resources文件引入,

需要创建一个jdbc.properties文件的配置。

同样是在src/main/resources资源文件夹下新建properties文件。

配置url/driver/username/password。

接下来就是实体类了

创建java对象。根据数据库表或者某些表的字段配置一个java对象。

mybatis可以根据框架将表中的数据自动转成对象。

创建实体类实现get、set方法

编写对应的接口需要操作的功能

在此演示一个Customer类

编写好实体类以及接口然后就配置对应的映射文件了

配置xml映射文件。在resources包下创建mapper文件夹然后创建与接口对象同名的.xml文件,配置java与数据库之间交互的方法。主要配置的有namespace、

sql语句

 

映射文件配置

<?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="com.nf147.dao.CustomerDAO"> <select id="queryAll" resultType="Customer">
select * from Customer
</select> <select id="queryById" resultType="Customer">
select * from Customer where CustomerId = #{CustomerId}
</select> </mapper>

配置好xml之后,需要在mybatis-config中将这个xml添加到mappers中,这样项目启动的时候才能加载到这些sql脚本。 

创建加载mybatis配置文件的类。可以通过mybatis框架自带的一些类加载xml配置文件,

根据factory获取一个session,通过session执行对应脚本的sql语句。

对于执行insert或者update语句需要在最后执行session.commit进行提交操作。

创建方法

public Object queryAll(){

        String resource = "/mybatis-config.xml";
InputStream inputStream = Resources.class.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); SqlSession sqlSession = sqlSessionFactory.openSession();
Object o = sqlSession.selectList("com.nf147.dao.CustomerDAO.queryById",1);
sqlSession.commit();
sqlSession.close();
return o;
}

然后编写测试类

针对于一些结果集渲染方法

使用resultMap
 <!--映射 Invoice表与BillingInfo-->
<resultMap id="invoiceInfo" type="Invoice" autoMapping="true">
<association property="billingInfo" javaType="BillingInfo" autoMapping="true">
<id property="BillingId" column="InvoiceId"></id>
</association>
</resultMap>
<!--映射Customer-->
<resultMap id="customer" type="Customer" autoMapping="true">
<collection property="invoices" ofType="Invoice" resultMap="invoiceInfo"></collection>
</resultMap>
<select id="getInvoiceInfo" resultMap="invoiceInfo">
SELECT
c.*,
i.InvoiceId,
i.InvoiceDate,
i.BillingAddress,
i.BillingCity,
i.BillingState,
i.BillingCountry,
i.BillingPostalCode,
i.Total
FROM Customer c LEFT JOIN Invoice I ON c.CustomerId = I.CustomerId
where i.InvoiceId = #{InvoiceId}
</select> <select id="queryById" resultMap="customer">
SELECT
c.*,
i.InvoiceId,
i.InvoiceDate,
i.BillingAddress,
i.BillingCity,
i.BillingState,
i.BillingCountry,
i.BillingPostalCode,
i.Total
FROM Customer c LEFT JOIN Invoice I ON c.CustomerId = I.CustomerId
where C.CustomerId = #{CustomerId}
</select>

IDEA如何构建mybatis的更多相关文章

  1. Maven的学习资料收集--(八) 构建MyBatis项目

    在这里,写一下,怎么使用Maven构建MyBatis项目. 1. 新建一个Web项目 可以参考前面的博客 2. 修改pom.xml,添加MyBatis依赖 <project xmlns=&quo ...

  2. maven学习5 构建MyBatis项目

    2. 修改pom.xml,添加MyBatis依赖 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi=& ...

  3. 从零开发分布式数据库中间件 二、构建MyBatis的读写分离数据库中间件

    在上一节 从零开发分布式数据库中间件 一.读写分离的数据库中间件 中,我们讲了如何通过ThreadLocal来指定每次访问的数据源,并通过jdbc的连接方式来切换数据源,那么这一节我们使用我们常用的数 ...

  4. Mybatis架构学习

    Mybatis架构学习 MyBatis 是支持定制化 SQL.存储过程以及高级映射的持久层框架.MyBatis 封装了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.可以对配置和原生Map使用 ...

  5. 优化与扩展Mybatis的SqlMapper解析

    接上一篇博文,这一篇来讲述怎么实现SchemaSqlMapperParserDelegate——解析SqlMapper配置文件. 要想实现SqlMapper文件的解析,还需要仔细分析一下mybatis ...

  6. 由“单独搭建Mybatis”到“Mybatis与Spring的整合/集成”

    在J2EE领域,Hibernate与Mybatis是大家常用的持久层框架,它们各有特点,在持久层框架中处于领导地位. 本文主要介绍Mybatis(对于较小型的系统,特别是报表较多的系统,个人偏向Myb ...

  7. Mybatis(一)实现单表的增删改查

    1.1 什么是Mybatis MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并 ...

  8. Mybatis集成到spring boot

    1, Mybatis简介 MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可 ...

  9. 【转】Mybatis源码解读-设计模式总结

    原文:http://www.crazyant.net/2022.html?jqbmtw=b90da1&gsjulo=kpzaa1 虽然我们都知道有26个设计模式,但是大多停留在概念层面,真实开 ...

随机推荐

  1. 3.Bacula Client安装配置

    1.   Bacula Client安装配置 1.1.   linux客户端安装 1.1.1.  安装依赖包 yum install libacl libacl-devel 1.1.2.  Clien ...

  2. kubernetes之pod调度

    调度规则 deployment全自动调度: 运行在哪个节点上完全由master的scheduler经过一系列的算法计算得出, 用户无法进行干预 nodeselector定向调度: 指定pod调度到一些 ...

  3. SSH环境搭建之Spring环境搭建篇

    SSH环境搭建之Spring环境搭建篇 一.引入Spring所使用的JAR文件 二.在src目录下创建beans.xml(Spring的容器文件) <?xml version="1.0 ...

  4. 创建yum本地仓库,将阿里仓库同步到本地,并定时更新

    很多时候为了加速自己内部的rpm包安装速度,都会搭建自己的yum源仓库,而使用系统光盘自带的源,由于软件版本比较落后,所以不太适用,而大家都在用的阿里仓库比较好用,所以就想到了把阿里仓库的rpm全部拉 ...

  5. hdu4612 Warm up[边双连通分量缩点+树的直径]

    给你一个连通图,你可以任意加一条边,最小化桥的数目. 添加一条边,发现在边双内是不会减少桥的.只有在边双与边双之间加边才有效.于是,跑一遍边双并缩点,然后就变成一棵树,这样要加一条非树边,路径上的点( ...

  6. Linux防CC攻击脚本

    多数CC攻击在web服务器日志中都有相同攻击的特征,我们可以根据这些特征过滤出攻击的ip,利用iptables来阻止 #!/bin/bash #by LinuxEye #BLOG: http://bl ...

  7. hbuilder离线打包iOS,xcode开发卡在启动页注意点

    1.Display Name的名称与manifest.json中的name保持一致. 2.项目文件夹名.contro.xml中的appid.manifest.json中的id一致

  8. JS 中获取服务器时间的注意点

    在通过js获取服务器时间时,遇到了小小的问题,但造成的影响挺大的,所以写出来提醒大家,在获取服务器时间时一定要细心要多测试多验证. js 中使用以下方法获取服务器时间时要注意两点: 1.xhr.ope ...

  9. MFC 静态文本框

    窗体上操作控件内容,需要句柄,在控件处使用鼠标右键——添加变量. DoDataExchange()函数会自动生成代码,把ID与变量绑定(即DDX_Control(pDX, IDC_TEXT, objT ...

  10. luogu 1169 [ZJOI2007]棋盘制作 悬线dp

    悬线法,虽然得不到局部最优解,但是一定能得到全局最优解的算法,十分神奇~ #include <cstdio> #include <algorithm> #define N 20 ...