Mybatis知识系列之一:认识Mabatis

1、什么mybatis?

mybatis是一个基于Java持久层框架。

2、持久化:数据从瞬时状态变为持久状态。

3、持久层:完成持久化工作的代码块。---dao

4、Mybatis就是帮助程序猿将数据存入数据库中,和从数据库中取数据。

5、传统的jdbc操作:有很多重复代码块。比如:数据取出时的封装。数据库的建立连接等等。通过框架可以减少重复代码,提高开发效率。

6、Mybatis是一个半自动化的ORM框架。O--object,R--relationship,M--mapping

7、Mybatis的功能:

MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。

8、如何使用mybatis?

步骤:

a)导入mybatis相关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-rc1.jar

log4j-core-2.0-rc1.jar

mybatis-3.2.7.jar

slf4j-api-1.7.5.jar

slf4j-log4j12-1.7.5.jar

数据库驱动包

b)编写mybatis核心配置文件

<?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>

   <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://localhost:3306/test" />

            <property name="username" value="root" />

            <property name="password" value="root" />

         </dataSource>

      </environment>

   </environments>

   <!-- <mappers>

      <mapper resource="org/mybatis/example/BlogMapper.xml" />

   </mappers> -->

</configuration>

 

c)创建SqlSessionFactory,以及获得SqlSession

public class MyBatisUtil {

   public static SqlSessionFactory getSqlSessionFactory() throws IOException{

      String resource = "mybatis.cfg.xml";

      InputStream inputStream = Resources.getResourceAsStream(resource);

      SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

      return sqlSessionFactory;

   }

   public static SqlSession getSession() throws IOException{

      SqlSessionFactory sqlSessionFactory=getSqlSessionFactory();

      return sqlSessionFactory.openSession();

   }

}

 

 

d)创建实体类

public class User {

   private int id;

   private String name;

   private String pwd;

   public int getId() {

      return id;

   }

   public void setId(int id) {

      this.id = id;

   }

   public String getName() {

      return name;

   }

   public void setName(String name) {

      this.name = name;

   }

   public String getPwd() {

      return pwd;

   }

   public void setPwd(String pwd) {

      this.pwd = pwd;

   }

}

 

 

e)编写sql语句的映射文件---添加到核心配置文件中

<?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="cn.sxt.entity.UserMapper">

   <select id="selectUser" resultType="cn.sxt.entity.User">

   select * from user where id = #{id}

   </select>

</mapper>

 

f)测试

public class Test {

   public static void main(String[] args) throws IOException {

      SqlSession session=MyBatisUtil.getSession();

      User user = session.selectOne("cn.sxt.entity.UserMapper.selectUser", 1);

      System.out.println("id="+user.getId()+",name="+user.getName()+",pwd="+user.getPwd());

      session.close();

   }

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值