GIS按属性选择怎么选多个?SQL条件如何设?
“选了这个就不能选那个?”——属性选择的多条件困局
上周一位在国土规划院实习的研究生私信我:“Dr. Gis,我在做村庄用地分类统计,想同时选出‘耕地’和‘林地’,但每次只能选一个,导出两次太麻烦了,有没有办法一次搞定?”这问题太典型了——不是软件不会,而是你没搞懂SQL的“逻辑语法糖”。

我在参与全国生态红线划定项目时,曾需要从百万级图斑中筛选“坡度>25°且土地类型为林地或草地”的区域。如果只会单选,那工作量简直能让人崩溃到辞职。
SQL不是外语,是“地理侦探”的推理语言
很多人把SQL当成编程语言,其实它更像侦探破案时的“线索串联术”。你想找“A或B”,就用 OR;想找“A且B”,就用 AND;想排除干扰项,就用 NOT。就这么简单。
举个生活化例子:假设你要去超市买水果,老板问你要什么?你说:“我要苹果或者梨子,但不要烂的。”翻译成SQL就是:
"水果类型" = '苹果' OR "水果类型" = '梨子' AND "状态" != '烂'注意!这里有个坑——AND优先级高于OR,所以上面这句话实际执行的是:“(苹果)或(梨子且非烂)”,可能漏掉“烂苹果”。正确写法应该加括号:
("水果类型" = '苹果' OR "水果类型" = '梨子') AND "状态" != '烂'实战演练:三步写出无bug的多条件SQL
我们以ArcGIS Pro为例(QGIS同理),目标:选出“用地类型为耕地或林地,且面积大于1公顷”的图斑。
- 打开属性表 → 点击“按属性选择”
- 构建表达式:
先选字段:"LAND_TYPE"
再写条件:= '耕地' OR "LAND_TYPE" = '林地'
接着加面积限制:AND "AREA_HA" > 1
完整语句:("LAND_TYPE" = '耕地' OR "LAND_TYPE" = '林地') AND "AREA_HA" > 1 - 点击“应用”,见证奇迹 —— 所有符合条件的图斑高亮显示,一键导出,效率提升10倍。
高级技巧:IN、LIKE、通配符让选择更聪明
如果你要选的类别超过3个(比如耕地、林地、草地、湿地),一个个写OR太啰嗦。这时候请祭出神器:IN。
"LAND_TYPE" IN ('耕地', '林地', '草地', '湿地')想模糊匹配?比如所有带“林”字的地类(乔木林、灌木林、经济林…),用 LIKE + 通配符 %:
"LAND_TYPE" LIKE '%林%'这些技巧在处理民政区划、POI分类、遥感解译标签时特别实用。
避坑指南:90%的人栽在这三个地方
| 错误类型 | 错误示例 | 正确写法 |
|---|---|---|
| 字段名没加引号 | LAND_TYPE = '耕地' | "LAND_TYPE" = '耕地' |
| 字符串没加单引号 | "LAND_TYPE" = 耕地 | "LAND_TYPE" = '耕地' |
| 逻辑优先级混乱 | A OR B AND C | (A OR B) AND C |
总结:从“点选菜鸟”到“批量高手”的跃迁
按属性选择多个要素,本质是掌握SQL的三种核心逻辑:AND(交集)、OR(并集)、IN/LIKE(模糊与枚举)。再加上括号控制优先级,你就能在百万数据中精准狙击目标。
下次遇到复杂筛选需求,别再手动Ctrl+Click了。打开SQL编辑器,写一行代码,让计算机替你打工。
你在项目中遇到过哪些“奇葩”的属性筛选需求?欢迎在评论区留言,我会挑三个最有代表性的,手把手帮你写出完美SQL语句!
相关文章
-
GIS属性表怎么按属性选择?查询语句怎么写? 2025-12-07 22:00:03
-
GIS属性表怎么导出Excel?转换工具在哪找? 2025-12-07 21:00:03
-
GIS是什么地理技术?核心概念怎么理解? 2025-12-07 20:00:03
-
GIS系统的主要用途有哪些?具体应用在哪? 2025-12-07 19:00:03
-
GIS和GPS有什么区别?核心功能各是什么? 2025-12-07 18:00:03
-
GIS开发工程师怎么学?WebGIS是必修课吗? 2025-12-07 17:00:03
-
SuperMap与GRASS GIS对比?开源与商业怎么选? 2025-12-07 16:00:03
-
GIS在水文分析中的应用:基于DEM的流域提取与河网生成 2025-12-07 15:00:03
-
GIS在网络分析中的应用:设施选址(Location-Allocation)模型 2025-12-07 14:00:03
-
GIS在适宜性评价中的应用:层次分析法(AHP)与多因子叠加 2025-12-07 13:00:03
-
GIS在多维数据分析中的应用:时空立方体(Space Time Cube)构建 2025-12-07 12:00:03
-
GIS在空间模式分析中的应用:平均最近邻(Average Nearest Neighbor) 2025-12-07 11:00:03
-
GIS在空间分布分析中的应用:标准差椭圆(Standard Deviational Ellipse) 2025-12-07 10:00:03
-
GIS在地统计学中的应用:克里金插值(Kriging)详解 2025-12-07 09:00:03
-
GIS在空间回归分析中的应用:普通最小二乘法(OLS) 2025-12-07 08:00:03
-
GIS在空间统计学中的应用:地理探测器(Geodetector)原理与实践 2025-12-07 07:00:03
-
GIS在空间统计学中的应用:聚类与异常值分析(Anselin Local Moran's I) 2025-12-07 06:00:03
-
GIS在空间统计学中的应用:冷热点分析(Getis-Ord Gi*) 2025-12-07 05:00:03
-
GIS在空间统计学中的应用:空间自相关(Moran's I) 2025-12-07 04:00:03
-
QGIS样式文件怎么保存?SLD格式如何导出? 2025-12-07 03:00:03
热门标签
最新资讯
2025-12-07 14:00:03
2025-12-07 13:00:03
2025-12-07 12:00:03
2025-12-07 11:00:03
2025-12-07 10:00:03
2025-12-07 09:00:03
2025-12-07 08:00:03
2025-12-07 07:00:03
2025-12-07 06:00:03
2025-12-07 05:00:03