【发布时间】: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