MySQL数据表key和value设计,怎么查询?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL数据表key和value设计,怎么查询?相关的知识,希望对你有一定的参考价值。

表字段 key 和 value

值: name web
num 2
num 5
num 10
num 3
name css

怎么查询 key字段 等于name,value字段 等于web,和 value字段 大于等于2 和 小于等于5

查询的SQL语句为:SELECT * FROM 数据表 WHERE key="name" AND value="Web" OR (value>=2 AND value<=5);。

SQL语句的含义:SELECT为查询语句,*表示显示数据表中所有的字段,FROM 后面跟的是查询的数据表,    WHERE后面跟的是查询的条件。

key=“name”表示查询表字段key等于name的行,AND为与操作,表示条件同时成立,value="Web" OR (value>=2 AND value<=5)表示查询value字段为Web或者字段值大于等于2小于等于5的行。

扩展资料:

mysql所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。

MySQL新特性:表和索引的分区、行级复制、MySQL 基群基于磁盘的数据支持、MySQL 集群复制、增强的全文本搜索函数、增强的信息模式(数据字典)、可插入的 API、服务器日志表

SQL SELECT 语法:

SELECT 列名称 FROM 表名称

注意:SQL 语句对大小写不敏感。SELECT 等效于 select。

星号(*)是选取所有列的快捷方式。

参考技术A

1、数据准备

drop table if exists test;

create table test(

id int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',

key_name varchar(32) not null default '' comment '名称',

key_value varchar(32) not null default '' comment '值',

num decimal(18,0) not null default 0 comment '变量值',

PRIMARY KEY (id) USING BTREE

);

insert into test(key_name,key_value,num)

values('name','web',2),('name','web',5),('name','web',10),('name','web',3),('name','css',0);

2、查询语句:

SELECT * FROM test 

WHERE key_name = 'name' 

AND key_value = 'web' 

AND num BETWEEN 2 AND 5;

MySQL.MyBatis怎么将查询的两个字段作为Map的key和value

MySQL.MyBatis怎么将查询的两个字段作为Map的key和value

问题的由来

前端使用Echarts图标显示汇总数据。需要形式如下的数据:


  "C20": 42.01,
  "C30": 1693.10,
  "C35": 231.00

但是经过以下的SQL查询

SELECT
	gsom.intensity_level AS  强度等级,
	SUM(gsom.quantity) AS  生产方量
FROM
	gt_szls_out_master gsom
WHERE org_id = '8100000000002334' AND dev_sn IN('00010001')
GROUP BY
	gsom.intensity_level

数据库查询出来的数据结果如下:

解决方案

其实观察一下前端需要的代码形式,我们只需要把SQL查询的结果中强度等级作为map的key生产方量作为map的value即可。

实现上面的方案有一下几种方法:

  • 1、可以将查询的结果在java代码中进行遍历,组装成相应的结构返回给前端
  • 2、使用注解+拦截器的方式直接返回符合条件的Map(后面会讲)
  • 3、就是我们本次要讲的实现方式:通过改造SQL以及处理返回结果

1、MapResultHandler.java

import org.apache.ibatis.session.ResultContext;
import org.apache.ibatis.session.ResultHandler;

import java.util.HashMap;
import java.util.Map;

/**
 * @Desc
 * @Creator Hardy
 * @Create_Date 2022/3/4 9:40
 * @Updater
 * @Update_Date
 **/
public class MapResultHandler implements ResultHandler<Map> 
    private final Map<String, String> mappedResults = new HashMap();

    @Override
    public void handleResult(ResultContext resultContext) 
        Map<String, String> m = (Map) resultContext.getResultObject();
        mappedResults.put(m.get("key"), m.get("value"));
    

    public Map getMappedResults() 
        return mappedResults;
    

2、xxxDao.java

void getMixingPlantProductionSummary(@Param("orgId") Long orgId, @Param("devSNs") String devSNs, MapResultHandler mapResultHandler);

3、Mybatis.xml

<resultMap id="mapResult" type="java.util.HashMap">
    <result property="key" column="name"/>
    <result property="value" column="count"/>
</resultMap>

<select id="getMixingPlantProductionSummary" resultMap="mapResult">
    SELECT
    gsom.intensity_level AS name,
    SUM(gsom.quantity) AS count
    FROM
    gt_szls_out_master gsom
    <where>
        <if test="orgId != null">
            and gsom.org_id = #orgId
        </if>

        <if test="devSNs != null">
            and gsom.dev_sn in (#devSNs)
        </if>
    </where>
    GROUP BY gsom.intensity_level
</select>

4、使用方式

MapResultHandler handler = new MapResultHandler();
xxxDao.getMixingPlantProductionSummary(orgId, devSNs, handler);
Map resultMap = handler.getMappedResults();

注意:

1、xxxDao.java中定义的接口返回值类型必须是void,如上面void getMixingPlantProductionSummary()

2、MyBatis.xml中定义的resultMap返回值类型是HashMap,其里面定义的两个result中的key要与MapResultHandler.java中代码mappedResults.put(m.get("key"), m.get("value"))保持一致;其value属性必须和Mybatis.xml中sql的返回值名称一致

3、Map resultMap = handler.getMappedResults();中的resultMap就是我们一开始讲到的前端需要的数据类型

以上是关于MySQL数据表key和value设计,怎么查询?的主要内容,如果未能解决你的问题,请参考以下文章

MySQL.MyBatis怎么将查询的两个字段作为Map的key和value

MySQL.MyBatis怎么将查询的两个字段作为Map的key和value

MySQL.MyBatis怎么将查询的两个字段作为Map的key和value

MySQL.MyBatis怎么将查询的两个字段作为Map的key和value

MySQL实战01の一条查询语句怎么执行的

Mysql查询json数据特定key的值