2016-10-04 98 views
0

我有一個爲INSERT準備的聲明函數,我在這個論壇中獲得了這個函數。但我不知道如何將變量/數組傳遞給此函數。我是新手,有些幫助會非常有用。如何在準備好的語句函數中傳遞變量?

我想somehing這樣的:

$obj->insert_data($parameter) 

我在下面列出的功能..

function insert_datas($array) { 
    $placeholders = array_fill(0, count($array), '?'); 

    $keys = $values = array(); 

    foreach($array as $k => $v) { 
     $keys[] = $k; 
     $values[] = !empty($v) ? $v : null; 
    } 

    $stmt = self::$mysqli->stmt_init(); 
    $query = 'INSERT INTO `'.DB_TABLE_PAGES.'` '. 
      '('.implode(',', $keys).') VALUES '. 
      '('.implode(',', $placeholders).')'; 
    $stmt->prepare($query); 

    call_user_func_array(
     array($stmt, 'bind_param'), 
     array_merge(
      array(str_repeat('s', count($values))), 
      $values 
     ) 
    ); 

    $stmt->execute();  
} 

回答

-1

試試這個,希望這有助於!

define('DB_HOST', 'database_host'); 
define('DB_NAME', 'database_name'); 
define('DB_USER', 'database_user'); 
define('DB_PASS', 'database_password'); 

$dbc = new PDO('mysql:host='. DB_HOST .';dbname='. DB_NAME, DB_USER, DB_PASS); 

function insert_datas($array) { 
    foreach($array as $a) { 
     $insert_table = "INSERT INTO table (column) VALUES (:column)"; 
     $stmt = $dbc->prepare($insert_table); 
     $stmt->bindValue(':column', $a['key'], PDO::PARAM_STR); 
     $stmt->execute(); 
    }  
} 
相關問題