当前位置: 首页 > article >正文

[JAVA]用MyBatis框架实现一个简单的数据查询操作

基于在前面几章我们已经学习了对MyBatis进行环境配置,并利用SqlSessionFactory核心接口生成了sqlSession对象对数据库进行交互,执行增删改查操作。这里我们就先来学习如何对数据进行查询的操作,具体查询操作有以下几个步骤

  1. 创建实体类
  2. 创建Mapper XML
  3. 编写<select>SQL标签
  4. 开启驼峰命名映射
  5. 新增<mapper>
  6. SqlSession执行select语言

首先,我们需要有可供查询信息的数据表并被导入到我们IDEA开发工具中,这里我导入了一个有关奶粉售卖信息的商品表

 其中t-goods商品表内容如下

我们要做的操作是按照商品编号从大到小倒序排列,并且将结果的前十条提取出来 步骤演示:

第一步.创建实体类

创建一个com.mybatis.entity.Goods包,创建命名为Goods代表商品的类,内容如下:

public class Goods{
   private Integer goodsId;//商品编号
   private String title;//标题
   private String subTitle;//子标题
   private Float originalCost;//原始价格
   private Float currentPrice;//当前价格
   private Float discount;//折扣率
   private Integer isFreeDelivery;//是否包邮,1-包邮 0-不包邮
   private Integer categoryId;//分类编号
}

然后选中以上代码块快捷键Alt+Insert生成getter/setter方法

public Integer getGoodsId() {
        return goodsId;
    }

    public void setGoodsId(Integer goodsId) {
        this.goodsId = goodsId;
    }

    public String getTitle() {
        return title;
    }

    public void setTitle(String title) {
        this.title = title;
    }

    public String getSubTitle() {
        return subTitle;
    }

    public void setSubTitle(String subTitle) {
        this.subTitle = subTitle;
    }

    public Float getOriginalCost() {
        return originalCost;
    }

    public void setOriginalCost(Float originalCost) {
        this.originalCost = originalCost;
    }

    public Float getCurrentPrice() {
        return currentPrice;
    }

    public void setCurrentPrice(Float currentPrice) {
        this.currentPrice = currentPrice;
    }

    public Float getDiscount() {
        return discount;
    }

    public void setDiscount(Float discount) {
        this.discount = discount;
    }

    public Integer getIsFreeDelivery() {
        return isFreeDelivery;
    }

    public void setIsFreeDelivery(Integer isFreeDelivery) {
        this.isFreeDelivery = isFreeDelivery;
    }

    public Integer getCategoryId() {
        return categoryId;
    }

    public void setCategoryId(Integer categoryId) {
        this.categoryId = categoryId;
    }
}

第二步.创建Mapper XML文件

在resources目录下创建名为mappers的包,创建goods.xml文件,此文件用意是说明实体类与表之间的映射关系

第三步.编写<select>SQL标签

在goods.xml中声明  文件内容:

//xml标准声明部分
<?xml version="1.0" encoding ="UTF-8"?>

//Mybatis的DTD部分
<!DOCTYPE mapper
       PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
       "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

//MyBatis映射部分   namespace:命名空间
<mapper namespace="goods">
    <select id="selectAll" resultType="com.mybatis.entity.Goods">
       select * from t_goods order by goods_id desc limit 10
       //按照商品编号从大到小倒序排列,并且将结果的前十条提取出来 
    </select>
</mapper>

//resultType="com.mybatis.entity.Goods"指定了该查询操作执行后返回结果的类型,这里将返回的结果映射成com.mybatis.entity.Goods类型的对象

第四步.新增<mapper>

然后在mybatis-config.xml中对它声明

<mappers>
     <mapper resource="mappers/goods.xml"/>
</mappers>

第五步.开启驼峰命名映射

<settings>
   <!--goods_id ==> goodsId 驼峰命名转换 -->
   <setting name="mapUnderscoreToCamelCase" value="true"/>
</settings>

第六步.SqlSession执行select语言

打开MyBatisTestor测试用例类,执行goods类中书写的SQ语句,并且得到对应的结果

@Test
public void testSelectAll(){
   SqlSession session = null;
   try{
       session = MyBatisUtils.openSession();
       List<Goods> List = session.selectList("goods.selectALL");
       //打印表结果
       for(Goods  g: list){
           System.out.printin(g.getTitle());
   }
   }catch(Exception e){
       throw e;
   }finally{
        MyBatisUtils.closeSession(session);
   }
  

}

演示查询结果:


http://www.kler.cn/a/406146.html

相关文章:

  • 云服务器部署WebSocket项目
  • JDK、MAVEN与IDEA的安装与配置
  • reactflow 中 useStoreApi 模块作用
  • 卷积神经网络各层介绍
  • WEB攻防-通用漏洞SQL注入Tamper脚本Base64Jsonmd5等
  • 永磁同步电机无速度算法--滑模观测器(PLL)
  • go版本,google-authenticator动态口令算法,二次安全校验
  • Elasticsearch面试内容整理-分析与映射
  • wsl2中kali linux下的docker使用教程(教程总结)
  • 深入实践 Shell 脚本编程:高效自动化操作指南
  • 【通俗理解】ELBO(证据下界)——机器学习中的“情感纽带”
  • leetcode hot100【LeetCode 53.最大子数组和】java实现
  • 金融科技白皮书:2022-2023年度回顾与前瞻
  • 基于docker进行任意项目灵活发布
  • 如何使用 Python 开发一个简单的文本数据转换为 Excel 工具
  • Leetcode 每日一题 11. 盛最多水的容器
  • 贪心算法(1)
  • C# 中的事件和委托:构建响应式应用程序
  • vue2-代理服务器插槽
  • [OpenHarmony5.0][Docker][环境]OpenHarmony5.0 Docker编译环境镜像下载以及使用方式
  • 力扣 LeetCode 530. 二叉搜索树的最小绝对差(Day10:二叉树)
  • 观察者模式和订阅模式
  • 信创时代的数据库之路:2024 Top10 国产数据库迁移与同步指南
  • Excel表查找与引用函数、逻辑函数、财务函数
  • Claude3.5-Sonnet和GPT-4o怎么选(附使用链接)
  • m个数 生成n个数的所有组合 详解