【DBAPI教程】DBAPI如何使用复杂多层嵌套JSON作为请求参数

news2025/1/12 23:29:59

DBAPI如何使用复杂多层嵌套JSON作为请求参数

DBAPI作为一款后端低代码接口快速开发工具,不仅能实现简单的字段传参给SQL,也可以实现复杂的JSON传参。下面我们就来看一个实际的例子。

背景需求

  • 假设我们现在MySql有一张GDP表,内容如下:

在这里插入图片描述

  • 我们的请求参数格式是这样的:
{
    "province": {
        "name": "广东",
        "cities": [{
                "name": "深圳",
                "code": "518000"
            }, {
                "name": "广州",
                "code": "510000"
            }
        ]
    }
}
  • 这是一个复杂的嵌套的JSON,那如何才能把参数中的两个城市深圳和广州取出来,作为参数传递给SQL呢?
  • 先定一个目标:查询参数中的城市的GDP。接下来开始操作。

实操

  • 第1步,创建数据源,将mysql账户地址填上并创建

图片

  • 第2步,创建一个分组

在这里插入图片描述

  • 第3步,在分组上创建API

在这里插入图片描述

注意在基本信息的Content Type中一定要选择application/json,然后将json参数填入其中。

在这里插入图片描述

在执行器中选择刚才创建的数据源,并填写sql,注意sql中的参数我们这样获取:

 #{province.cities[0].name}   #{province.cities[1].name}

在这里插入图片描述

  • 保存并发布API

验证

  • 最后我们来验证数据,我们来到请求测试页面,点击发送请求,可以看到查询到了深圳和广州的数据。完成!

图片

  • 是不是很方便呢

解释

  • json取值就是通过“.”符号来取字段值,如果是数组类型,可以用“[下标]”的方式来取出对应的元素。

扩展

  • 有同学又问了,如果json参数中的cities数组不是2个元素,是3个元素怎么办呢?那SQL不就只能接收2个参数了吗?能否根据参数数组中的个数自动接收参数呢?

  • 当然可以!那就要用到类似Mybatis的动态SQL语法了!我们修改API,修改SQL为以下内容,然后保存并发布API。

select * from gdp where city in 
<foreach open="(" close=")" collection="province.cities" separator="," item="city" index="index">
#{city.name}
</foreach>

图片

  • 接下来修改参数为3个城市,发送请求,可以看到查询结果正确!

在这里插入图片描述

  • 那么这一段动态SQL如何解释呢

  • collection="province.cities" 表示将province.cities取出来,它是一个数组,对这个数组进行循环遍历

  • item="city"表示循环遍历的时候对每个元素进行命名为city

  • 所以最后取值的时候用#{city.name}来取值

  • 不熟悉的同学可以学习下mybatis动态SQL语法喔!

总结

  • 作为一款API低代码快速开发工具,DBAPI是不是很方便呢?
  • 欢迎关注DBAPI微信公众号以及官网地址https://www.51dbapi.com

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1016887.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

代码随想录 -- day52 --300.最长递增子序列 、674. 最长连续递增序列 、718. 最长重复子数组

300.最长递增子序列 dp[i]表示i之前包括i的以nums[i]结尾的最长递增子序列的长度 if (nums[i] > nums[j]) dp[i] max(dp[i], dp[j] 1); 每一个i&#xff0c;对应的dp[i]&#xff08;即最长递增子序列&#xff09;起始大小至少都是1. class Solution { public:int lengt…

Godot使用C#语言编写脚本(使用VSCode作为外部编辑器)

文章目录 Godot部分查看VSCode的所在位置配置外部编辑器 配置VSCode编写脚本中文注释 其他文章字符编码 Godot部分 打开编辑器-编辑器设置&#xff1b; 查看VSCode的所在位置 右键单击你的VScode快捷方式&#xff0c;选择属性。 这里的目标就是你的VSCode所在的位置。 配…

初识Java 9-2 内部类

目录 为什么需要内部类 闭包和回调 内部类和控制框架 继承内部类 内部类的重写&#xff08;并不能&#xff09; 局部内部类 内部类标识符 本笔记参考自&#xff1a; 《On Java 中文版》 为什么需要内部类 在一些情况下&#xff0c;我们无法享受接口带来的便利&#xff0…

差分方程模型:国民总收入(GDP)的乘数-加速数模型

【背景知识-凯恩斯经济增长模型】 凯恩斯(John M.Keynes)建立了著名的国民经济增长模型。令Y表示国民总收入&#xff0c;C表示总消费&#xff0c;E为总支出&#xff0c;I表示投资&#xff0c;G为政府的投入&#xff08;如基建等&#xff09;。那么有 【6.1】 其中&#xff0…

黑马JVM总结(十一)

&#xff08;1&#xff09;垃圾回收概述 前面我们学了堆&#xff0c;里面有一个垃圾回收的机制 &#xff08;2&#xff09;判断垃圾_引用计数 指只要有一个对象被其他变量所引用&#xff0c;我们就让这个对象的计数加1&#xff0c;有个一变量不在引用&#xff0c;让它的计数…

Leetcode—— 1. 两数之和

题目 给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是&#xff0c;数组中同一个元素在答案里不能重复出现。 你可以按任意顺…

代码随想录训练营第四十八天|198.打家劫舍 ● 213.打家劫舍II ● 337.打家劫舍III

198.打家劫舍 力扣题目链接(opens new window) 你是一个专业的小偷&#xff0c;计划偷窃沿街的房屋。每间房内都藏有一定的现金&#xff0c;影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统&#xff0c;如果两间相邻的房屋在同一晚上被小偷闯入&#xff0c;系…

Zookeeper 源码分析流程

文章目录 前言Zookeeper启动加载磁盘数据与客户端的通信交互Leader选举准备节点状态处理总结 前言 Zookeeper 作为分布式协调服务为分布式系统提供了一些基础服务&#xff0c;如&#xff1a;命名服务、配置管理、同步等&#xff0c;使得开发者可以更加轻松地处理分布式问题。 …

Java 基于 SPringBoot 的幼儿园管理系统,附源码、数据库

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝30W,Csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 文章目录 一、效果演示二、前言介绍三、主要技术四、系统设计&#xff08;部分&#xff09;4.1、主要功能模…

ipv6笔记及总结

1、路由器请求消息Router Solicitation和路由器通告Router Advertisement消息主要用于无状态地址的情况下&#xff0c;有状态的情况使用的是dhcpv6 server分配&#xff08;例如&#xff1a;IPv6地址以及其他信息&#xff08;DNS、域名等&#xff09;&#xff09;。 2、关于IPv…

腾讯mini项目-【指标监控服务重构】2023-08-16

今日已办 v1 验证 StageHandler 在处理消息时是否为单例&#xff0c;【错误尝试】 type StageHandler struct { }func (s StageHandler) Middleware1(h message.HandlerFunc) message.HandlerFunc {return func(msg *message.Message) ([]*message.Message, error) {log.Log…

安全线程的集合

1. CopyOnWriteArrayList package com.kuang.unsafe;import java.util.*; import java.util.concurrent.CopyOnWriteArrayList;//java.util.ConcurrentModificationException 并发修改异常&#xff01; 因为List集合线程不安全&#xff01; public class ListTest {public st…

Linux —— 线程

一&#xff0c;线程概念 在一程序内&#xff0c;一个执行路线称为线程thread&#xff0c;即线程是一个进程内部的控制序列&#xff1b; 一切进程至少都有一个执行线程&#xff1b;线程在进程内部运行&#xff0c;本质是在进程地址空间内运行&#xff1b;在Linux系统中&#xf…

许可分析 license分析 第十七章

许可分析是指对软件许可证进行详细的分析和评估&#xff0c;以了解组织内部对软件许可的需求和使用情况。通过许可分析&#xff0c;可以帮助组织更好地管理和优化软件许可证的使用。以下是一些可能的许可分析方法和步骤&#xff1a; 软件许可证的云化管理&#xff1a;将许可证管…

如何删除清理Mac“其他”文件并删除它

当我们通过「关于本机」>「存储空间」查看硬盘的空间占用情况时。系统会将存储空间根据不同文件类别所占的空间大小显示在条状图上&#xff0c;大部分类型看文字都比较好理解&#xff0c;但对于“其他”这一类很多小伙伴都感觉很困惑&#xff0c;会产生一些问题如&#xff1…

Mac FoneLab for Mac:轻松恢复iOS数据,专业工具助力生活

如果你曾经不小心删除了重要的iOS数据&#xff0c;或者因为各种原因丢失了这些数据&#xff0c;那么你一定知道这种痛苦。现在&#xff0c;有一个名为Mac FoneLab的Mac应用程序&#xff0c;它专门设计用于恢复iOS数据&#xff0c;这可能是你的救星。 Mac FoneLab for Mac是一种…

MySQL数据库详解 二:数据库的高级语言和操作

文章目录 1. 克隆表 ---- 将数据表的数据记录生成到新的表中1.1 方式一&#xff1a;先创建新表&#xff0c;再导入数据1.2方式二&#xff1a;创建的时候同时导入 2. 清空表 ---- 删除表内的所有数据2.1 delete删除2.2 truncate删除&#xff08;重新记录&#xff09;2.3 创建临时…

基于Java+SpringBoot+Vue的大学生线上心理咨询系统(可随意更改项目主题如医院预约、店铺预约、专家挂号、在线咨询等)

大学生线上心理咨询室系统 一、前言二、我的优势2.1 自己的网站2.2 自己的小程序&#xff08;小蔡coding&#xff09;2.3 有保障的售后2.4 福利 三、开发环境与技术3.1 MySQL数据库3.2 Vue前端技术3.3 Spring Boot框架3.4 微信小程序 四、功能设计4.1 主要功能描述 五、系统实现…

确认过眼神,你就是我心中的【理想型】API!

API作为开发者友好的Friend凭借信息直达、灵活便捷、简单高效的特点&#xff0c;成为了商户绝佳的“资源连接利器”&#xff0c;也是跨境支付过程的“基石堡垒”&#xff0c;通过以上全面的释义&#xff0c;你清晰了解API的作用了吗&#xff1f; 但API与全球电子商户的相遇过程…

《ADS2011射频电路设计与仿真实例》第一章—第六章用ads2017跟做的不同操作

我用的是ads2017&#xff0c;可能是因为版本原因&#xff0c;有些操作和书上的不一样 1.P69 Smith chart utility中&#xff0c;若要调节各曲线圆系的线条颜色&#xff0c;书上写的“执行菜单命令【circles】→【colors】”应该是【view】→【colors】 2.P83 要用微带线&…