首页 GIS基础理论 GIS按属性选择怎么选多个?SQL条件如何设?

GIS按属性选择怎么选多个?SQL条件如何设?

作者: GIS研习社 更新时间:2025-12-07 23:00:03 分类:GIS基础理论

“选了这个就不能选那个?”——属性选择的多条件困局

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

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公顷”的图斑。

  1. 打开属性表 → 点击“按属性选择”
  2. 构建表达式
    先选字段:"LAND_TYPE"
    再写条件:= '耕地' OR "LAND_TYPE" = '林地'
    接着加面积限制:AND "AREA_HA" > 1
    完整语句:
    ("LAND_TYPE" = '耕地' OR "LAND_TYPE" = '林地') AND "AREA_HA" > 1
  3. 点击“应用”,见证奇迹 —— 所有符合条件的图斑高亮显示,一键导出,效率提升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语句!

相关文章