IDEA XML文件里写SQL比较大小条件

背景

最近开发的时候,有一个需求的查询需要支持范围查询[a,b),并且查询的结果要求查询的范围含头端点不含尾端点。因为between...and...查询的范围是含头含尾的,因而不能使用。

因此打算直接使用>=和<来比较实现,使用>=的时候没有什么问题,结果在使用<的时候发现IDEA在报错。

查了一下发现是XML文件没法区分<是小于号还是一个标签的开始。

解决方案

以在用户表查询用户年龄范围为例子。

方案一

这种语法冲突的,一般情况下都可以利用转义字符来实现,这里也有类似的用法。

转移字符 实际含义
&lt; <
&gt; >

可以写作如下:

SELECT * FROM user WHEREage &gt;= a AND age &lt; b

方案二

当然还可以使用 <![CDATA[ SQL语句 ]]>语法来实现,在CDATA标签中间的SQL会被单纯当成SQL

例子:

<![CDATA[ SELECT * FROM user WHERE age >= a AND age < b ]]>

方案三

可以继续使用between a and b,不过需要加多一个条件,xxx != b

例子:

SELECT * FROM user WHERE age BETWEEN a AND b AND age != b

方案四

可以把需要用到<的地方都转换成使用>

例子:

SELECT * FROM user WHERE age >= a AND b > age

相关推荐
TDengine (老段)4 小时前
TDengine 一条 SQL 从客户端到执行完成的全链路
大数据·数据库·sql·物联网·时序数据库·tdengine·涛思数据
唐青枫6 小时前
别只会写 IF:MySQL CASE WHEN 条件判断实战详解
sql·mysql
升鲜宝供应链及收银系统源代码服务7 小时前
升鲜宝供应链管理系统box_周转物功能设计模块详细开发文档(一)---升鲜宝生鲜配送供应链管理系统源代码服务
java·intellij-idea·生鲜配送源代码·升鲜宝生鲜配送源代码·后端app与手机端·b2b订货商城·客户订货系统源代码
zhishijike8 小时前
全国行政区划sql(省市区)
数据库·sql·mysql
阳光九叶草LXGZXJ9 小时前
达梦数据库-学习-52-DmDrs参数介绍(Manager模块)
linux·运维·数据库·sql·学习
网管NO.110 小时前
SQL 是什么?
数据库·sql
Chase_______12 小时前
【Java基础核心知识点全解·第0篇】Java开发环境搭建指南:JDK + IDEA 从安装配置到运行 HelloWorld
java·开发语言·intellij-idea
蜡台12 小时前
IDEA 编辑器两个竖线显示位置
java·编辑器·intellij-idea
丑八怪大丑12 小时前
XML_Tomcat_HTTP
xml·http·tomcat
码上有光12 小时前
MySQL基础操作——约束(下)——期末快速复习
数据库·sql·mysql·期末快速复习