Mybatis是现在主流的持久化层框架,与Hibernate不同的是,它鼓励程序员使用原声SQL语句对数据库进行操作.因此提供了非常灵活的功能.特别是当数据库同时访问数过多,需要进行优化时,使用sql语句进行优化远比使用Hibernate的查询语句简单得多.

Mybatis也有它的缺点.因为它是使用原生的SQL语句,所以他的数据库兼容性不高.但是这并不妨碍它的作用,接下来,就让我们简单使用一下Mybatis.

我使用的是Eclipse,数据库为Oracle 创建一个java项目

首先,像hibernate.cfg.xml一样,我们需要创建一个mybatisConfig.xml(名字任意取),在这个配置文件中执行对数据库的连接

    <configuration>
<!--2-->
<typeAliases>
<!-- 别名 因为实体类的名称几乎总是冗长的,我们有必要为它去一个别名-->
<typeAlias type="com.jacx.entity.Emp" alias="emp" />
</typeAliases>
<!--1-->
<environments default="oracle">
<environment id="oracle">
<transactionManager type="JDBC"></transactionManager>
<!--使用线程池-->
<dataSource type="POOLED">
<property name="driver" value="oracle.jdbc.driver.OracleDriver" />
<property name="url" value="jdbc:oracle:thin:@127.0.0.1:1521:orcl" />
<property name="username" value="scott" />
<property name="password" value="tiger" />
</dataSource>
</environment>
</environments>
<!-- 配置加载映射文件 -->
<!--3-->
<mappers>
<mapper resource="com/jacx/config/empMapper.xml" />
</mappers>
</configuration>

对数据库进行连接后,我们需要创建一个实体类.注意在这个时候我们并没有将实体类和数据库表进行关系映射,想想我们怎么通过实体字段找到对应的数据库字段

当没有写进行关系映射时,如果数据库名和实体变量名一致,他依然会对应

    private Integer empNo;
private String eName;
private String job;
private String mgr;
private String sal;
private String comm;
private String deptNo;

然后生成它的get set方法即可

接下来我们创建一个empMapper.xml,写SQL语句进行增删改查的操作,我会在代码备注中一一解释他们的作用

<!--namespace不能为空,它指向你的mapper的路径,每个实体(表)都要有一个mapper.xml-->
<mapper namespace="com.jacx.config.empMapper">
<!--id=相当于方法名,在客户端中进行调用,resultType=执行本操作返回的类型,比如我执行的是查询操作,他就返回emp;注意,这里填emp是因为我在mybatisConfig.xml中写的别名是emp.resultMap,emp实体映射的数据库字段-->
<select id="queryAll" resultType="emp" resultMap="empResultMap">
SELECT * FROM emp
</select>
<select id="queryById" resultType="Emp" parameterType="int" resultMap="empResultMap">
Select * FROM emp WHERE empNo = #{id}
</select>
<delete id="deleteById" parameterType="int">
DELETE FROM emp WHERE empNo = #{id}
</delete>
<update id="updateEmp" parameterType="Emp">
UPDATE emp
<set>
<if test="eName!=null">
ENAME = #{eName},
</if>
<if test="job!=null">
JOB = #{job},
</if>
<if test="mgr!=null">
MGR = #{mgr},
</if>
<if test="sal!=null">
SAL = #{sal},
</if>
<if test="comm!=null">
COMM = #{comm},
</if>
<if test="deptNo!=null">
DEPTNO = #{deptNo}
</if> </set>
WHERE empNo = #{empNo}
</update>
<!--实体通过resultMap知道自己的变量对应哪个字段.column为数据库中的列明,property为实体类中的变量名,id是增删改中resultMap用到的-->
<resultMap type="Emp" id="empResultMap">
<id column="EMPNO" property="empNo" />
<result column="ENAME" property="eName" />
<result column="JOB" property="job" />
<result column="MGR" property="mgr" />
<result column="SAL" property="sal" />
<result column="COMM" property="comm" />
<result column="DEPTNO" property="deptNo" />
</resultMap>
</mapper>
然后把它加到mybatisConfig.xml中
接下来就可以在客户端里进行操作了(这是main方法中的代码)
 Reader reader = null;
SqlSessionFactoryBuilder sqlSessionFactoryBuilder = null;
SqlSessionFactory sqlSessionFactory = null;
SqlSession sqlSession = null;
try {
reader = Resources.getResourceAsReader("mybatisConfig.xml");
sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
sqlSessionFactory = sqlSessionFactoryBuilder.build(reader);
sqlSession = sqlSessionFactory.openSession();
//查
//引号中的代码为mapmer.xml的路径加上对应方法的id
List<Emp> empList = sqlSession.selectList("com.jacx.config.empMapper.queryAll");
for (Emp e : empList) {
System.out.println(e.getDeptNo() + "\t" + e.geteName() + "\t" + e.getJob() + "\t" + e.getMgr() + "\t"
+ e.getSal() + "\t" + e.getEmpNo());
} //改
Emp emp = new Emp();
emp.seteName("jac");
emp.setEmpNo(7499);
sqlSession.update("com.jacx.config.empMapper.updateEmp",emp);
//删
sqlSession.delete("com.jacx.config.empMapper.deleteById", 7521);
//增 在增加功能中,我们需要为数据库emp表添加一个序列,因为oracle不允许自动增长
Emp emp = new Emp();
emp.seteName("123");
sqlSession.insert("com.jacx.config.empMapper.addEmp")
sqlSession.commit();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

SSMybatis整合 --详细解读Mybatis对oracle数据库进行增删改查(一)的更多相关文章

  1. java连接Oracle数据库实现增删改查并在Navicat中显示

    创建TEST表 eclipse中的java项目 代码 数据库方法类 DBUtil: package util; import java.sql.Connection; import java.sql. ...

  2. mybatis实现MySQL数据库的增删改查

    环境: jdk1.8 mysql5.7 maven3.6.0 IDEA 什么是mybatis框架? MyBatis 是一款优秀的持久层框架, 它支持自定义 SQL.存储过程以及高级映射. MyBati ...

  3. mybatis实现MySQL数据库的增删改查之二

    这里直接附上代码: 1 package com.qijian.pojo; 2 3 import org.apache.ibatis.type.Alias; 4 5 6 public class Use ...

  4. Mybatis学习笔记(二) 之实现数据库的增删改查

    开发环境搭建 mybatis 的开发环境搭建,选择: eclipse j2ee 版本,mysql 5.1 ,jdk 1.7,mybatis3.2.0.jar包.这些软件工具均可以到各自的官方网站上下载 ...

  5. python链接oracle数据库以及数据库的增删改查实例

    初次使用python链接oracle,所以想记录下我遇到的问题,便于向我这样初次尝试的朋友能够快速的配置好环境进入开发环节. 1.首先,python链接oracle数据库需要配置好环境. 我的相关环境 ...

  6. java web数据库的增删改查详细

    本次课上实验是完成数据库的增删改查. 包括增加用户信息.删除用户信息.多条件查找用户信息.修改用户信息(主要是复选框单选框等的相关操作.) 下面下看一下各个界面的样子. 总页面:显示全部页面:增加页面 ...

  7. java jdbc 连接mysql数据库 实现增删改查

    好久没有写博文了,写个简单的东西热热身,分享给大家. jdbc相信大家都不陌生,只要是个搞java的,最初接触j2ee的时候都是要学习这么个东西的,谁叫程序得和数据库打交道呢!而jdbc就是和数据库打 ...

  8. 【转载】通过JDBC对MySQL数据库的增删改查

    通过JDBC进行简单的增删改查(以MySQL为例) 目录 前言:什么是JDBC 一.准备工作(一):MySQL安装配置和基础学习 二.准备工作(二):下载数据库对应的jar包并导入 三.JDBC基本操 ...

  9. SpringBoot+Mybatis+Maven+MySQL逆向工程实现增删改查

    SpringBoot+Mybatis+MySQL+MAVEN逆向工程实现增删改查 这两天简单学习了下SpringBoot,发现这玩意配置起来是真的方便,相比于SpringMVC+Spring的配置简直 ...

随机推荐

  1. hdu 1874 畅通工程(spfa 邻接矩阵 邻接表)

    题目链接 畅通工程,可以用dijkstra算法实现. 听说spfa很好用,来水一发 邻接矩阵实现: #include <stdio.h> #include <algorithm> ...

  2. 转:攻击JavaWeb应用[1]-javaEE基础

    http://www.cnblogs.com/oh3o/p/3224562.html JSP: 全名为java server page,其根本是一个简化的Servlet. Servlet:Servle ...

  3. 洛谷——P1208 [USACO1.3]混合牛奶 Mixing Milk

    P1208 [USACO1.3]混合牛奶 Mixing Milk 题目描述 由于乳制品产业利润很低,所以降低原材料(牛奶)价格就变得十分重要.帮助Marry乳业找到最优的牛奶采购方案. Marry乳业 ...

  4. 1、编译安装Nginx

    1.1 如何选择web服务器 在实际工作中,我们需要根据业务需求来选择合适的业务服务软件,有关web服务,选择建议如下: 静态业务:若是高并发场景,尽量采用nginx或lighttpd,二者首选ngi ...

  5. tomcat服务器上web项目日志存放位置

    1.找到log日志的配置文件:log.xml,或者log.property,找到rollingFile标签,该标签的fileName属性就是更新的日志文件的存放位置.(相对于tomcat的bin目录)

  6. [BZOJ 1901] Dynamic Rankings

    Link: BZOJ 1901 传送门 Solution: 带修改主席树的模板题 对于静态区间第$k$大直接上主席树就行了 但加上修改后会发现修改时复杂度不满足要求了: 去掉/增加第$i$位上的值时要 ...

  7. BZOJ 2467 [中山市选2010]生成树(组合数学)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2467 [题目大意] 有一种图形叫做五角形圈.一个五角形圈的中心有1个由n个顶点和n条边 ...

  8. java浏览器控件jxbrowser(简单demo模拟自动登录与点击)

    写在前面: 老大让我写个脚本自动给他写dms有一段时间了,说实话当时不知道老大指的这个脚本是什么?毕竟是做web的,难道是写个数据库sql语句脚本吗?也就放在了一边.巧了,最近一个朋友说他之前写了个程 ...

  9. Everything | 本地文件搜索引擎工具

    文章目录 本地文件搜索软件 下载地址 注意 本地文件搜索软件 您是否觉得 Windows 自带的文件搜索比较慢?! 今天,给大家分享一款超快好用的本地文件搜索软件:Everything Search ...

  10. 原生js实现图片轮播思路分析

    一.复习原生js实现图片轮播 1.要点 自动轮播 点击小圆圈按钮,显示相应图片 点击左右箭头,实现向前向后轮播图片 2.实现思路 <div id="container"> ...