Java编程:MyBatis读取数据库数据

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介: Java编程:MyBatis读取数据库数据

1、文件结构

20190119102215573.png

一共涉及3个文件夹8个文件,心累…

注意config文件夹和lib文件夹需要设置为资源文件夹,不然找不到文件

2、依赖下载

放入lib文件夹

mybatis: https://github.com/mybatis/mybatis-3/releases

mysql-connector: https://dev.mysql.com/downloads/connector/j/

3、数据准备

demo的数据库下有一个names的数据表,字段类型和数据如下

mysql> desc names;
+-------+--------------+------+-----+---------+----------------+
| Field | Type         | Null | Key | Default | Extra          |
+-------+--------------+------+-----+---------+----------------+
| id    | int(10)      | NO   | PRI | NULL    | auto_increment |
| name  | varchar(255) | YES  | UNI | NULL    |                |
| age   | int(10)      | YES  |     | NULL    |                |
+-------+--------------+------+-----+---------+----------------+
mysql> select * from names;
+----+--------+------+
| id | name   | age  |
+----+--------+------+
|  2 | 大红   |   27 |
|  3 | 大壮   |   24 |
|  4 | 秀英   |   25 |
+----+--------+------+

4、Person类编写

其实就是一个普通的java类

Person.class

public class Person {
    private Integer id;
    private  String name;
    private Integer age;
    public Integer getAge() {
        return age;
    }
    public void setAge(Integer age) {
        this.age = age;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String toString(){
        return "[Person] id: "+ id + " name: " + name + " age :"+ age;
    }
}

5、配置映射器

方式一 文件配置映射器:

映射接口 PersonMapper.class

public interface PersonMapper {
    public Person getPersonById(Integer id);
}

映射文件 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">
<!--
1.PersonMapper为命名空间,为映射接口的全类名
2.id为唯一标识,与PersonMapper接口中的对应方法名相同
3.resultType为查询后的返回类型
4.#{id}指从传递过来的参数中取出id值
-->
<mapper namespace="PersonMapper">
    <select id="getPersonById" resultType="Person">
    select id,name, age from names where id = #{id}
  </select>
</mapper>

方式二 注解配置映射器:

PersonMapperAnnoation.class

import org.apache.ibatis.annotations.Select;
public interface PersonMapperAnnoation {
        @Select("select id, name, age from names where id = #{id}")
        public Person getPersonById(Integer id);
}

这样看来,方式2更为简洁和清晰

6、数据库配置填入数据库的地址,账号,密码

配置映射器,可以使用两种方式resourceclass

<?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">
            <!-- 配置事务管理器,采用的是JDBC的管理器方式 -->
            <transactionManager type="JDBC"/>
            <!--  POOLED代表采用MyBatis内部提供的连接池方式 -->
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/demo"/>
                <property name="username" value="root"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>
    <!--  引入映射器 包名+文件名-->
    <mappers>
        <mapper resource="PersonMapper.xml"/>
        <mapper class="PersonMapperAnnoation"/>
    </mappers>
</configuration>

7、代码测试

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 java.io.IOException;
import java.io.InputStream;
public class mybatisDemo {
    public static void main(String[] args) throws IOException{
        //1.根据MyBatis的配置文件,即mybatis-config.xml创建SqlSessionFactory
        SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
        //2.获取session实例开启会话,其能直接执行*已经映射的SQL语句*
        SqlSession session = sqlSessionFactory.openSession();
        try {
          // 方式1 查询
            //3.获取接口的实现类对象
            PersonMapper personMapper = session.getMapper(PersonMapper.class);
            //4.执行查询操作
            Person person = personMapper.getPersonById(2);
            System.out.println(person);
      // 方式2 查询
            //3.获取接口的实现类对象
            PersonMapperAnnoation personMapperAnnoation = session.getMapper(PersonMapperAnnoation.class);
            //4.执行查询操作
            Person person1 = personMapperAnnoation.getPersonById(2);
            System.out.println(person1);
        } finally {
            //4.关闭会话session
            session.close();
        }
    }
    //根据MyBatis的配置文件,即mybatis-config.xml创建SqlSessionFactory
    public static SqlSessionFactory getSqlSessionFactory() throws IOException {
        String resource = "mybatis-config.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        return sqlSessionFactory;
    }
}
/*
两种方式都能查到数据
[Person] id: 2 name: 大红 age :27
[Person] id: 2 name: 大红 age :27
*/

参考

(二)MyBatis学习笔记-HelloWorld

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
4月前
|
SQL Java 数据库
解决Java Spring Boot应用中MyBatis-Plus查询问题的策略。
保持技能更新是侦探的重要素质。定期回顾最佳实践和新技术。比如,定期查看MyBatis-Plus的更新和社区的最佳做法,这样才能不断提升查询效率和性能。
186 1
|
9月前
|
安全 Java 数据库连接
Java使用MyBatis-Plus的OR
通过MyBatis-Plus的条件构造器,Java开发者可以方便地进行复杂的查询条件组合,包括AND和OR条件的灵活使用。熟练掌握这些技巧,可以显著提升开发效率和代码可读性。
320 20
|
SQL Java 关系型数据库
Java中的ORM框架——myBatis
Java中的ORM框架——myBatis
229 3
|
9月前
|
SQL Java 数据库连接
【潜意识Java】MyBatis中的动态SQL灵活、高效的数据库查询以及深度总结
本文详细介绍了MyBatis中的动态SQL功能,涵盖其背景、应用场景及实现方式。
923 6
|
9月前
|
SQL Java 数据库连接
【潜意识Java】深入理解MyBatis的Mapper层,以及让数据访问更高效的详细分析
深入理解MyBatis的Mapper层,以及让数据访问更高效的详细分析
1278 1
|
9月前
|
SQL Java 数据库连接
【潜意识Java】深入理解MyBatis,从基础到高级的深度细节应用
本文详细介绍了MyBatis,一个轻量级的Java持久化框架。内容涵盖MyBatis的基本概念、配置与环境搭建、基础操作(如创建实体类、Mapper接口及映射文件)以及CRUD操作的实现。此外,还深入探讨了高级特性,包括动态SQL和缓存机制。通过代码示例,帮助开发者更好地掌握MyBatis的使用技巧,提升数据库操作效率。总结部分强调了MyBatis的优势及其在实际开发中的应用价值。
225 1
|
9月前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
360 2
|
9月前
|
SQL Java 数据库连接
Java MyBatis 面试题
Java MyBatis相关基础面试题
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
524 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
12月前
|
搜索推荐 Java 数据库连接
Java|在 IDEA 里自动生成 MyBatis 模板代码
基于 MyBatis 开发的项目,新增数据库表以后,总是需要编写对应的 Entity、Mapper 和 Service 等等 Class 的代码,这些都是重复的工作,我们可以想一些办法来自动生成这些代码。
269 6