【问题标题】:Insert data to database table field with type decimal(12,2)将数据插入十进制类型的数据库表字段(12,2)
【发布时间】:2016-09-19 22:25:35
【问题描述】:

我正在处理csv 导入数据库,我成功读取了csv 文件内容,下面的代码会将内容导入数据库。

<?php  
foreach ($data as $value) {
  $data = array (
    'checklist_item_id' => ($this->table == 'checklist_item') ? $this->id : null,
    'imp_sequence_no'   => $value['Sequence No.'],
    'imp_vendor_tin'    => $value['Vendor TIN'],
    'imp_vendor_name'   => $value['Vendor Name'],
    'imp_input_vat_per_client' => $value['Input VAT per client'],
    'imp_gsi    '       => $value['Goods/Services/Importations']
  );
  $this->db->insert("transaction", $data);
}
?>

这一行

  'imp_input_vat_per_client' => $value['Input VAT per client'],

代码,有一个带小数点的值,有时带逗号。

例如:

  624.00
  312.00
  1,137.57

imp_input_vat_per_client,是一个类型为decimal(12,2)的字段名。

我成功地将数据插入数据库,但是所有行中字段imp_input_vat_per_client的值都是,

  0.00

你能解释发生了什么吗? 怎么办?

【问题讨论】:

  • 这是 DECIMAL 数据类型的默认值,您可能插入了空白值!
  • 不,我确定,因为当你使用 var_dump 时它显示有
  • 我认为您将字符串值发送到数据,例如您发送值 $value = "10,22";
  • 你需要把你的数据类型改成varchar再检查一遍
  • 需要将imp_input_vat_per_client改为text或者varchar(255)

标签: php mysql codeigniter csv mariadb


【解决方案1】:

变化:

'imp_input_vat_per_client' => $value['Input VAT per client'],

'imp_input_vat_per_client' => floatval(str_replace(',', '', trim($value['Input VAT per client']))),

【讨论】:

  • 这行得通,谢谢,但你在trim(['Input VAT per client']))) 中忘记了$value
  • 没关系,我明白了
猜你喜欢
  • 2018-03-02
  • 1970-01-01
  • 2014-03-09
  • 2017-01-13
  • 2020-12-23
  • 2014-04-15
  • 2015-05-04
  • 1970-01-01
  • 2016-06-22
相关资源
最近更新 更多