解决范围的重叠问题

20 篇文章 0 订阅

荆轲刺秦王

问题场景:数据表中有开始ID和结束ID字段,这两个ID表示一段范围,现在我需要在每次插入新数据的时候,

我都要判断插入的数据是否和原有数据(原有的两个字段范围)有重叠的现象,如果有重叠则提示用户数据

不合法。

假设$startID和$endID 是接收用户输入的值。

mysql : 需要两条查询语句

SELECT * FROM 'tableName' where "$startID between start_id and end_id"

SELECT * FROM 'tableName' where "$endID between start_id and end_id"

这两条语句就是查询用户输入的数据是否在已有数据中,如果查询出来的有结果,那就是重叠,提示用户数据不合法。

使用ThinkPHP写:

//检查是否重叠

$checkStartID = $this->db->where("$startID between start_id and end_id")->select();

//echo $this->db->getLastSql();

//print_r($checkStartID);exit();

if($checkStartID) $this->error('开始ID重复','',true);

$checkEndID = $this->db->where("$endID between start_id and end_id")->select();

//echo $this->db->getLastSql();

//print_r($checkStartID);exit();

if($checkEndID) $this->error('结束ID重复','',true);


在接收用户输入信息的时候,一定要进行过滤,因为用户可能会输入任何东西。

在检查这个开始ID和结束ID的时候,除了要验证是 int 类型的,还要判断是否开始ID小于结束ID,

如果ID是事先生成好的,那么还要判断用户输入的这两个ID是否存在




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值