mybatis实战教程(mybatis in action)之一:开发环境搭建

摘要: mybatis 的开发环境搭建,选择: eclipse j2ee 版本,mysql 5.1 ,jdk 1.7,mybatis3.2.0.jar包。这些软件工具均可以到各自的官方网站上下载。首先建立一个名字为 MyBaits 的 dynamic web project  1. 现阶段,你可以直接建立java 工程,但一般都是开发web项目,这个系列教程最后也是web的,所以一开始就建立web工程。2. 将 mybatis-3.2.0-SNAPSHOT.jar,mysql-connector-java-5.1.22-bin.jar 拷贝到 web工程的lib目录.3. 创建mysql 测试数据库和用户表,注意,这里采用的是 utf-8 编码

mybatis 的开发环境搭建,选择: eclipse j2ee 版本,mysql 5.1 ,jdk 1.7,mybatis3.2.0.jar包。这些软件工具均可以到各自的官方网站上下载。
首先建立一个名字为 MyBaits 的 dynamic web project
1. 现阶段,你可以直接建立java 工程,但一般都是开发web项目,这个系列教程最后也是web的,所以一开始就建立web工程。
2. 将 mybatis-3.2.0-SNAPSHOT.jar,mysql-connector-java-5.1.22-bin.jar 拷贝到 web工程的lib目录.
3. 创建mysql 测试数据库和用户表,注意,这里采用的是 utf-8 编码

创建用户表,并插入一条测试数据

Create TABLE `user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `userName` varchar(50) DEFAULT NULL,
  `userAge` int(11) DEFAULT NULL,
  `userAddress` varchar(200) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;


Insert INTO `user` VALUES ('1', 'summer', '100', 'shanghai,pudong');

到此为止,前期准备工作就完成了。下面开始真正配置mybatis项目了。
1. 在MyBatis 里面创建两个源码目录,分别为 src_user,test_src, 用如下方式建立,鼠标右键点击 JavaResource.


2. 设置mybatis 配置文件:Configuration.xml, 在src_user目录下建立此文件,内容如下:



     
         
     

	
		
		
			
			
			
			
			
			
		
	
	
	
	    
	



3. 建立与数据库对应的 java class,以及映射文件.
在src_user下建立package:com.yihaomen.mybatis.model ,并在这个 package 下建立 User 类:
package com.yihaomen.mybatis.model;

public class User {
	
	private int id;
	private String userName;
	private String userAge;
	private String userAddress;
	
	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 getUserAge() {
		return userAge;
	}
	public void setUserAge(String userAge) {
		this.userAge = userAge;
	}
	public String getUserAddress() {
		return userAddress;
	}
	public void setUserAddress(String userAddress) {
		this.userAddress = userAddress;
	}

}


同时建立这个User 的映射文件 User.xml:




	



下面对这几个配置文件解释下:
1.Configuration.xml 是 mybatis 用来建立 sessionFactory 用的,里面主要包含了数据库连接相关东西,还有 java 类所对应的别名,比如 这个别名非常重要,你在 具体的类的映射中,比如User.xml 中 resultType 就是对应这里的。要保持一致,当然这里的 resultType 还有另外单独的定义方式,后面再说。
2. Configuration.xml 里面 的是包含要映射的类的xml配置文件。
3. 在User.xml 文件里面 主要是定义各种SQL 语句,以及这些语句的参数,以及要返回的类型等.

开始测试
在test_src 源码目录下建立com.yihaomen.test这个package,并建立测试类Test:
package com.yihaomen.test;

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 com.yihaomen.mybatis.model.User;

public class Test {
    private static SqlSessionFactory sqlSessionFactory;
    private static Reader reader; 

    static{
        try{
            reader    = Resources.getResourceAsReader("Configuration.xml");
            sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
        }catch(Exception e){
            e.printStackTrace();
        }
    }

    public static SqlSessionFactory getSession(){
        return sqlSessionFactory;
    }
    
    public static void main(String[] args) {
    	SqlSession session = sqlSessionFactory.openSession();
    	try {
    	User user = (User) session.selectOne("com.yihaomen.mybatis.models.UserMapper.selectUserByID", 1);
    	System.out.println(user.getUserAddress());
    	System.out.println(user.getUserName());
    	} finally {
    	session.close();
    	}
	}
}

现在运行这个程序,是不是得到查询结果了。恭喜你,环境搭建配置成功,接下来第二章,将讲述基于接口的操作方式,增删改查。
整个工程目录结构如下:

上一篇: mybatis实战教程(mybatis in action),mybatis入门到精通
下一篇: mybatis实战教程(mybatis in action)之二:以接口的方式编程

Avatar

wulasong 评论于: 2017-11-29

[quote=iBambooes]你好,请问为什么我在第一步的时候就提示
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/log4j/Priority
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:274)
    at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:176)
    at org.apache.ibatis.io.Resources.classForName(Resources.java:254)
    at org.apache.ibatis.type.TypeAliasRegistry.registerAlias(TypeAliasRegistry.java:153)
    at org.apache.ibatis.session.Configuration.(Configuration.java:173)
    at org.apache.ibatis.builder.xml.XMLConfigBuilder.(XMLConfigBuilder.java:76)
    at org.apache.ibatis.builder.xml.XMLConfigBuilder.(XMLConfigBuilder.java:60)
    at org.apache.ibatis.session.SqlSessionFactoryBuilder.build(SqlSessionFactoryBuilder.java:48)

[/quote]mybatis3.2.0.jar 换成3.4.5就行了
[reply=yihaomen,2017-11-30 07:56 PM]http://www.yihaomen.com/article/java/665.htm, 参考这个例子吧,虽然是几年前的老版本,参考价值还是有的。[/reply]

Avatar

我去勒 评论于: 2017-06-07

文件上传这个功能怎么没有啊?博客没图
[reply=yihaomen,2017-11-30 07:56 PM]我在这里有一个例子。http://www.yihaomen.com/article/java/665.htm[/reply]

Avatar

游客yy 评论于: 2017-06-07

[img][/img]
怎么回事?

Avatar

cyb 评论于: 2016-11-08

good[face41]

Avatar

yeyu 评论于: 2015-08-05

可以把所有包怎么下载也告诉我们吗?我直接刚接触这东东
[reply=yihaomen,2015-08-06 01:05 PM]http://www.yihaomen.com/article/java/318.htm 这里有下载的。[/reply]

Avatar

iBambooes 评论于: 2015-07-31

你好,请问为什么我在第一步的时候就提示
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/log4j/Priority
	at java.lang.Class.forName0(Native Method)
	at java.lang.Class.forName(Class.java:274)
	at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:176)
	at org.apache.ibatis.io.Resources.classForName(Resources.java:254)
	at org.apache.ibatis.type.TypeAliasRegistry.registerAlias(TypeAliasRegistry.java:153)
	at org.apache.ibatis.session.Configuration.(Configuration.java:173)
	at org.apache.ibatis.builder.xml.XMLConfigBuilder.(XMLConfigBuilder.java:76)
	at org.apache.ibatis.builder.xml.XMLConfigBuilder.(XMLConfigBuilder.java:60)
	at org.apache.ibatis.session.SqlSessionFactoryBuilder.build(SqlSessionFactoryBuilder.java:48)

Avatar

aa 评论于: 2015-06-24

null
空指针异常

Avatar

不若风 评论于: 2014-05-19

好文章!!!

Avatar

风雪夜归人 评论于: 2013-10-24

[quote=风雪夜归人]你好,你这个不能运行吧,没有UserMapper借口哎

 轻舞肥羊 于 2013-10-21 08:44 PM 回复能运行的。看看后面的几篇文章,后来有代码下载的。[/quote]

谢谢!不好意思,初学,还以为只有接口的方式呢

Avatar

风雪夜归人 评论于: 2013-10-21

你好,你这个不能运行吧,没有UserMapper借口哎
[reply=轻舞肥羊,2013-10-21 08:44 PM]能运行的。看看后面的几篇文章,后来有代码下载的。[/reply]

Avatar

weasd 评论于: 2013-06-25

明白了 namespace="com.yihaomen.mybatis.models.UserMapper"就是定义一个名字  方便后面使用的时候就通过这个名字告诉程序应该执行哪段代码

Avatar

weasd 评论于: 2013-06-25

你好。请问,在user.xml 中后面内容namespace指向的是接口,但是现在写着namespace="com.yihaomen.mybatis.models.UserMapper"  并没有这个类啊?是一种固定写法?

同问

Avatar

wangmengself 评论于: 2013-05-25

你好。请问,在user.xml 中后面内容namespace指向的是接口,但是现在写着namespace="com.yihaomen.mybatis.models.UserMapper"  并没有这个类啊?是一种固定写法?

Avatar

wpt 评论于: 2012-12-25

你好,请问你那个静态的getSession()方法有用途吗  session已经通过静态代码块拿到了啊
[reply=轻舞肥羊,2012-12-25 04:17 PM]session 是在 静态方法中得到的。这个例子里没用到,其实最终的session 是由sessionfactory产生。[/reply]
 评论 ( What Do You Think )
名称
邮箱
网址
评论
验证
   
 

 


  • 微信公众号

  • 我的微信

站点声明:

1、一号门博客CMS,由Python, MySQL, Nginx, Wsgi 强力驱动

2、部分文章来源于互联网, 若有侵权, 联系邮箱:summer@yihaomen.com, 同时欢迎大家注册用户,主动发布文章.

3、鄂ICP备14001754号-3, 鄂公网安备 42280202422812号