mybatis入门-开发环境搭建

简介

MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架。MyBatis 避免了几乎所有的 JDBC 代码和手工设置参数以及抽取结果集。MyBatis 使用简单的 XML 或注解来配置和映射基本体,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。

准备

创建一个数据库mybatis,建表user:

开发环境搭建

建立一个名为 MyBaits 的 dynamic web project,mybatis-3.2.8.jarmysql-5.1.8.jar添加到 web工程的lib目录

下载地址:http://code.google.com/p/mybatis/

构建 SqlSessionFactory

每个基于mybatis的应用都是以一个SqlSessionFactory实例为中心的。构建SqlSessionFactory实例有两种方法:xml配置文件和配置类

这里只用xml配置文件的方法来构建SqlSessionFactory实例。

设置mybatis配置文件

在src目录下创建一个Configuration.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="com.org.mybatis.domain.User" />
	</typeAliases>

	<environments default="development">
		<environment id="development">
			<transactionManager type="JDBC" />
			<dataSource type="POOLED">
				<property name="driver" value="com.mysql.jdbc.Driver" />
				<property name="url" value="jdbc:mysql://127.0.0.1:3306/mybatis" />
				<property name="username" value="root" />
				<property name="password" value="123456" />
			</dataSource>
		</environment>
	</environments>

	<mappers>
		<mapper resource="com/org/mybatis/domain/User.xml" />
	</mappers>
</configuration>

typeAliases:类的别名

environment :包含了事务管理和连接池的环境配置。

mappers :包含一组 mapper 映射器(这些 mapper的 XML 文件包含了 SQL 代码和映射定义信息)。



建立与数据库对应的类和映射文件

User.java:

package com.org.mybatis.domain;


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.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.org.mybatis.domain.UserMapper">
    <select id="selectUserByID" parameterType="int" resultType="User">
        select * from user where id = #{id}
    </select>
</mapper>

测试

建立一个测试类Test.java:

package com.org.mybatis.domain;
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.org.mybatis.domain.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.org.mybatis.domain.UserMapper.selectUserByID", 1);
        System.out.println(user.getUserAddress());
        System.out.println(user.getUserName());
        } finally {
        session.close();
        }
    }
}


运行结果:guangdong,chaozhou wck




你可能感兴趣的:(mybatis)