zoukankan      html  css  js  c++  java
  • MyBatis入门学习(一)

    所须要jar包:mybatis-3.x.x.jar 、假设须要和spring整合,还须要增加相关的包

    1:看项目文件夹 红颜色不要关心

    2:依照步骤:

    1:增加jar包

    2:创建数据源(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>
    		<!--给实体类起一个别名 user -->
    		<typeAlias type="com.forum.po.User" alias="User" />
    	</typeAliases>
    	<!--数据源配置  这块用 BD2数据库 -->
    	<environments default="development">
    		<environment id="development">
    			<transactionManager type="jdbc" />
    			<dataSource type="POOLED">
    				<property name="driver" value="com.ibm.db2.jcc.DB2Driver" />
    				<property name="url" value="jdbc:db2://localhost:50000/forum" />
    				<property name="username" value="DB2ADMIN" />
    				<property name="password" value="admin" />
    			</dataSource>
    		</environment>
    	</environments>
    	<mappers>
    		<!--userMapper.xml装载进来  同等于把“dao”的实现装载进来 -->
    		<mapper resource="myBatis/userMapper.xml" />
    	</mappers>
    </configuration> 
    3:创建实体类USER

    package com.forum.po;
    
    /**
     * 用户类
     * 
     * @author db2admin
     * 
     */
    public class User extends Entity {
    	private String name;
    	private Integer age;
    	public String getName() {
    		return name;
    	}
    	public void setName(String name) {
    		this.name = name;
    	}
    	public Integer getAge() {
    		return age;
    	}
    	public void setAge(Integer age) {
    		this.age = age;
    	}
    	public User() {
    	}
    
    }

    4:创建dao接口、能够说是Mapper接口:UserMapper

    package com.forum.dao;
    
    import com.forum.po.User;
    
    public interface UserMapper {
    	public User findById(String Id);
    }
    

    5:创建dao的实现,不同于hibernarte的此处的实现为一个xml文件,也就是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">
    	<!--这块等于dao接口的实现  namespace必须和接口的类路径一样-->
    <mapper namespace="com.forum.dao.UserMapper">
    	<!-- findById必须和接口中的方法名一样  返回一个User  就是刚才的别名  假设不弄别名要连类路径一起写 麻烦-->
    	<select id="findById" parameterType="HashMap" resultType="User">
    		select
    		* from butone.student where id=#{id}
        </select>
    </mapper>

    6:測试类,MyBatisTest

    package com.forum.test;
    
    import java.io.IOException;
    
    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.forum.dao.UserMapper;
    import com.forum.po.User;
    
    /**
     * myBatis数据库连接測试
     * 
     * @author db2admin
     * 
     */
    public class MyBatisTest {
    	/**
    	 * 获得MyBatis SqlSessionFactory  
    	 * SqlSessionFactory负责创建SqlSession,一旦创建成功,就能够用SqlSession实例来运行映射语句,commit,rollback,close等方法。
    	 * @return
    	 */
    	private static SqlSessionFactory getSessionFactory() {
    		SqlSessionFactory sessionFactory = null;
    		String resource = "configuration.xml";
    		try {
    			sessionFactory = new SqlSessionFactoryBuilder().build(Resources
    					.getResourceAsReader(resource));
    		} catch (IOException e) {
    			// TODO Auto-generated catch block
    			e.printStackTrace();
    		}
    		return sessionFactory;
    	}
    
    	public static void main(String[] args) {
    		SqlSession sqlSession = getSessionFactory().openSession();
    		UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
    		User user = userMapper.findById("1");
    		System.out.println(user.getName());
    
    	}
    
    }

  • 相关阅读:
    如何在for循环中使用多线程
    解决ios10以上H5页面手势、双击缩放问题
    select标签默认选项
    vue三级联动
    手动安装composer详细教学
    密码校验:长度6位以上,至少包含一个数字,一个大写字母,一个小写字母,不包含空格
    tp5生成6位不重复验证码
    css漂亮的阴影边框
    圆形进度条css3样式
    jQuery倒计时组件(jquery.downCount.js)
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/4042337.html
Copyright © 2011-2022 走看看