weixin_42411605 2011-01-13 13:50
浏览 257
已采纳

关于mysql数据库memory表数据重复问题

PHP+MYSQL项目

要实现一个预约功能,我的实现方式是把当天的预约提取出来存入一个memory类型的表,一般情况下一千条左右数据。
然后每次访问时对这个表进行查询此时刻向前推五分钟内,有无未执行的预约之后执行。如执行成功则进行相应的标记。

每次查询前会检查是否有当天的数据,如果没有,则对表进行清空操作。然后从其他表把当天数据查询出来插入memory类型的表。

相关代码大概为:
[code="php"]
//查询今天的数据条数:
$forday = strtotime(date("Y-m-d", $timestamp));
$havefresh = $DB->result("SELECT COUNT(id) FROM ".tname('freshtmp')." WHERE forday = $forday");
if (empty($havefresh)) {
  //此条语句清空数据表
  $DB->query("TRUNCATE TABLE ".tname('freshtmp'));
//此处为从其他表查询出数据并组合成:$txt = (1,2,3,4),(1,2,3,4)......这样的格式
$DB->query("INSERT INTO ".tname('freshtmp')." (houseid, uid, freshtime, forday, fangan, addtime) VALUES $txt");//此处一般会一次性插入2000条左右的数据
} else {
//执行相应刷新操作
}
[/code]

我的问题是:
就上面这段代码,经常出现数据重复插入的情况,明明只有2000条数据,结果经常会出现表里成倍的插入数据,变成4000条或六千条。而且通过我记录的插入时间来看,几批数据多是相差一两秒。我分析可能是由于网站并发较大,第一次的语句没有执行成功时在间隔时间内另一个请求又执行了插入代码。
但又实在想不出好的解决办法,特来请教,万分感谢!

----区分下面的广告

  • 写回答

2条回答 默认 最新

  • xieye114 2011-01-14 09:10
    关注

    mysql有锁表语句的,你可以直接调用LOCK TABLES。

    具体看看手册吧

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥100 有人会搭建GPT-J-6B框架吗?有偿
  • ¥15 求差集那个函数有问题,有无佬可以解决
  • ¥15 【提问】基于Invest的水源涵养
  • ¥20 微信网友居然可以通过vx号找到我绑的手机号
  • ¥15 寻一个支付宝扫码远程授权登录的软件助手app
  • ¥15 解riccati方程组
  • ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
  • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
  • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
  • ¥50 树莓派安卓APK系统签名