创建一个简单的MyBatis入门程序,实现对学生信息的增删改查功能(基于XML配置)

一、新建一个Java工程,导入MyBatis核心jar包、日志相关的jar包以及连接Oracle数据库所需驱动包,目录结构如下

二、创建MyBatis核心配置文件mybatis-config.xml

<?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>
<!-- 引入资源文件 -->
<properties resource="db.properties"></properties>
<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="com/heaven/dao/StudentMapper.xml"/>
</mappers>
</configuration>

三、创建POJO类Student.java

package com.heaven.bean;

import java.util.Date;

public class Student {
private Integer studId;
private String name;
private String email;
private Date dob; public Student() {
} public Student(Integer studId, String name, String email, Date dob) {
this.studId = studId;
this.name = name;
this.email = email;
this.dob = dob;
} public Integer getStudId() {
return studId;
}
public void setStudId(Integer studId) {
this.studId = studId;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public Date getDob() {
return dob;
}
public void setDob(Date dob) {
this.dob = dob;
}
@Override
public String toString() {
return "Student [studId=" + studId + ", name=" + name + ", email=" + email + ", dob=" + dob + "]";
} }

四、创建StudentMapper.xml映射文件

<?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.heaven.dao.StudentMapper">
<!-- 保存学生信息 -->
<insert id="saveStudent" parameterType="com.heaven.bean.Student">
insert into students(stud_id,name,email,dob) values(#{studId},#{name},#{email},#{dob})
</insert>
<!-- 根据Id查询学生信息 -->
<select id="selectById" parameterType="Integer" resultType="com.heaven.bean.Student">
select stud_id studId,name,email,dob from students where stud_id = #{id}
</select>
<!-- 查询所有学生信息 -->
<select id="findAll" resultType="com.heaven.bean.Student">
select stud_id studId,name,email,dob from students
</select>
<!-- 更新学生信息 -->
<update id="updateStudent" parameterType="com.heaven.bean.Student">
update students set email = #{email} where stud_id = #{studId}
</update>
<!-- 根据Id删除学生信息 -->
<delete id="deleteById" parameterType="Integer">
delete from students where stud_id = #{id}
</delete>
</mapper>

五、创建映射接口StudentMapper.java

package com.heaven.dao;

import java.util.List;

import com.heaven.bean.Student;

public interface StudentMapper {
/**
* 保存学生信息
* @param stu 入参 :Student对象
*/
void saveStudent(Student stu);
/**
* 根据id查询学生信息
* @param id 入参:id
* @return 返回值:Student对象
*/
Student selectById(Integer id);
/**
* 查询所有学生信息
*/
List<Student> findAll();
/**
* 删除学生信息
* @param id 入参:id
*/
void deleteById(Integer id);
/**
* 更新学生信息:入参:Student对象
* @param stu
*/
void updateStudent(Student stu);
}

六、编写JUnit测试类Test.java

package com.heaven.test;

import java.io.IOException;
import java.util.Date;
import java.util.List; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Before;
import org.junit.Test; import com.heaven.bean.Student;
import com.heaven.dao.StudentMapper; public class TestMapper {
private SqlSessionFactory factory;
private SqlSession sqlSession;
private StudentMapper mapper;
/**
* 执行测试方法之前执行,用于创建SqlSessionFactory并获取SqlSession对象
*/
@Before
public void init() {
try {
//创建SqlSessionFactory,加载mybatis核心配置文件
factory = new SqlSessionFactoryBuilder().build(Resources.getResourceAsStream("mybatis-config.xml"));
//获取SqlSession接口对象
sqlSession = factory.openSession();
//使用动态代理方式创建mapper接口的代理对象
mapper = sqlSession.getMapper(StudentMapper.class);
} catch (IOException e) {
e.printStackTrace();
}
} @Test
public void saveStudent() {
Student stu = new Student(1001,"TOM","123456",new Date());
mapper.saveStudent(stu);
sqlSession.commit();
sqlSession.close();
} @Test
public void selectById(){
Student student = mapper.selectById(1001);
System.out.println(student);
}
@Test
public void findAll(){
List<Student> list = mapper.findAll();
System.out.println(list.toString());
} @Test
public void updateStudent(){
Student stu = new Student(1001, "Tom", "123@", new Date());
mapper.updateStudent(stu);
sqlSession.commit();
} @Test
public void deleteById(){
mapper.deleteById(1001);
sqlSession.commit();
}
}

七、其他相关文件

数据库连接配置db.properties

driver=oracle.jdbc.driver.OracleDriver
url=jdbc:oracle:thin:@127.0.0.1:1521:XE
username=heaven
password=heaven

log4j配置文件log4j.properties

#设置日志输出级别,输出方式
log4j.rootLogger=DEBUG, stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d [%-5p] %c - %m%n
#show sql
log4j.logger.java.sql.ResultSet=INFO
log4j.logger.org.apache=INFO
log4j.logger.java.sql.Connection=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG

MyBatis入门程序(基于XML配置)的更多相关文章

  1. MyBatis应用程序根据XML配置文件创建SqlSessionFactory

    MyBatis应用程序根据XML配置文件创建SqlSessionFactory,SqlSessionFactory在根据配置,配置来源于两个地方,一处是配置文件,一处是Java代码的注解,获取一个Sq ...

  2. Spring Boot 框架下使用MyBatis访问数据库之基于XML配置的方式

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

  3. 【Spring Framework】Spring入门教程(二)基于xml配置对象容器

    基于xml配置对象容器--xml 标签说明 alias标签 作用:为已配置的bean设置别名 --applicationContext.xml配置文件 <?xml version="1 ...

  4. SpringBoot入门之基于XML的Mybatis

    上一博客介绍了下SpringBoot基于注解引入Mybatis,今天介绍基于XML引入Mybatis.还是在上一篇demo的基础上进行修改. 一.Maven引入 这个与上一篇的一样,需要引入mybat ...

  5. Mybatis入门程序

    作为一个java的学习者,我相信JDBC是大家最早接触也是入门级别的数据库连接方式,所以我们先来回忆一下JDBC作为一种用于执行SQL语句的Java API是如何工作的.下面的一段代码就是最基本的JD ...

  6. MyBatis入门程序(1)

    一.入门程序: 1.mybatis的配置文件SqlMapConfig.xml 配置mybatis的运行环境,数据源.事务等. <?xml version="1.0" enco ...

  7. Sping MVC不使用任何注解处理(jQuery)Ajax请求(基于XML配置)

    1. Spring Spring框架是一个轻量级的解决方案,是一个潜在的一站式商店,用于构建企业就绪的应用程序.Spring框架是一个Java平台,为开发Java应用程序提供全面的基础架构支持.Spr ...

  8. Mybatis学习——Mybatis入门程序

    MyBatis入门程序 一.查询用户 1.使用客户编号查询用户 (1).创建一个数据表 USE spring; #创建一个名为t_customer的表 CREATE TABLE t_customer( ...

  9. ssm整合(基于xml配置方式)

    本文是基于xml配置的方式来整合SpringMVC.Spring和Mybatis(基于注解的方式会再写一篇文章),步骤如下: (1)首先自然是依赖包的配置文件 pom.xml <project ...

随机推荐

  1. 42.国际化-配置package的资源文件

    转自:https://wenku.baidu.com/view/84fa86ae360cba1aa911da02.html 同样在建立com.asm包下建立两个资源文件(package级别的资源文件名 ...

  2. could not be installed at this time

    无法下载应用 此时无法安装 Unable to Download App ''App" could not be installed at this time 编译程序的时候,Target ...

  3. ACCESS 组合字段 order by 出错

    ACCESS 组合字段 order by 出错 SELECT boardID,boardType,parentID,child,depth,rootID,(parentStr + ',' + boar ...

  4. windows解压缩版MySQL5.6.40的安装

    windows解压缩版MySQL5.6.40的安装 安装步骤: 1.下载mysql-5.6.40-winx64.zip https://cdn.mysql.com//Downloads/MySQL-5 ...

  5. tensorflow笔记 :常用函数说明

    常用函数说明,梯度.产生变量等 http://blog.csdn.net/c2a2o2/article/details/69061539

  6. 启动JAR Hadoop任务

    [启动JAR Hadoop任务] 一般情况下,我们会使用下面的命令来运行一个hadoop任务: 这个命令实际上是转化成下面的命令来运行的 在RunJar中,会读取abc.jar文件,然后尝试从mani ...

  7. Template7学习记录

    来源:http://idangero.us/template7/#.V2iXqJGF6Ul 测试用json数据: var jsonData = { people: [ { firstName: 'Jo ...

  8. 阿里云Object Storage Service(OSS)

    最近在做一个文件上传.下载的东西,由于上传下载操作频繁.文件存储到独立的服务器, 后来发现阿里云有一项文件存储服务,介绍说很好用,于是就开始使用了. https://help.aliyun.com/d ...

  9. java内存模型—先行发生原则

    Java语言中有一个“先行发生”(happens-before)的原则.这个原则非常重要,它是判断数据是否存在竞争,线程是否安全的主要依据,依赖这个原则,我们可以通过几条规则一揽子解决并发环境下两个操 ...

  10. vs2012

    https://www.microsoft.com/zh-CN/download/confirmation.aspx?id=36020