- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图在 mysql 表“winners”上的获胜日期早于 1 天时使确认代码过期。我的 php 代码工作正常并将 confirmation_status 设置为 "expired",但是当有超过 1 行具有相同的 id_recharge_winner 时,脚本将所有这些行设置为 "expired"。我希望只有年长的人被排除在外。
请帮帮我
我的 table 上赢家是这样的:
|id_recharge_winner |confirmation_code |confirmation_status| date_confirmation |date_win|
-------------------------------------------------------------------------------------------
1 |8eomdv | not confirmed |NULL |2019-01-20 23:58:41
1 |ioozpu | not confirmed |NULL |2019-02-02 09:57:10
1 |cpq2vp | not confirmed |NULL |2019-01-26 01:05:18
2 |tnymsp | not confirmed |NULL |2019-02-02 01:09:54
2 |qh8lqq | not confirmed |NULL |2019-02-02 06:14:37
2 |jgg3xi | not confirmed |NULL |2019-01-26 01:22:40
3 |cukxc5 | expired |NULL |2019-01-26 01:33:11
4 |3ixoj4 | not confirmed |NULL |2019-01-26 01:43:42
5 |20bqrn | not confirmed |NULL |2019-01-26 11:18:16
6 |lebx61 | not confirmed |NULL |2019-02-02 12:40:27
6 |7tgoaz | not confirmed |NULL |2019-01-26 12:42:41
6 |kphs5k | not confirmed |NULL |2019-01-26 12:51:33
6 |6vxcy9 | not confirmed |NULL |2019-01-26 13:07:23
7 |sttyul | not confirmed |NULL |2019-01-26 13:11:47
我的 php:
for ($i=1;$i<=7;$i++){
//Verify if confirmation code is expired
$sql_expired = "SELECT id_recharge_winner, date_win, date_confirmation
FROM winners
WHERE id_recharge_winner ='$i'";
$result_expired = mysqli_query($conn, $sql_expired);
if (mysqli_num_rows($result_expired) > 0) {
while($row = mysqli_fetch_assoc($result_expired)){
$id_recharge_winner = $row['id_recharge_winner'];
$date_win = $row['date_win'];
$date_confirmation = $row['date_confirmation'];
$expiration_delay = 1; //One day
if ((time() - $date_win) >= $expiration_delay) {
$sql_set_expired = "UPDATE `winners`
SET `confirmation_status` = 'expired'
WHERE confirmation_status = 'not confirmed'
AND id_recharge_winner = '$id_recharge_winner'";
$set_expired_result = mysqli_query($conn, $sql_set_expired);
}
}
}
}
最佳答案
我怀疑您可以简单地通过选择/更新所有相关记录的单个查询来完成工作。
考虑:
UPDATE winners w
SET w.confirmation_status = 'expired'
WHERE
w.id_recharge_winner = ?
AND w.confirmation_status = 'not confirmed'
AND DATEDIFF(CURDATE(), w.date_win) > 1
AND NOT EXISTS (
SELECT 1
FROM winners w1
WHERE
w1.id_recharge_winner = w.id_recharge_winner
AND w1.confirmation_status = w.confirmation_status
AND w1.date_win < w.date_win
)
WHERE
子句应用相关过滤器;如果没有记录匹配,则不会发生 UPDATE
。该子句还包含一个 NOT EXITS
条件,该条件使用相关性来确保正在更新的记录(如果有)是最旧的记录(即没有更旧的记录)。
PS:我用绑定(bind)参数 (?
) 替换了 PHP 变量 $id_recharge_winner
;你应该看看how to use parameterized queries让您的代码更安全、更简洁。
关于php - 如何使确认码在 1 天后过期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54498659/
TCP header 上的 32 位确认字段,比如 x告诉另一台主机“我收到了所有字节,直到并包括 x-1,现在期待来自 x 和 on 的字节”。在这种情况下,接收方可能已经收到了一些更多字节,比如
我正在使用 PyCharm 2020.2.3 不知不觉中我点击了下图中的复选框 现在,即使我的代码正在调试中,点击运行也会终止调试并开始运行代码。如何将其恢复为未选中状态?谢谢。 PS:我的“允许并行
我想知道何时使用 RabbitMQ 和 Spring Boot 接受 (ack) 或不接受 (nack) 消息。 我想将消息发送到队列(通过交换)并检查队列是否已接受该消息。实际上我想发送到两个不同的
我一直在寻找一种方法让用户确认 票在分配给他们之后。不知道有没有 这是一个内置功能,或者如果有一个插件 将为用户创建一个状态/按钮以接受票证 在它被放入队列之后。我希望 从附近的售票窗口看到类似的东西
我正在构建一个应用程序以通过 Xbee API 与 Xbee 模块通信。 目前我有一些工作,但它相当简单并且有很多限制。 Sub processPackets() ' this runs as its
我有一个复选框,更改后会自动发布。 自动发布对于两者(选中和未选中)都适用,但我想在每个事件发生之前弹出一个对话框进行确认。 到目前为止,当选中该复选框时,弹出框就会起作用。 但当取消选中该复选框时,
当我使用 UIGestureRecognizer ,例如,当用户向右滑动时,我想要一个 UIAlertView询问他是否真的要进行向右滑动的 Action 。 我曾尝试这样做,但没有成功。 最佳答案
我有一个 asp:CheckBoxList,我想显示一条警告消息仅在使用 jquery 取消选中复选框时。 $('.chklist').click( function () {
我想知道有什么可能的方法来确定我们的推送消息是否最终从 APNS 服务器传送。我已经想出了一些信息,如下所述 APNS 正在发送接受推送请求的响应代码,并可能给出错误代码(如果有)。例如:如果您的有效
我有此页面,我正在尝试确认输入文本字段中的日期与当前日期。如果输入字段中的日期晚于当前日期,则需要出现确认框以确认他们输入了正确的日期。因此,“确定”按钮需要完成数据提交,“取消”按钮需要将它们返回到
我有一个功能: function placeOrder(price, productList) { var bulletinBoardItem = Number(productList.box
我不明白为什么即使我点击“否”,这个confirm()调用也会被触发。你能告诉我我做错了什么吗? $('.deleteButton').livequery('click',function(){
我目前正在使用 dotmailer 生成一个新表单(简单的文本框和提交按钮),自动将电子邮件地址添加到 dotmailer 地址簿。 当有人提交电子邮件地址时 - 他们可以被带到网页。 我一直在尝试
这是不起作用的代码...它只是删除表单而不先提示。 $(".delete").click(function () { if(confirm('You honestly want to dele
我在我的程序中使用 aprgeparse 创建一个参数,允许用户从 amazon s3 存储桶中删除文件。我以这种方式创建它: parser.add_argument("-r", "--remove"
我正在努力学习 puppeteer 操作。我已经成功编写了登录页面和一些导航的脚本。然后我让它点击一个按钮。该页面抛出一个 window.confirm,我希望我的脚本接受它以继续下一步,但我不知
某网站实现了一个第三方插件,提示用户在删除前进行确认。 confirmDelete: function (event) { var go_ahead = confirm("Are you su
我想在 primefaces 的选择/取消选择复选框上显示确认对话框。我试过了 但它不起作用,因为 selectBooleanCheckBox 不可确认。是否有解决此问题的解决方法? 最
我们已经从 TFS 下载了一个项目,在恢复 Nuget 包后,我们收到以下错误: Error 5 The "ValidatePackageReferences" task could not
我有两个单独的 ul 列表:列表 A 和列表 B 由于 jQuery UI 插件,它们都可以排序。 我正在开发的项目的用户希望在项目从一个列表移动到另一个列表时确认操作,但在同一列表内移动时则不需要。
我是一名优秀的程序员,十分优秀!