省市县相关校验sql随笔

devtools/2024/9/25 8:37:18/

1.层级校验

要判断一个给定的省、市、区(县)名字是否符合正确的层级关系,假设你的表结构如下:

CREATE TABLE regions (id INT PRIMARY KEY,name VARCHAR(255),parent_id INT,  -- 指向上一级区域的id,例如市的parent_id指向省的id,区的parent_id指向市的idlevel VARCHAR(50)  -- 标记层级,可能的值:'province', 'city', 'district'
);

则可以这么写

SELECT CASE WHEN d.id IS NOT NULL AND c.id IS NOT NULL AND p.id IS NOT NULL AND d.parent_id = c.id AND c.parent_id = p.id THEN '符合层级关系'ELSE '不符合层级关系'END AS result
FROM regions d
JOIN  regions c ON d.parent_id = c.id AND c.level = 'city'
JOIN  regions p ON c.parent_id = p.id AND p.level = 'province'
WHERE d.name = '给定的区名' AND c.name = '给定的市名' AND p.name = '给定的省名' AND d.level = 'district';

查询逻辑

1.自联结:通过 parent_id 字段与同一表中的其他记录联结,以找到区、市、和省的正确层级关系。
2.联结条件:
        d.parent_id = c.id:区的 parent_id 应该等于市的 id。
        c.parent_id = p.id:市的 parent_id 应该等于省的 id。
    WHERE 子句:指定区、市、和省的名字和层级。

可能不走ELSE,可以把JOIN换成LEFT JOIN,通过将 c.regionName = 'xxx'p.regionName = 'xxx' 的条件放在 LEFT JOIN 中,可以避免 WHERE 子句排除掉非匹配的行,从而确保 ELSE 分支能被正确触发。

2.地址校验

查出产品地址是不含"西藏"的产品个数,假如有产品表:product,地址字段:addressName,

地址样例:专供(不含海南、西藏、北京)

给定的省名:西藏自治区

SELECTcount(1)
FROM  product pd
WHERE EXISTS(SELECTCASE  WHEN d.id IS NOT NULL AND c.id IS NOT NULL AND p.id IS NOT NULL  AND   d.parentId  = c.id AND c.parentId = p.id THEN '1' ELSE '0' END AS resultFROM  regions dJOIN  regions c ON d.parent_id = c.id AND c.level = 'city'JOIN  regions p ON c.parent_id = p.id AND p.level = 'province'WHEREd.level = 'district'AND d.regionName   LIKE CONCAT('%', '给定的区名', '%')AND c.regionName   LIKE CONCAT('%', '给定的市名', '%')AND p.regionName   LIKE CONCAT('%', '给定的省名', '%')AND pd.addressName LIKE CONCAT('%不含%', SUBSTRING('给定的省名', 1, 2), '%'))


http://www.ppmy.cn/devtools/111506.html

相关文章

Qt_自定义信号

目录 1、自定义信号的规定 2、创建自定义信号 3、带参数的信号与槽 4、一个信号连接多个槽 5、信号与槽的断开 结语 前言: 虽然Qt已经内置了大量的信号,并且这些信号能够满足大部分的开发场景,但是Qt仍然允许开发者自定义信号&#…

红队攻防文库文章集锦

0.红队攻防 1.红队实战 红队攻防之特殊场景上线cs和msf CVE-2021-42287&CVE-2021-42278 域内提权 红队攻防之Goby反杀 红队攻防实战之钉钉RCE 红队攻防实战之从边界突破到漫游内网(无cs和msf) 红队攻防实战系列一之Cobalt Strike 红队攻防实战系列一之metasploit …

从C语言过渡到C++

📔个人主页📚:秋邱-CSDN博客☀️专属专栏✨:C 🏅往期回顾🏆:单链表实现:从理论到代码-CSDN博客🌟其他专栏🌟:C语言_秋邱的博客-CSDN博客 目录 ​…

挖耳勺可以伸进耳朵多深?安全可视挖耳勺推荐!

一般来说,挖耳勺不应该伸进耳朵太深,外耳道的长度大约在2.5厘米到3.5厘米之间,但不建议将挖耳勺伸进超过外耳道外1/3的深度,也就是大概1厘米左右较为安全。因为如果伸得太深,很容易损伤外耳道皮肤,引起疼痛…

项目中遇到的问题

1、文件上传 背景: 项目基于jquery,文件列表中有文件上传功能,点击上传按钮,弹出模态框,在模态框的形式选择文件,进行上传。 遇到的问题: 关闭模态框,无法查看文件上传的进度切换…

vue3 element plus table 滚动到指定位置

一. 需求 页面表格数据加载完成之后 计算一下需要滚动的高度 表格自动滚动 二. code 1. 给table加上ref <el-table ref"tableRef" :data"tableData">...</el-table> 2. 使用nextTick在表格渲染完之后计算高度滚动 import { ref, nextT…

百度大模型构建智能问答系统技术实践

背景 随着大模型的飞速发展&#xff0c; AI 技术开始在更多场景中普及。在数据库运维领域&#xff0c;我们的目标是将专家系统和 AI 原生技术相融合&#xff0c;帮助数据库运维工程师高效获取数据库知识&#xff0c;并做出快速准确的运维决策。 传统的运维知识库系统主要采用…

【React】Vite 构建 React

项目搭建 vite 官网&#xff1a;Vite 跟着文档走即可&#xff0c;选择 react &#xff0c;然后 ts swc。 着重说一下 package-lock.json 这个文件有两个作用&#xff1a; 锁版本号&#xff08;保证项目在不同人手里安装的依赖都是相同的&#xff0c;解决版本冲突的问题&am…