gpt4 book ai didi

php - 奇怪的自动增量问题

转载 作者:行者123 更新时间:2023-11-29 00:01:12 28 4
gpt4 key购买 nike

我正在制作一个带有 BIGINT(20) 自动递增字段的事务表。

添加新事务时,检索插入 Id 并将其格式化为更具可读性:

public function add_transaction($paymethod, $cursus_id)
{
$this->load->model('Config_model');

$btw = $this->Config_model->get('transactions.btw');

$query = " INSERT INTO transacties(userid, paymethod, amount, btw_pc)
VALUES((SELECT userid FROM users WHERE lcase(username)=lcase('{$this->session->userdata('username')}')),
'{$paymethod}',
(SELECT prijs FROM p_cursus_uitvoering WHERE uitvoering_id = {$cursus_id}),
{$btw});";

$this->db->query($query);
$insertId = $this->db->insert_id();

$newCode = date('Ymd') . str_pad($insertId, 8, '0', STR_PAD_LEFT);

$this->db->where('transact_id', $insertId);
$this->db->update('transacties', ['transact_id' => $newCode]);

return $newCode;
}

结果是 ID 从 5 更新为 2015041800000005。

这工作得很好,但正如您所见,newCode 在函数中返回并被另一个函数使用,它被重新插入到另一个表中。

问题就出在这里,ID变成:201504192058506757。

即使我回显 newCode,它仍然打印 201504192058506757.. 即使它一次正确插入,但第二次错误插入!

编辑:

这是调用函数的代码片段:

public function workshop(){
$this->load->model('Inschrijven_model');
$paymethod = $this->input->post("paymethod");
//eigenlijk uitvoering_id.....
$cursus_id = $this->input->post("cursus_id");
if($paymethod == null || $cursus_id == null){
redirect('cursus');
}
if($this->Inschrijven_model->cursus_has_room($cursus_id)){
if(!$this->Inschrijven_model->cursus_ingeschreven($cursus_id)){
$this->load->model('Cc_payment_model');
$this->load->model('Cursus_model');
$amount = $this->Cursus_model->get_price($cursus_id);

$orderId = $this->Cc_payment_model->add_transaction($paymethod, $cursus_id);
$this->Inschrijven_model->cursus_inschrijven($cursus_id,$orderId);


$function = explode('_',$paymethod);
$this->{$function[0]}($function[1], $amount, $orderId);

}else{
echo "Al ingeschreven";
}
}else{
echo "geen ruimte";
}
}

这是重新插入返回 $newCode 的代码片段:

public function cursus_inschrijven($cursus_id,$transaction_id){
$query = " INSERT INTO p_cursus_in(uitvoering_id, userid, transact_id)
VALUES({$cursus_id},(SELECT userid FROM users WHERE lcase(username)=lcase('{$this->session->userdata('username')}')),{$transaction_id})";
$this->db->query($query);
}

它被重新插入,因此我可以在某人的类(class)注册和他们为该类(class)支付的费用之间建立联系。

最佳答案

在将其导入 PHP 之前,必须将 BIGINT 转换为字符串

以下是如何使用 SQL 语句转换它: https://dev.mysql.com/doc/refman/5.7/en/cast-functions.html#function_convert

我不知道你使用的是什么框架,但是如果你使用 BIGINT,PHP 不直接支持其长度,则必须进行转换。貌似更新后框架会读取记录来判断操作是否成功,因为读取的过程没有转换,所以你得到了一个错误的数字。

您还可以使用 PHP GMP 模块来处理 BIGINT: https://php.net/manual/en/book.gmp.php

关于php - 奇怪的自动增量问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29730691/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com