mybatis 对应关系配置

Mybatis     基于Xml配置

1创建数据库表 

创建数据库
create database mybatisDemo;
use mybatisDemo;
create table person(pid  int  primary key AUTO_INCREMENT, pname varchar( 50 ), page  int );
2建立一个java工程,导入包


3 在工程中添加数据库配置文件   mybatis-config.xml

mybatis-config.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>
<!-- 可以配置多个运行环境,但是每个 SqlSessionFactory 实例只能选择一个运行环境  
  一、development:开发模式
   二、work:工作模式-->
 <environments default="development">
 <!--id属性必须和上面的default一样  -->
    <environment id="development">
    <!--事务管理器
        一、JDBC:这个配置直接简单使用了 JDBC 的提交和回滚设置。它依赖于从数据源得到的连接来管理事务范围
        二、MANAGED:这个配置几乎没做什么。它从来不提交或回滚一个连接。而它会让容器来管理事务的整个生命周期
            比如 spring 或 JEE 应用服务器的上下文,默认情况下,它会关闭连接。然而一些容器并不希望这样,
            因此如果你需要从连接中停止它,就可以将 closeConnection 属性设置为 false,比如:
            <transactionManager type="MANAGED">
                <property name="closeConnection" value="false"/>
            </transactionManager>
      -->
      <transactionManager type="JDBC"/>
      <!--dataSource 元素使用标准的 JDBC 数据源接口来配置 JDBC 连接对象源  -->
      <dataSource type="POOLED">
        <property name="driver" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/mybatisdemo"/>
        <property name="username" value="root"/>
        <property name="password" value="root"/>
      </dataSource>
    </environment>
  </environments>
</configuration>
4定义表对应的类

Person.java
package  com.ys.bean;
 
public  class  Person {
     private  int  pid;
     private  String pname;
     private  int  page;
     
     public  int  getPid() {
         return  pid;
     }
     public  void  setPid( int  pid) {
         this .pid = pid;
     }
     public  String getPname() {
         return  pname;
     }
     public  void  setPname(String pname) {
         this .pname = pname;
     }
     public  int  getPage() {
         return  page;
     }
     public  void  setPage( int  page) {
         this .page = page;
     }
     @Override
     public  String toString() {
         return  "Person [pid="  + pid +  ", pname="  + pname +  ", page="  + page
                 "]" ;
     }
}

5定义操作person表的sql映射文件personMapper.xml

personMapper.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.ys.bean.personMapper" >
   <!-- 根据 pid 查询 person 表中的数据
        id:唯一标识符,此文件中的id值不能重复
        resultType:返回值类型,一条数据库记录也就对应实体类的一个对象
        parameterType:参数类型,也就是查询条件的类型
    -->
   <select id= "selectPersonById"
             resultType= "com.ys.bean.Person"  parameterType= "int" >
     <!-- 这里和普通的sql 查询语句差不多,对于只有一个查询条件后面的 #{pid}表示占位符,里面不一定要写pid,写啥都可以,但是不要空着;如果有多个查询条件,则要写pojo类里面的属性 -->
     select * from person where pid = #{pid}
   </select>
   
   <!-- 查询person 表所有数据 -->
   <select id= "getAllPerson"  resultType= "com.ys.bean.Person" >
     select * from person
   </select>
   
   <!-- 根据id更新数据 -->
   <update id= "updatePersonById"  parameterType= "com.ys.bean.Person" >
     update person set pname=#{pname},page=#{page} where pid = #{pid}
   </update>
   
   <!-- 向 person 表插入一条数据 -->
   <insert id= "addPerson"  parameterType= "com.ys.bean.Person" >
     insert into person(pid,pname,page) values(#{pid},#{pname},#{page})
   </insert>
   
   <!-- 根据 pid 删除数据 -->
   <delete id= "deletePersonById"  parameterType= "Long" >
     delete from person where pid=#{pid}
   </delete>
   
</mapper>

6向 mybatis-configuration.xml 配置文件中注册 personMapper.xml 文

<mappers>
        <!-- 注册personMapper.xml文件,
        personMapper.xml位于com.ys.bean这个包下,所以resource写成com/ys/bean/personMapper.xml-->
        <mapper resource= "com/ys/bean/personMapper.xml" />
</mappers>

例:

7创建测试类

MyBatisTest.java
package  com.ys.test;
 
import  java.io.InputStream;
import  java.util.List;
 
import  org.apache.ibatis.session.SqlSession;
import  org.apache.ibatis.session.SqlSessionFactory;
import  org.apache.ibatis.session.SqlSessionFactoryBuilder;
import  org.junit.Before;
import  org.junit.Test;
 
import  com.ys.bean.Person;
 
public  class  MyBatisTest {
     SqlSession session;
     
     @Before
     public  void  beforeLoadXML(){
         //加载 mybatis 配置文件
         InputStream inputStream = MyBatisTest. class .
                 getClassLoader().getResourceAsStream( "mybatis-configuration.xml" );
         //构建sqlSession的工厂
         SqlSessionFactory sqlSessionFactory =
                 new  SqlSessionFactoryBuilder().build(inputStream);
         //根据 sqlSessionFactory 产生 session
         session = sqlSessionFactory.openSession();
     }
     
     //根据 pid 查询 person 表中的数据
     @Test
     public  void  testSelectById(){
         //这个字符串有 personMapper.xml 文件中 两个部分构成
         //<mapper namespace="com.ys.bean.personMapper"> 的 namespace 的值
         //<select id="selectPersonById" > id 值
         String statement =  "com.ys.bean.personMapper" + ".selectPersonById" ;
         Person p = session.selectOne(statement,  1 );
         System.out.println(p);
         session.close();
     }
     
     //查询person 表所有数据
     @Test
     public  void  testGetAllPerson(){
         String statement =  "com.ys.bean.personMapper.getAllPerson" ;
         List<Person> listPerson = session.selectList(statement);
         System.out.println(listPerson);
         session.close();
     }
     
     //根据id更新数据
     @Test
     public  void  updateById(){
         String statement =  "com.ys.bean.personMapper.updatePersonById" ;
         Person p =  new  Person();
         p.setPid( 1 );
         p.setPname( "aaa" );
         p.setPage( 11 );
         session.update(statement, p);
         session.commit();
         session.close();
     }
     
     //向 person 表插入一条数据
     @Test
     public  void  addPerson(){
         String statement =  "com.ys.bean.personMapper.addPerson" ;
         Person p =  new  Person();
         //由于我们设置了主键的自增长机制,故这里不需要手动设置 pid 的值
         //p.setPid(1);
         p.setPname( "add" );
         p.setPage( 11 );
         session.insert(statement, p);
         session.commit();
         session.close();
     }
     
     //根据 pid 删除person 表中的数据
     @Test
     public  void  deletePersonById(){
         String statement =  "com.ys.bean.personMapper.deletePersonById" ;
         session.delete(statement,  1 );
         session.commit();
         session.close();
         
     }
     
 
}







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值