[J2EE]MyBatis HelloWorld
一、MyBatis简单介绍
iBatis是apche的一个开源项目。2010年迁移到google code后改名为MyBatis,2013年前已到github.MyBatis是一个基于java的持久层框架。与hibernate相比更加简单。关于MyBatis和Hibernate的对照,可參考这篇博客:Hibernate与 MyBatis的比較.
二、MyBatis特点
- 开源的优秀持久层框架
- sql语句与代码分离
- 面向配置编程
- 支持复杂数据映射
- 动态sql
三、MyBatis开发环境搭建
工程文件夹:
3.1下载jar包
- mybatis-3.2.8.zip(3.2.8之后的jar包没有log4j,这一点我临时也不知道为什么)
- mysql-connector,选择JDBC Driver for MySQL下载。
3.2在mysql中新建数据库
MyBatis是一个持久层框架,也就是和数据库打交道的,mysql新建一个数据库用来做測试。
create database book
建立一张user表:
Create Table: CREATE TABLE `User` (
`id` int(10) NOT NULL AUTO_INCREMENT,
`username` varchar(20) NOT NULL,
`passWord` varchar(20) NOT NULL,
PRIMARY KEY (`id`)
)
插入几条记录:
+----+----------+------------+
| id | username | passWord |
+----+----------+------------+
| 1 | 小华 | xiaohua |
| 2 | 柯南 | 666666 |
| 3 | 慕白 | 123456 |
| 4 | 小明 | xiaoming12 |
+----+----------+------------+
这样数据库准备好了,也能够在mysql图形界面中操作。
3.3配置开发环境
3.3.1新建java project
在eclipse中新建java project,命名为Mybatis HelloWorld
3.3.2导入jar包
单击工程名右键->build path->config build path->add external jars,加入下面jar包mysql-connector-java-5.1.38-bin.jar、 mybatis-3.2.8.jar、asm-3.3.1.jar、cglib-2.2.2.jar、commons-logging-1.1.1.jar、javassist-3.17.1-GA.jar、log4j-1.2.17.jar、log4j-api-2.0.2.jar、log4j-core-2.0.2.jar、slf4j-api-1.7.5.jar、slf4j-log4j12-1.7.5.jar
3.3.3配置log4j
在src文件夹下加入log4j.properties,log4j可用来打印sql查询语句:
log4j.rootLogger=DEBUG, CONSOLE
#Console
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
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
3.3.4 加入User.java
新建ucas.book.map、ucas.book.pojo、ucas.book.test包
在ucas.book.pojo包下新建User实体:
package ucas.book.pojo;
public class User {
private int id;
private String username;
private String password;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
3.3.5Mybatis配置文件
在ucas.book.map包下加入mybatis.xml和UserMapper.xml:
数据库连接和相关配置信息写在mybatis.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>
<typeAlias alias="User" type="ucas.book.pojo.User" />
</typeAliases>
<environments default="development">
<environment id="development">
<!-- 事务管理类型,JDBC表示直接使用JDBC的提交和回滚设置,依赖于数据源得到的连接来管理事务 -->
<transactionManager type="JDBC" />
<!-- 数据库连接池POOLED表示使用数据库连接池 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/book?useSSL=true" />
<property name="username" value="root" />
<property name="password" value="napoay" />
</dataSource>
</environment>
</environments>
<mappers>
<!-- SQL代码和映射信息配置文件 -->
<mapper resource="ucas/book/map/UserMapper.xml" />
</mappers>
</configuration>
sql代码写在UserMapper.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">
<!-- namespace必须是唯一的,建议用该文件所在的包路径全类名 -->
<mapper namespace="ucas.book.map.UserMapper">
<!-- select:表示这是一个查询操作 -->
<!-- id:用来配合namespace来定位这个操作,也就是在调用时,将採用ucas.book.pojo.User.getUserById -->
<!-- resultType:表示返回值类型,必须是全类名。MyBatis将自己主动为我们将查询结果封装成Student对象 -->
<!-- parameterType:表示传进来的參数的类型,由于传的是id主键。所以是int型 -->
<select id="getUserById" parameterType="int" resultType="ucas.book.pojo.User">
<!-- #{id}:表示占位符。也就是调用时必须为其传一个id參数进来。注意是#不是$ -->
select * from User where id = #{id}
</select>
</mapper>
<select></select>中写的是通过id查询记录的sql语句。
3.3.6測试代码
package ucas.book.test;
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;
import ucas.book.pojo.User;
public class TestUser {
public static void main(String[] args) {
String resource = "ucas/book/map/mybatis.xml";
Reader reader = null;
SqlSession session;
try {
reader = Resources.getResourceAsReader(resource);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader);
session = factory.openSession();
User user = session.selectOne("getUserById", 1);
System.out.println("\nusername:" + user.getUsername());
session.close();
}
}
结果:
[J2EE]MyBatis HelloWorld的更多相关文章
- Mybaits 源码解析 (一)----- 搭建一个mybatis框架(MyBatis HelloWorld)
源码分析之前先搭一个mybatis的demo,这个在看源码的时候能起到了很大的作用,因为在看源码的时候,会恍然大悟,为什么要这么配置,为什么要这么写.(老鸟可以跳过这篇) 开发环境的准备 创建mave ...
- 01、MyBatis HelloWorld
1. MyBatis简介 1)MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架 2)MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集 3)MyB ...
- J2EE开发HelloWorld
J2EE开发实战基础系列一 HelloWorld 开始咱们的第一个程序,首先是配置环境,按照上一章所描述的方式下载开发工具,然后配置Java环境变量,给大家看下具体的结构: 环境变量配置OK的提示,如 ...
- J2EE MyBatis使用
MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis .20 ...
- 新建一个mybatis HelloWorld
1.下载mybatis https://github.com/mybatis/mybatis-3/ 没有梯子好像打不开 下载一个最新版本,我这里下载的是mybatis-3.4.1.zip 里面有myb ...
- Mybatis——helloWorld级程序
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configuration PUBLIC & ...
- Mybatis(1) 创建Mybatis HelloWorld
简介: MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可以使用简单的 ...
- springboot之HelloWorld
简介 为了简化开发Spring的复杂度,Spring提供了SpringBoot可以快速开发一个应用,这里就简单介绍下SpringBoot如何快速开发一个J2EE应用 HelloWorld 首先在gra ...
- mybatis(1)
一.MyBatis简介 MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架.MyBatis 消除了几乎所有的 JDBC 代码和参数的手工设置以及结果集的检索.MyBatis ...
随机推荐
- 利用Nodejs & Cheerio & Request抓取Lofter美女图片
还是参考了这篇文章: http://cnodejs.org/topic/54bdaac4514ea9146862abee 另外有上面文章 nodejs抓取网易公开课的一些经验. 代码如下,注意其中用到 ...
- centOS6.5 Hadoop1.0.4安装
前段时间去培训,按照教程装了一遍Hadoop.回来又重新装一次,捋下思路,加深理解. 基本配置如下,三个节点,一个namenode,两个datanode. Namenode 192.168.59.14 ...
- 使用Fabric模块实现自动化运维
一.安装软件 简介:Fabric是基于Python实现的SSH命令行工具,简化了SSH的应用程序部署及系统管理任务,它提供了系统基础的操作组件,可以实现本地或远程shell命令,包括:命令执行.文件上 ...
- (六)SSO之CAS框架扩展 改动CAS源代码实现与ESS动态password验证对接
题记: 偶尔的偶尔我们会听到这个站点的数据泄露了,那个站点的用户数据泄露了.让用户又一次改动登录password,所以,对于用户数据安全性越发的引起我们的重视了,尤其是一些保密性要求高的站点.更须要添 ...
- js文件加载执行顺序
转自:http://blog.163.com/water_down/blog/static/170276590201111711243458/ <script type="text/j ...
- 极客技术专题【011期】:EasyUI初级教程
来源:GBin1.com 技术专题:EasyUI初级教程 分享人:极客标签技术编辑 - html580(请站内关注分享人) 资深Web前端工程师,HTML580创始人,目前就职于广州一间软件公司.多年 ...
- vue 项目心得
v-bind 数据绑定 可以简写成 : 通过 props 将数据对象 传给 组件 export default { props: { seller: { type: Object } } } crea ...
- js操作当前窗口
CreateTime--2017年7月21日09:58:34Author:Marydon js操作当前窗口 1.打开一个新的窗口(新的标签页) 实现方式:window.open(url) 实例一: ...
- 基于mybatis-generator代码生成工具改(链式方法实体版)
概述 一直以来使用原生mybatis-generator的我发现有一个地方很不方便,即它生成的实体类的set方法返回值是void,而目前比较流行的则是链式set的写法,即set方法返回值不再是void ...
- 仿网易/QQ空间视频列表滚动连播炫酷效果
代码地址如下:http://www.demodashi.com/demo/11201.html 一.准备工作 AndroidStudio 开发环境 需要下载七牛的开源播放器SDK 本例子实现了仿网易/ ...