[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 ...
随机推荐
- 文字溢出显示省略号,兼容ie9以上浏览器
最近遇上一个问题,文字溢出展示省略号在ie上不管用,经过查找,是少了word-wrap: normal;这个css属性 width:100px; overflow: hidden; white-spa ...
- 本地化,将cancel替换成"取消"
在工程文件中选info,添加下面内容
- webDriver API——第12部分WebElement
class selenium.webdriver.remote.webelement.WebElement(parent, id_) Bases: object Represents a DOM el ...
- CSS优先级的详细解说
一.什么是CSS优先级? 所谓CSS优先级,即是指CSS样式在浏览器中被解析的先后顺序. 二.CSS优先级规则 既然样式有优先级,那么就会有一个规则来约定这个优先级,而这个“规则”就是本次所需要讲的重 ...
- Pthreads并行编程之spin lock与mutex性能对比分析(转)
POSIX threads(简称Pthreads)是在多核平台上进行并行编程的一套常用的API.线程同步(Thread Synchronization)是并行编程中非常重要的通讯手段,其中最典型的应用 ...
- onWindowFocusChanged重要作用(得到/失去焦点call) 、
onWindowFocusChanged重要作用 Activity生命周期中,onStart, onResume, onCreate都不是真正visible的时间点,真正的visible时间点是onW ...
- javascript Array(数组)
迁移时间:2017年5月25日08:05:33 UpdateTime--2017年3月31日16:29:08 一.数组(Array) (一)用法 //js声明数组的两大类方式 // 第一类(通常使 ...
- android与服务端通讯时使用到的GZIP压缩及解压
为了减小android项目与服务端进行通讯时的数据流量,我们可以使用GZIP对服务端传输的数据进行压缩,在android客户端解压.或在客户端压缩,在服务端解压.代码如下: android客户端的GZ ...
- 13-spring学习-class类型表达式
Class表达式 spring中对于class反射机制也有自己的处理. 1,class::使用T(类名)的形式可以取得一个指定泛型类型的Class对象. 范例: package com.Spring. ...
- Oracle中查询某字段不为空或者为空的SQL语句怎么写
比如 insert into table a (a1,b1)values("a1",''); 对于这种情况,因为表里存的是'',其实是没有内容的,要查询这个字段,不能直接使用 se ...