【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)

x33g5p2x  于2022-04-02 转载在 其他  
字(7.9k)|赞(0)|评价(0)|浏览(706)

大家好,我是【1+1=王】, 热爱java的计算机(人工智能)渣硕研究生在读。
如果你也对java、人工智能等技术感兴趣,欢迎关注,抱团交流进大厂!!!
Good better best, never let it rest, until good is better, and better best.

近期会重新温习一下SSM的相关知识,相应的博客会更新至专栏【SSM框架】中,欢迎大家关注!
SSM专栏:https://blog.csdn.net/weixin_43598687/category_11652306.html

准备工作

1. 创建user表

2. 创建User实体类

  1. public class User {
  2. private Integer id;
  3. private String username;
  4. private String password;
  5. public User() {
  6. }
  7. public User(String username, String password) {
  8. this.username = username;
  9. this.password = password;
  10. }
  11. public User(Integer id, String username, String password) {
  12. this.id = id;
  13. this.username = username;
  14. this.password = password;
  15. }
  16. public Integer getId() {
  17. return id;
  18. }
  19. public void setId(Integer id) {
  20. this.id = id;
  21. }
  22. public String getUsername() {
  23. return username;
  24. }
  25. public void setUsername(String username) {
  26. this.username = username;
  27. }
  28. public String getPassword() {
  29. return password;
  30. }
  31. public void setPassword(String password) {
  32. this.password = password;
  33. }
  34. @Override
  35. public String toString() {
  36. return "User{" +
  37. "id=" + id +
  38. ", username='" + username + '\'' +
  39. ", password='" + password + '\'' +
  40. '}';
  41. }
  42. }

3. 引入mysql驱动

  1. <dependency>
  2. <groupId>mysql</groupId>
  3. <artifactId>mysql-connector-java</artifactId>
  4. <version>5.1.6</version>
  5. </dependency>

原始JDBC操作

查询

  1. public static List<User> findAll() throws Exception {
  2. Class.forName("com.mysql.jdbc.Driver");
  3. Connection conn = DriverManager.getConnection("jdbc:mysql:///test", "root", "123456");
  4. String sql = "select * from user";
  5. PreparedStatement pstmt = conn.prepareStatement(sql);
  6. ResultSet rs = pstmt.executeQuery();
  7. List<User> userList = new ArrayList<User>();
  8. while(rs.next()){
  9. User user = new User();
  10. user.setId(rs.getInt("id"));
  11. user.setUsername(rs.getString("username"));
  12. user.setPassword(rs.getString("password"));
  13. userList.add(user);
  14. }
  15. rs.close();
  16. pstmt.close();
  17. conn.close();
  18. return userList;
  19. }

插入

  1. public static void insertUser(User user) throws Exception{
  2. Class.forName("com.mysql.jdbc.Driver");
  3. Connection conn = DriverManager.getConnection("jdbc:mysql:///test", "root", "123456");
  4. String sql = "insert into user(id,username,password) values(?,?,?)";
  5. PreparedStatement pstmt = conn.prepareStatement(sql);
  6. pstmt.setInt(1,user.getId());
  7. pstmt.setString(2,user.getUsername());
  8. pstmt.setString(3,user.getPassword());
  9. int i = pstmt.executeUpdate();
  10. System.out.println(i);
  11. pstmt.close();
  12. conn.close();
  13. }

mybatis简介与开发步骤

  • mybatis是一个优秀的基于java的持久层框架,它内部封装了jdbc,使开发者只需要关注sql语句本身,而不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。
  • mybatis通过xml或注解的方式将要执行的各种statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的sql语句。
  • 最后mybatis框架执行sql并将结果映射为java对象并返回。采用ORM思想解决了实体和数据库映射的问题,对jdbc进行了封装,屏蔽了jdbcapi底层访问细节,使我们不用与jdbcapi打交道,就可以完成对数据库的持久化操作。

MyBatis官网地址:http://www.mybatis.org/mybatis-3/

1. 引入mybatis依赖包

  1. <dependency>
  2. <groupId>org.mybatis</groupId>
  3. <artifactId>mybatis</artifactId>
  4. <version>3.4.5</version>
  5. </dependency>

2. 创建表和对应实体类

同上。

3. 编写映射文件UserMapper.xml

在resources目录下创建文件com/wang/mapper/UserMapper.xml。路径与实体类的包路径对应

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper
  3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <mapper namespace="userMapper">
  6. <select id="findAll" resultType="com.wang.pojo.User">
  7. select * from user
  8. </select>
  9. </mapper>

4. 配置mybatis核心配置文件

在resources目录下创建文件sqlMapConfig.xml. 并添加相应配置

  1. <configuration>
  2. <environments default="development">
  3. <environment id="development">
  4. <transactionManager type="JDBC"/>
  5. <dataSource type="POOLED">
  6. <property name="driver" value="com.mysql.jdbc.Driver"/>
  7. <property name="url" value="jdbc:mysql:///test"/>
  8. <property name="username" value="root"/>
  9. <property name="password" value="123456"/>
  10. </dataSource>
  11. </environment>
  12. </environments>
  13. <mappers>
  14. <!-- 映射文件所在位置-->
  15. <mapper resource="com/wang/mapper/UserMapper.xml"/>
  16. </mappers>
  17. </configuration>

测试

  1. public static void main(String[] args) throws IOException {
  2. //加载核心配置文件
  3. InputStream inputStream = Resources.getResourceAsStream("sqlMapConfig.xml");
  4. //获得sqlSession工厂对象
  5. SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
  6. //获得sqlSession对象
  7. SqlSession session = sqlSessionFactory.openSession();
  8. //执行sql语句
  9. List<User> userList = session.selectList("userMapper.findAll");
  10. Iterator<User> iterator = userList.iterator();
  11. while(iterator.hasNext()){
  12. System.out.println(iterator.next());
  13. }
  14. session.close();
  15. }

mybatis的增删改查

插入操作

  1. 映射文件加入
  1. <insert id="add" parameterType="com.wang.pojo.User">
  2. insert into user(id,username,password) values(#{id},#{username},#{password})
  3. </insert>
  1. 测试
  1. @Test
  2. public void add() throws Exception{
  3. //加载核心配置文件
  4. InputStream inputStream = Resources.getResourceAsStream("sqlMapConfig.xml");
  5. //获得sqlSession工厂对象
  6. SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
  7. //获得sqlSession对象
  8. SqlSession session = sqlSessionFactory.openSession();
  9. //执行sql语句
  10. int insert = session.insert("userMapper.add",new User("Curry","30303030"));
  11. System.out.println(insert);
  12. session.commit();
  13. session.close();
  14. }

3. 注意

  • 插入语句使用insert标签
  • 在映射文件中使用parameterType属性指定要插入的数据类型
  • Sql语句中使用#{实体属性名}方式引用实体中的属性值
  • 插入操作使用的API是sqlSession.insert(“命名空间.id”,实体对象);
  • 插入操作涉及数据库数据变化,所以要使用sqlSession对象显示的提交事务,即sqlSession.commit()

删除操作

  1. 映射文件加入
  1. <delete id="delete" parameterType="java.lang.Integer">
  2. delete from user where id=#{id}
  3. </delete>
  1. 测试
  1. @Test
  2. public void delete() throws Exception{
  3. //加载核心配置文件
  4. InputStream inputStream = Resources.getResourceAsStream("sqlMapConfig.xml");
  5. //获得sqlSession工厂对象
  6. SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
  7. //获得sqlSession对象
  8. SqlSession session = sqlSessionFactory.openSession();
  9. //执行sql语句
  10. int delete = session.delete("userMapper.delete",1); //删除id=1的user
  11. System.out.println(delete);
  12. session.commit();
  13. session.close();
  14. }

3. 注意

  • 删除语句使用delete标签
  • Sql语句中使用#{任意字符串}方式引用传递的单个参数
  • 删除操作使用的API是sqlSession.delete(“命名空间.id”,Object);

修改操作

  1. 映射文件加入
  1. <update id="update" parameterType="com.wang.pojo.User">
  2. update user set username=#{username},password=#{password} where id=#{id}
  3. </update>
  1. 测试
  1. @Test
  2. public void update() throws Exception{
  3. //加载核心配置文件
  4. InputStream inputStream = Resources.getResourceAsStream("sqlMapConfig.xml");
  5. //获得sqlSession工厂对象
  6. SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
  7. //获得sqlSession对象
  8. SqlSession session = sqlSessionFactory.openSession();
  9. //执行sql语句
  10. int update = session.update("userMapper.update",new User(2,"科比","24-8")); //删除id=2的user
  11. System.out.println(update);
  12. session.commit();
  13. session.close();
  14. }

3. 注意

  • 修改语句使用update标签
  • 修改操作使用的API是sqlSession.update(“命名空间.id”,实体对象);

查询操作

见上述开发步骤,这里不再重复。

核心配置文件常用标签

1. environments标签


事务管理类型有两种

  1. JDBC:使用了JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。
  2. MANAGED:这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如JEE 应用服务器的上下文)。默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将closeConnection属性设置为false 来阻止它默认的关闭行为。

数据源类型有三种:

  1. UNPOOLED:这个数据源的实现只是每次被请求时打开和关闭连接。
  2. POOLED:这种数据源的实现利用“池”的概念将JDBC 连接对象组织起来。
  3. JNDI:这个数据源的实现是为了能在如EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个JNDI 上下文的引用。

2. mapper标签
mapper标签用于加载映射文件。
加载方式有如下几种:

  • 使用相对于类路径的资源引用,例如:<mapper resource="com/wang/mapper/UserMapper.xml"/>
  • 使用完全限定资源定位符(URL),例如:<mapper url="file:///mapper/UserMapper.xml"/>
  • 使用映射器接口实现类的完全限定类名,例如:<mapper class="com.wang.mapper.UserMapper"/>
  • 将包内的映射器接口实现全部注册为映射器,例如:<package name="com.wang.mapper"/>

3. properties标签
properties标签加载额外配置的properties文件,例如将数据源的配置信息单独抽取成一个properties文件。

4. typeAliases标签
在映射文件中为SQL参数类型或者返回类型的时候,需要配置全包名,这就比较烦人。

这是就可以使用typeAliases标签,为Java 类型设置一个短的名字。

  1. <typeAliases>
  2. <typeAlias type="com.wang.pojo.User" alias="user"/>
  3. </typeAliases>


mybatis框架已经为我们设置好的一些常用的类型的别名

SSM专栏:https://blog.csdn.net/weixin_43598687/category_11652306.html

相关文章