PHP Преобразование из целого числа в десятичное

0

Я пытаюсь сохранить целое число со значением 0 в php до десятичного (7,2) в miranda db.

Но целое число со значением 0 сохранить всегда 99999.99 Я не могу найти решение. Я думаю, что он может автоматически трансформироваться. Я использую PDO в php.

Другие значения, отличные от 0, хорошо работают.

Мой вставленный массив:

array(":name"=>"3ld",":urlid"=>($url->id),":date"=>"NOW()",":type"=>"renew",":status"=>($url->alias.$url->custom.".".$url->tld),":price"=>$price)

Значение дампа Var из массива:

array(6) { [":name"]=> string(3) "3ld" [":urlid"]=> string(1) "1" [":date"]=> string(5) "NOW()" [":type"]=> string(5) "renew" [":status"]=> string(19) "support.url.tld" [":price"]=> int(0) }

Часть кода:

$this->db->insert("log_url",array(":name"=>"3ld",":urlid"=>($url->id),":date"=>"NOW()",":type"=>"renew",":status"=>($url->alias.$url->custom.".".$url->tld),":price"=>$price));

Функция вставки DB:

    public function insert($table,$parameters=array()){
    $param="";
    $val="";
    $insert= $this->ph($parameters);
    //Build Query
    $query="INSERT INTO {$this->dbinfo["prefix"]}$table";                       
    if(is_array($insert)){
        $count=count($insert);
        $i=0;           
        foreach ($insert as $key => $value) {
            if($parameters[$value]=="NOW()"){
                $val.= "NOW()";
                unset($parameters[$value]);
            }else{
                $val.=$this->quote($value,$parameters);
            }                   
            $param.="'$key'";
            if(++$i != $count) {
                $param.=",";
                $val.=",";
            }               
        }
        $query.=" ($param) VALUES ($val)";
    }       
    $result = $this->db->prepare($query);
    $result->execute($parameters);
    if($this->error_message($result->errorInfo())) {
        $this->query=strtr($query,$parameters);
        $this->db_error=$this->error_message($result->errorInfo());
        exit;
    }
    ++$this->num_queries;
return TRUE;        
}

Функция котировки:

private function quote($string,$param=''){  
    if(empty($param)){
        return "'$string'";
    }
    return $string;
}

Создать функцию заполнителей:

private  function ph(array $a){
    $b=array();
    foreach ($a as $key => $value) {
        $b[str_replace(":", "", $key)]="$key";
    }
    return $b;
}

Любая информация помогает, спасибо.

Обновленный код:

public function insert($table,$parameters=array()){
    $param="";
    $val=array();
    $insert= array_keys($parameters); var_dump($parameters);
    //Build Query
    $query="INSERT INTO {$this->dbinfo["prefix"]}$table";

    if(is_array($insert)){

        $query.=' (''.implode($insert,"','").'') VALUES (:'.implode($insert,', :').')';

        $result = $this->db->prepare($query);

        foreach($parameters as $key=>$param) {
          $result->bindParam(":".$key, ($param['value']=='NOW()')?date('Y-m-d H:i:s'):$param['value'], PDO::PARAM_STR);
        }
    }      

    $result->execute(); //$result->execute($parameters);
    if($this->error_message($result->errorInfo())) {
        $this->query=strtr($query,$parameters);
        $this->db_error=$this->error_message($result->errorInfo());
        exit;
    }
    ++$this->num_queries;
return TRUE;        
}

производить по цене 2015.00

  • 0
    покажи нам фрагмент кода пожалуйста
  • 0
    я уточню вопрос
Показать ещё 13 комментариев
Теги:
decimal
integer

1 ответ

1
Лучший ответ

Замените вызов на метод, удалив ":", нет смысла отправлять ":", а затем удалять это ":" by ->ph()

$this->db->insert("log_url",
    array("name"=>array("value"=>"3ld","type"=>PDO::PARAM_STR), //
      "urlid"=>array("value"=>$url->id,"type"=>PDO::PARAM_STR),
      "date"=>array("value"=>'NOW()',"type"=>PDO::PARAM_STR),     
"type"=>array("value"=>'renew',"type"=>PDO::PARAM_STR),
"status"=>array("value"=>$url->alias.$url->custom.".".$url->tld,"type"=>PDO::PARAM_STR),
"price"=>array("value"=>$price,"type"=>PDO::PARAM_STR)));       //

о параметрах PDO типов читайте здесь: http://php.net/manual/en/pdo.constants.php и здесь http://php.net/manual/en/pdostatement.bindparam.php

и внутри вашей функции вы можете заменить это:

$param="";
    $val="";
    $insert= $this->ph($parameters);
    //Build Query
    $query="INSERT INTO {$this->dbinfo["prefix"]}$table";                       
    if(is_array($insert)){
        $count=count($insert);
        $i=0;           
        foreach ($insert as $key => $value) {
            if($parameters[$value]=="NOW()"){
                $val.= "NOW()";
                unset($parameters[$value]);
            }else{
                $val.=$this->quote($value,$parameters);
            }                   
            $param.="'$key'";
            if(++$i != $count) {
                $param.=",";
                $val.=",";
            }               
        }
        $query.=" ($param) VALUES ($val)";
    }       
    $result = $this->db->prepare($query);

с этим:

$val=array();
$insert= array_keys($parameters);
//Build Query
$query="INSERT INTO {$this->dbinfo["prefix"]}$table";                       
if(is_array($insert)){

    $query.=' (''.implode($insert,"','").'') VALUES (:'.implode($insert,', :').')';

    $stmt= $this->db->prepare($query);

    foreach($parameters as $key=>$param) {
      //$stmt->bindParam(":".$key, ($param['value']=='NOW()')?date('Y-m-d H:i:s'):$param['value']);
      if($param['value']=='NOW()') {
         $now = date('Y-m-d H:i:s');
         $stmt->bindParam(":".$key, $now, $param['type']); 
      } else {
         $stmt->bindParam(":".$key, $param['value'], $param['type']); 
      }
    }
}       

так что это должно работать

кстати, не забывайте изменения:

 $result->execute($parameters);

в

 $stmt->execute();

там внизу...

Ещё вопросы

Сообщество Overcoder
Наверх
Меню