Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/60.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 使用decimal(12,2)类型向数据库表字段插入数据_Php_Mysql_Codeigniter_Csv_Mariadb - Fatal编程技术网

Php 使用decimal(12,2)类型向数据库表字段插入数据

Php 使用decimal(12,2)类型向数据库表字段插入数据,php,mysql,codeigniter,csv,mariadb,Php,Mysql,Codeigniter,Csv,Mariadb,我正在处理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.'], '

我正在处理
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);
}
?>
在代码中,有一个带小数点的值,有时还有逗号

例如:

  624.00
  312.00
  1,137.57
imp\u input\u vat\u per\u client
,是一个字段名,类型为
十进制(12,2)

我成功地将数据插入数据库,但所有行中的字段
imp\u input\u vat\u per\u client
的值为

  0.00
你能解释一下发生了什么事吗? 如何处理它?

更改:

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

更改:

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


这是DECIMAL数据类型的默认值,您可能正在插入空白值!不,我敢肯定,因为当你使用var_dump时,它显示我认为你在向数据发送字符串值,例如,你发送值$value=“10,22”;您需要将数据类型更改为varchar并再次检查需要将imp_input_vat_per_client更改为text或varchar(255)这是DECIMAL数据类型的默认值,您可能正在插入空白值!不,我敢肯定,因为当你使用var_dump时,它显示我认为你在向数据发送字符串值,例如,你发送值$value=“10,22”;您需要将数据类型更改为varchar并再次检查需要将imp_input_vat_per_client更改为text或varchar(255),谢谢,但您在
trim(['input vat per client']))中忘记了
$value
这没关系,我知道它是有效的,谢谢,但您在
trim(['input vat per client'])中忘记了
$value
)))
没关系,我明白了
'imp_input_vat_per_client' => floatval(str_replace(',', '', trim($value['Input VAT per client']))),