5

我的数据库发生了一些非常奇怪的事情。我正在使用 PHP 将数据插入到我的数据库中,过去 2 年我一直在这样做,没有任何问题。当客户在我的网站上付款时,我将来自该交易的所有数据存储在我的数据库中。每笔交易都有一个唯一的“transaction_id”。当我将付款信息插入数据库时​​,除了“transaction_id”之外的所有信息都正确插入。所有交易都被赋予“4294967295”的“transaction_id”。所以我做了一些测试。这是我所做的:

1)我将“transaction_id”回显到我的屏幕上,看看会说什么。结果是被回显的“transaction_id”是正确的。这不是重复的“4294967295”。但是,当我查看我的数据库时,它显示“4294967295”。

2)这次我决定将查询回显到我的网络浏览器。查询是正确的。在查询中,正确的“transaction_id”在查询中。但是,当我查看我的数据库时,它显示“4294967295”。

我有 3 个不同的页面供客户付款。所有 3 个页面于 2012 年 4 月 6 日开始执行此操作。这些页面都没有被修改。我已经超过 2 年没有修改这些页面了。任何帮助是极大的赞赏!

$query = "INSERT INTO payments (customer_id, transaction_id, invoice_number, authorization_code, subscription, subscription_id, avs_result, cvv_result, amount, full_tuition, payment_date, ip_address) VALUES ({$_SESSION['customer_id']}, {$_SESSION['transaction_id']}, {$_SESSION['invoice_number']}, '{$_SESSION['authorization_code']}', '{$_SESSION['subscription']}', {$_SESSION['subscription_id']}, '{$_SESSION['avs_result']}', '{$_SESSION['cvv_result']}', {$_SESSION['amount']}, {$_SESSION['full_tuition']}, '{$_SESSION['payment_date']}', '{$_SESSION['ip_address']}')" ;
$result = mysqli_query($dbc, $query) OR die ('<p>There was an error with the INSERT payments query.: ' . mysqli_error($dbc) . '<br />Query:' . $query . '</p>') ;

echo '<p>Transaction ' .  $_SESSION['transaction_id'] . ' has been <font color="green">APPROVED</font> by the system.</p>' ;

echo '<br /><br />' ;

echo '<p>Below is a summary:</p>' ;
echo '<p>Transaction ID: ' .  $_SESSION['transaction_id'] . '<br />
Payment Method: XXXX<br />
Amount: $' . $amount . '<br />
Customer Name: ' . $_SESSION['first_name'] . ' ' . $_SESSION['last_name'] . '<br />
</p>' ;

echo "<p>Note: Please do NOT click the browser's Back button to enter a new transaction.</p>" ;


echo $query ;
4

5 回答 5

9

您的数字大于数据库中的字段可以处理...

4294967295 是 32 位可以容纳的最大数字,您的事务 ID 现在大于您的数据库可以容纳的数字字段。

于 2012-04-11T17:50:43.217 回答
5

出色地调查问题并在您的问题中报告结果!

4294967295 是 mysql 可以容纳的最大 INT,因此高于该值的事务 ID 将存储为 4294967295。要解决此问题,您可以将列类型更改为 BIGINT:modify column transaction_id bigint

这应该在保留所有数据的同时转换列类型,但最好先备份数据库以防万一!

于 2012-04-11T17:54:17.173 回答
1

4294967295 方便地是 2^32-1 - 32 位无符号整数的最大值。看起来你给它的任何 transaction_id 都太大了,所以它溢出了,MySQL 在这种情况下的行为是将它设置为最大值。

另外,如果你使用 MySQLi,你应该考虑使用准备好的语句。我不确定您的会话变量的值是什么,但我怀疑它们未转义,因此它们需要转义或使用准备好的语句。

于 2012-04-11T17:50:15.093 回答
0

将数据类型更改transaction_idBIGINT

于 2012-04-11T17:52:21.770 回答
0

另一种选择是查看表的自动增量值。就我而言,它是 4294967295 :/

于 2015-09-24T11:31:06.513 回答