SQL SELECT 查询给定列的行数据中的多个值和范围。
问题描述:
服务器:MySQL
数据库:Customer
表:Lan
列:(Allowed VLAN
在 1-4096 范围内)
一行在列中有如下数据Allowed VLAN
:
180,181,200,250-499,550-811,826-mismatched
我需要一个SELECT
声明WHERE
,该列Allowed VLAN
包括一个给定的数字,例如'600'
。给定的数字'600'
甚至是逗号分隔值之一或包含在“250-499”、“550-811”的任何范围内,或者它只是“826-mismatched”范围的起始数字值。
SELECT * WHERE `Allowed VLAN`='600' OR `Allowed VLAN` LIKE '%600%' OR (`Allowed VLAN` BETWEEN '1-1' AND '1-4096');
我无法弄清楚如何使用 WHERE 子句处理数据范围。我已经使用explode() 拆分函数等解决了PHP 代码的问题,但我认为有一些SQL SELECT 解决方案。
我将不胜感激任何帮助。