MyBatis_入门案例(xml)

文章目录

      • 2. MyBatis 入门案例(xml)
        • 2.1. 数据库连接
        • 2.2. MyBatis核心配置
        • 2.3. mapper.xml
        • 2.4. 测试
        • 总结:

2. MyBatis 入门案例(xml)

使用xml配置的方式查询出user表中的数据

  1. 配置数据库连接
  2. 设置mybatis核心配置文件
  3. 编写mybatis的sql映射文件
  4. 测试

2.1. 数据库连接

jdbc.properties

#注意mybatis版本>=6.0使用如下驱动,如果<6.0使用com.mysql.jdbc.Driver
driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=UTF-8&&serverTimezone=Hongkong&useSSL=false
username=root
password=root

如果连接数据库错误
=app

2.2. MyBatis核心配置

mybatis-config.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN"".dtd"><configuration><!--引入jdbc属性配置--><properties resource="jdbc.properties"></properties><!--mybatis的核心环境配置--><environments default="development"><environment id="development"><!--在 MyBatis 中有两种类型的事务管理器(也就是 type="[JDBC|MANAGED]"):JDBC – 这个配置直接使用了 JDBC 的提交和回滚设施MANAGED – 这个配置几乎没做什么--><transactionManager type="JDBC"/><!--type可选值:UNPOOLED 不使用连接池POOLED使用连接池JNDI 从配置好的JNDI数据源获取连接池--><dataSource type="POOLED"><property name="driver" value="${driver}"/><property name="url" value="${url}"/><property name="username" value="${username}"/><property name="password" value="${password}"/></dataSource></environment></environments><mappers><mapper resource="mapper/UserMapper.xml"/></mappers>
</configuration>

2.3. mapper.xml

在resource目录下新建mapper目录,存放UserMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"".dtd"><!--
namespace
用于对SQL语句进行隔离,mapper文件有多个,不同的mapper文件中SQL可能重复,
可以使用namespace进行区分,因此namespace最好保证唯一性,否则没有意义
-->
<mapper namespace="test"><!--id:sql片段的唯一标识,同一个mapper文件中不能重复parameterType:参数类型resultType:返回值类型--><select id="selectOne" parameterType="int" resultType="com.czxy.mybatis.model.User">SELECTuid,username,birthday,phone,sex,addressFROM `user`WHERE uid = #{id}</select></mapper>

2.4. 测试

测试类:MyBatisTest.java

public class MyBatisTest {@Testpublic void selectOne() throws IOException {//1.配置文件位置String resource = "mybatis-config.xml";//2.读取配置文件InputStream inputStream = Resources.getResourceAsStream(resource);//3.通过配置文件创建SessionFactorySqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);//SqlSession 提供了在数据库执行 SQL 命令所需的所有方法。 可以通过 SqlSession 实例来直接执行已映射的 SQL 语句//4.读取数据库连接SqlSession sqlSession = sqlSessionFactory.openSession();//5.通过 namespace.id的方式确定要执行的SQL片段User user = sqlSession.selectOne("test.selectOne",10);System.out.println(user);//6.用完后必须关闭连接sqlSession.close();}
}

总结:

  • mybatis开发过程总结
  1. 编写mybatis-config.xml
  2. 编写mapper.xml
  3. 编程通过配置文件创建SqlSessionFactory
  4. 通过SqlSessionFactory获取SqlSession
  5. 通过SqlSession操作数据库:
    1. 如果执行添加、更新、删除需要调用SqlSession.commit()
  6. SqlSesion使用完成要关闭

MyBatis_入门案例(xml)

文章目录

      • 2. MyBatis 入门案例(xml)
        • 2.1. 数据库连接
        • 2.2. MyBatis核心配置
        • 2.3. mapper.xml
        • 2.4. 测试
        • 总结:

2. MyBatis 入门案例(xml)

使用xml配置的方式查询出user表中的数据

  1. 配置数据库连接
  2. 设置mybatis核心配置文件
  3. 编写mybatis的sql映射文件
  4. 测试

2.1. 数据库连接

jdbc.properties

#注意mybatis版本>=6.0使用如下驱动,如果<6.0使用com.mysql.jdbc.Driver
driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=UTF-8&&serverTimezone=Hongkong&useSSL=false
username=root
password=root

如果连接数据库错误
=app

2.2. MyBatis核心配置

mybatis-config.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN"".dtd"><configuration><!--引入jdbc属性配置--><properties resource="jdbc.properties"></properties><!--mybatis的核心环境配置--><environments default="development"><environment id="development"><!--在 MyBatis 中有两种类型的事务管理器(也就是 type="[JDBC|MANAGED]"):JDBC – 这个配置直接使用了 JDBC 的提交和回滚设施MANAGED – 这个配置几乎没做什么--><transactionManager type="JDBC"/><!--type可选值:UNPOOLED 不使用连接池POOLED使用连接池JNDI 从配置好的JNDI数据源获取连接池--><dataSource type="POOLED"><property name="driver" value="${driver}"/><property name="url" value="${url}"/><property name="username" value="${username}"/><property name="password" value="${password}"/></dataSource></environment></environments><mappers><mapper resource="mapper/UserMapper.xml"/></mappers>
</configuration>

2.3. mapper.xml

在resource目录下新建mapper目录,存放UserMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"".dtd"><!--
namespace
用于对SQL语句进行隔离,mapper文件有多个,不同的mapper文件中SQL可能重复,
可以使用namespace进行区分,因此namespace最好保证唯一性,否则没有意义
-->
<mapper namespace="test"><!--id:sql片段的唯一标识,同一个mapper文件中不能重复parameterType:参数类型resultType:返回值类型--><select id="selectOne" parameterType="int" resultType="com.czxy.mybatis.model.User">SELECTuid,username,birthday,phone,sex,addressFROM `user`WHERE uid = #{id}</select></mapper>

2.4. 测试

测试类:MyBatisTest.java

public class MyBatisTest {@Testpublic void selectOne() throws IOException {//1.配置文件位置String resource = "mybatis-config.xml";//2.读取配置文件InputStream inputStream = Resources.getResourceAsStream(resource);//3.通过配置文件创建SessionFactorySqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);//SqlSession 提供了在数据库执行 SQL 命令所需的所有方法。 可以通过 SqlSession 实例来直接执行已映射的 SQL 语句//4.读取数据库连接SqlSession sqlSession = sqlSessionFactory.openSession();//5.通过 namespace.id的方式确定要执行的SQL片段User user = sqlSession.selectOne("test.selectOne",10);System.out.println(user);//6.用完后必须关闭连接sqlSession.close();}
}

总结:

  • mybatis开发过程总结
  1. 编写mybatis-config.xml
  2. 编写mapper.xml
  3. 编程通过配置文件创建SqlSessionFactory
  4. 通过SqlSessionFactory获取SqlSession
  5. 通过SqlSession操作数据库:
    1. 如果执行添加、更新、删除需要调用SqlSession.commit()
  6. SqlSesion使用完成要关闭