MyBatis的经典案例
1.首先我们先了解Mybatis的一些jar包

---和项目框架

2.接下来就看看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>
<!-- 别名 -->
<typeAliases >
<package name="cn.happy.entity"/>
</typeAliases> <environments default="development">
<environment id="development">
<!-- 使用jdbc的事务 -->
<transactionManager type="JDBC" />
<!-- 使用自带的连接池 -->
<dataSource type="POOLED">
<property name="driver" value="oracle.jdbc.OracleDriver" />
<property name="url" value="jdbc:oracle:thin:@localhost:1521:orcl" />
<property name="username" value="happy" />
<property name="password" value="1" />
</dataSource>
</environment>
</environments>
<mappers>
<!-- 连接小配置 -->
<mapper resource="cn/happy/dao/StudentDAO.xml" />
</mappers>
</configuration>
3.在dao层的小配置(StudentDAO.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="cn.happy.dao"> <!-- 添加 -->
<insert id="insertStudent">
insert into student(stuno,stuname,stuage,studate)
values(ssm.nextval,#{stuname},#{stuage},#{studate}) <selectKey keyProperty="stuno" resultType="int">
select SSM.CURRVAL from dual
</selectKey>
</insert>
<!-- 查询所有 -->
<select id="findAll" resultType="Student">
select * from student
</select> <!-- 模糊查询 -->
<select id="findAllLike" resultType="Student">
<!-- 不管参数为什么都可以 -->
<!--select * from student where stuname like concat('%',#{stuname},'%')-->
<!-- 字符串 -->
<!-- select * from student where stuname like '%${value}%' -->
<!-- 对象 -->
select * from student where stuname like '%${stuname}%'
</select> <!--删除学生 --> <delete id="delStudent">
delete from student where stuno=#{id}<!-- #{id}随便写,起到一个占位的作用 -->
</delete> </mapper>
4.entity层实体类(Student)
package cn.happy.entity;
import java.util.Date;
public class Student {
private int stuno;
private String stuname;
private int stuage;
private Date studate;
public String toString() {
return "Student [stuno=" + stuno + ", stuname=" + stuname + ", stuage="
+ stuage + ", studate=" + studate + "]";
}
public int getStuno() {
return stuno;
}
public void setStuno(int stuno) {
this.stuno = stuno;
}
public String getStuname() {
return stuname;
}
public void setStuname(String stuname) {
this.stuname = stuname;
}
public int getStuage() {
return stuage;
}
public void setStuage(int stuage) {
this.stuage = stuage;
}
public Date getStudate() {
return studate;
}
public void setStudate(Date studate) {
this.studate = studate;
}
}
5.dao层(IStudentDAO)
package cn.happy.dao; import java.io.IOException;
import java.util.List; import cn.happy.entity.Student; public interface IStudentDAO { /*
* 添加学生信息
*/
public int addStu(Student stu) throws IOException; /*
* 查询所有
*/
public List<Student> findAll() throws IOException; /*
* 模糊查询
*/
public List<Student> findAlllike(Student stu) throws IOException; /*
* 模糊查询字符串
*/
public List<Student> findAlllikebstuname(String stuname) throws IOException; /*
* 删除
*/
public int delStudent(int id) throws IOException;
}
6.dao层下的impl层(IStudentDAOImpl)
package cn.happy.dao.impl; import java.io.IOException;
import java.util.List;
import org.apache.ibatis.session.SqlSession;
import cn.happy.dao.IStudentDAO;
import cn.happy.entity.Student;
import cn.happy.util.MybatisUtil; public class IStudentDAOImpl implements IStudentDAO{ /*
* session成员变量
*/
SqlSession session; /*
* 添加
* (non-Javadoc)
* @see cn.happy.dao.IStudentDAO#addStu(cn.happy.entity.Student)
*/
public int addStu(Student stu) throws IOException {
//获取session
session = MybatisUtil.getSession(); //添加insert
int result = session.insert("insertStudent", stu); //添加事物
session.commit(); //关闭session
session.close();
return result;
} /*
* 查询所有
* (non-Javadoc)
* @see cn.happy.dao.IStudentDAO#fandAll()
*/
public List<Student> findAll() throws IOException {
//获取session
session = MybatisUtil.getSession();
List<Student> list = session.selectList("findAll");
//关闭session
session.close();
return list;
} /*
* 模糊查询
* 1.参数为对象
* (non-Javadoc)
* @see cn.happy.dao.IStudentDAO#findAll(cn.happy.entity.Student)
*/
public List<Student> findAlllike(Student stu) throws IOException {
//获取session
session = MybatisUtil.getSession();
List<Student> list = session.selectList("findAllLike",stu);
//关闭session
session.close();
return list;
} /*
* 模糊查询
* 2.参数为字符串
* (non-Javadoc)
* @see cn.happy.dao.IStudentDAO#findAll(cn.happy.entity.Student)
*/
public List<Student> findAlllikebstuname(String stuname) throws IOException {
//获取session
session = MybatisUtil.getSession();
System.out.println("222");
List<Student> list = session.selectList("findAllLike",stuname);
System.out.println("333");
//关闭session
session.close();
return list;
} /*
* 删除
*/
public int delStudent(int id) throws IOException {
//获取session
session = MybatisUtil.getSession();
int result = session.delete("delStudent", id);
session.commit();
return result;
} }
7.util层的工具类(MybatisUtil )
package cn.happy.util; import java.io.IOException;
import java.io.Reader; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; /**
* 工具类
* @author Happy
*
*/
public class MybatisUtil {
private static String config="mybatis-config.xml";
static Reader reader;
static{
try {
reader= Resources.getResourceAsReader(config);
} catch (IOException e) {
e.printStackTrace();
}
}
private static SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader);
//提供一个可以获取到session的方法
public static SqlSession getSession() throws IOException{ // 1.1 openSession到底做了什么
SqlSession session = factory.openSession();
System.out.println("3333");
return session;
}
}
8. 日志信息配置文件(log4j.properties)
### direct log messages to stdout ###
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n ### direct messages to file mylog.log ###
log4j.appender.file=org.apache.log4j.FileAppender
log4j.appender.file.File=c\:mylog.log
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n ### set log levels - for more verbose logging change 'info' to 'debug' ###
//记录cn.happy.dao包下的信息
log4j.logger.cn.happy.dao=trace, stdout
暂时就这么多了,如果想了解更多就记得多多关注吧!!!!
MyBatis的经典案例的更多相关文章
- javascript的理解及经典案例
js的简介: JavaScript是一种能让你的网页更加生动活泼的程式语言,也是目前网页中设计中最容易学又最方便的语言. 你可以利用JavaScript轻易的做出亲切的欢迎讯息.漂亮的数字钟.有广告效 ...
- jQuery基础的工厂函数以及定时器的经典案例
1. jQuery的基本信息: 1.1 定义: jQuery是JavaScript的程序库之一,它是JavaScript对象和实用函数的封装, 1.2 作用: 许多使用JavaScript能实现的交 ...
- Linux运维之道(大量经典案例、问题分析,运维案头书,红帽推荐)
Linux运维之道(大量经典案例.问题分析,运维案头书,红帽推荐) 丁明一 编 ISBN 978-7-121-21877-4 2014年1月出版 定价:69.00元 448页 16开 编辑推荐 1 ...
- 经典案例:那些让人赞不绝口的创新 HTML5 网站
在过去的10年里,网页设计师使用 Flash.JavaScript 或其他复杂的软件和技术来创建网站.但现在你可以前所未有的快速.轻松地设计或创造互动的.有趣好看的网站.如何创建?答案是 HTML5 ...
- Altera OpenCL用于计算机领域的13个经典案例(转)
英文出自:Streamcomputing 转自:http://www.csdn.net/article/2013-10-29/2817319-the-application-areas-opencl- ...
- php中foreach()函数与Array数组经典案例讲解
//php中foreach()函数与Array数组经典案例讲解 function getVal($v) { return $v; //可以加任意检查代码,列入要求$v必须是数字,或过滤非法字符串等.} ...
- 阿里云资深DBA专家罗龙九:云数据库十大经典案例分析【转载】
阿里云资深DBA专家罗龙九:云数据库十大经典案例分析 2016-07-21 06:33 本文已获阿里云授权发布,转载具体要求见文末 摘要:本文根据阿里云资深DBA专家罗龙九在首届阿里巴巴在线峰会的&l ...
- 经典案例之MouseJack
引言:在昨天的文章<无线键鼠监听与劫持>中,我们提到今天会向您介绍一个无线键鼠的监听与劫持的经典案例,<MouseJack>:MouseJack能利用无线鼠标和键盘存在的一些问 ...
- HTML5 CSS3 经典案例:无插件拖拽上传图片 (支持预览与批量) (二)
转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/31513065 上一篇已经实现了这个项目的整体的HTML和CSS: HTML5 C ...
随机推荐
- 显示或隐藏div
代码来源于博客,如有侵权,请联系我! ASP.NET中TextBox控件设置ReadOnly="true"H或Enabled=false后台取不到值 当TextBox设置了Read ...
- 使用keychain保存用户名和密码等敏感信息 KeychainItemWrapper和SFHFKeychainUtils
iOS的keychain服务提供了一种安全的保存私密信息(密码,序列号,证书等)的方式,每个ios程序都有一个独立的keychain存储.相对于 NSUserDefaults.文件保存等一般方式,ke ...
- WPF 画心2.0版之元旦快乐
2017年元旦已经到了,想做一个祝福语的窗口,就把上一篇画心的程序改了改,变成了如下界面. 说下改动的地方,首先窗口没有标题栏了. MainWindow.xaml AllowsTransparency ...
- C#后台调用公网接口(GET, POST)
//get方法调用接口获取json文件内容 public void GetFunction() { string service ...
- php定界符<<<EOF讲解(转)
Heredoc技术.可用来输出大段的html和javascript脚本 1.PHP定界符的作用就是按照原样,包括换行格式什么的,输出在其内部的东西: 2.在PHP定界符中的任何特殊字符都不需要转义: ...
- AJAX的核心XMLHttpRequest对象
为了实现异步通讯,提高用户体验度,而将很多旧知识(XML,DOM,JavaScript,HTML,jQuery,Css...)重新融合程一个新的知识框架.而XMLHttpRequest对象则是其中的重 ...
- Jenkins+Maven+SVN快速搭建持续集成环境
http://www.cnblogs.com/sunzhenchao/archive/2013/01/30/2883289.htmlhttp://blog.csdn.net/pein_zero/art ...
- C#使用ListView更新数据出现闪烁解决办法
C#使用ListView更新数据出现闪烁解决办法 在使用vs自动控件ListView控件时候,更新里面的部分代码时候出现闪烁的情况 如图: 解决以后: 解决办法使用双缓冲:添加新类继承ListView ...
- Aspx页面模拟WebService功能
在后台引入 using System.Web.Services 命名空间 然后在编写web服务方法: [WebMethod] public static string GetData(string t ...
- UWP VirtualizedVariableSizedGridView 支持可虚拟化可变大小Item的View(二)
上篇UWP VirtualizedVariableSizedGridView 支持可虚拟化可变大小Item的View(一) 讲到该控件的需要和设计过程. 这篇讲讲开发过程中一些重要问题解决. 1.支持 ...