Deprecated: The each() function is deprecated. This message will be suppressed on further calls in /home/zhenxiangba/zhenxiangba.com/public_html/phproxy-improved-master/index.php on line 456
PHP: pg_insert - Manual
[go: Go Back, main page]

PHP
downloads | documentation | faq | getting help | mailing lists | reporting bugs | php.net sites | links | conferences | my php.net

search for in the

pg_last_error" width="11" height="7"/> <pg_host
Last updated: Sun, 25 Nov 2007

view this page in

pg_insert

(PHP 4 >= 4.3.0, PHP 5)

pg_insert — テーブルに配列を挿入する

説明

mixed pg_insert ( resource $connection , string $table_name , array $assoc_array [, int $options ] )

pg_insert() は、 table_name で指定したテーブルに assoc_array の値をを挿入します。 options が指定されている場合、そのオプションと ともに pg_convert()assoc_array に適用されます。

警告

この関数は、 実験的 なものです。この関数の動作・ 名前・その他ドキュメントに書かれている事項は、予告なく、将来的な PHP のリリースにおいて変更される可能性があります。 この関数は自己責任で使用してください。

パラメータ

connection

PostgreSQL データベースの接続リソース。

table_name

行を挿入するテーブルの名前。テーブル table_name は、少なくとも assoc_array の要素数ぶんのカラムを 保持している必要があります。

assoc_array

テーブル table_name のフィールド名をキーに、 挿入する内容を値にもつ配列。

options

PGSQL_CONV_OPTSPGSQL_DML_NO_CONVPGSQL_DML_EXECPGSQL_DML_ASYNC あるいは PGSQL_DML_STRING を組み合わせた数。 PGSQL_DML_STRINGoptions に含まれていた場合、 クエリ文字列が返されます。

返り値

成功した場合に TRUE を、失敗した場合に FALSE を返します。 optionsPGSQL_DML_STRING が渡された場合は文字列を返します。

Example#1 pg_insert() の例

<?php 
  $dbconn 
pg_connect('dbname=foo');
  
// これは安全です。なぜなら $_POST は自動的に変換されるからです。
  
$res pg_insert($dbconn'post_log'$_POST);
  if (
$res) {
      echo 
"POST data is successfully logged\n";
  } else {
      echo 
"User must have sent wrong inputs\n";
  }
?>

参考



pg_last_error" width="11" height="7"/> <pg_host
Last updated: Sun, 25 Nov 2007
 
add a note add a note User Contributed Notes
pg_insert
jsnell at e-normous dot com
28-Sep-2007 04:49
If you need schema support, this function will do something similar to pg_insert:

function pg_insert_with_schema($connection, $table, $updates)
{
 $schema = 'public';
 if (strpos($table, '.') !== false)
    list($schema, $table) = explode('.', $table);

    if (count($updates) == 0) {
        $sql = "INSERT INTO $schema.\"$table\" DEFAULT VALUES";
            return pg_query($sql);
        } else {
 $sql = "INSERT INTO $schema.\"$table\" ";
           
 $sql .= '("';
 $sql .= join('", "', array_keys($updates));
 $sql .= '")';

 $sql .= ' values (';
 for($i = 0; $i < count($updates); $i++)
   $sql .= ($i != 0? ', ':'').'$'.($i+1);
 $sql .= ')';
 return pg_query_params($connection, $sql, array_values($updates));
 }
}
excalibur at nospam dot icehouse dot net
17-Oct-2006 12:06
Today at work I isolated a problem I was having with this function to how I was formatting the date.  I was assigning the date in my code as follows:

$today = date( "Ymd" ); // ISO 8601

This format is acceptable to PostgreSQL, as verified by their documentation and buy tests using psql.  However, to make it work in my code, I had to make the following change:

$today = date( "Y-m-d" ); // also ISO 8601 format
ANDYCHR17 at HOTMAIL dot COM
06-May-2006 06:50
Had a few issues while trying to run this in PHP 4.4.0:

- I could not get it to work with column names that are SQL reserved words (example: desc, order). I was forced to change the column names in order to use the function. I could not put the column names in quotes, because that caused pg_convert() to fail.

- Function was returning false until I passed the PGSQL_DML_EXEC option.
skippy at zuavra dot net
15-Feb-2005 12:08
Beware of the following: pg_insert() and pg_update() are adding slashes to all character-like fields they work with. This makes them SQL injection super-safe, but there are unwanted consequences, as follows:

If you have a regular setup with magic_quotes_gcp=On, and you use pg_insert() or pg_update(), you will end up with fields that look as if you used addslashes() twice. To solve this, you can use stripslashes() on the data just before using it with pg_insert() or pg_update().

There's another alternative, which seems better to me. Why make yourself crazy all over the code, adding slashes, stripping slashes, worrying whether magic_quotes_gpc is on or off and so on and so forth? Why do this, when the only place you actually need those slashes is right when you push the data into the database?

So why not get rid of your addslashes() and stripslashes() from all over your code, and turn magic_quotes_gcp off. As long as you always use pg_insert() and pg_update() to do your DB work, you're SQL-injection safe AND slash-headache free.
mina86 at tlen dot pl
24-May-2004 10:24
Next version :) My version checks whether value is bool, null, string or numeric and if one of the values is not function returns false if not. null values are inserted as NULL, bool as true or false and strings are add-shlashed before adding to query string. Note, that this function is not safe. SQL injection is possible with column names if you use $_POST or something similar as a $array.

<?php
function db_build_insert($table, $array) {
  if (
count($array)===0) return false;
 
$columns = array_keys($array);
 
$values = array_values($array);
  unset(
$array);

  for (
$i = 0, $c = count($values); $i$c; ++$i) {
    if (
is_bool($values[$i])) {
     
$values[$i] = $values[$i]?'true':'false';
    } elseif (
is_null($values[$i])) {
     
$values[$i] = 'NULL';
    } elseif (
is_string($values[$i])) {
     
$values[$i] = "'" . addslashes($values[$i]) . "'";
    } elseif (!
is_numeric($values[$i])) {
      return
false;
    }
  }

  return
"INSERT INTO $table ($column_quote" . implode(', ', $columns) .
   
") VALUES (" . implode(', ', $values) . ")";
}
?>
shane at treesandthings dot com
22-Jan-2004 01:04
Returns SQL statement, slight improvement on the code from 'rorezende at hotmail dot com'.  This version adds bool values correctly.It also checks to make sure there is actually a value in the array before including it in the sql statement. (ie: null values or empty strings won't be added to the sql statement)

<?PHP
function db_build_insert($table,$array)
{

  
$str = "insert into $table ";
  
$strn = "(";
  
$strv = " VALUES (";
   while(list(
$name,$value) = each($array)) {

       if(
is_bool($value)) {
               
$strn .= "$name,";
               
$strv .= ($value ? "true":"false") . ",";
                continue;
        };

       if(
is_string($value)) {
               
$strn .= "$name,";
               
$strv .= "'$value',";
                continue;
        }
       if (!
is_null($value) and ($value != "")) {
               
$strn .= "$name,";
               
$strv .= "$value,";
                continue;
       }
   }
  
$strn[strlen($strn)-1] = ')';
  
$strv[strlen($strv)-1] = ')';
  
$str .= $strn . $strv;
   return
$str;

}
?>
rorezende at hotmail dot com
17-Jul-2003 03:49
Time is money, then I write a function similar to pg_insert in PHP (only output sql statement) :

   function db_mount_insert($table,$array) {

    $str = "insert into $table (";
    while(list($name,$value) = each($array)) {       
        $str .= "$name,";       
    }
    $str[strlen($str)-1] = ')';
    $str .= " values (";
    reset($array);
    while(list($name,$value) = each($array)) {       
        if(is_string($value))
            $str .= "'$value',";
        else
            $str .= "$value,";
    }
    $str[strlen($str)-1] = ')';
    $str .= ";"    ;
   
    return $str;

   }

pg_last_error" width="11" height="7"/> <pg_host
Last updated: Sun, 25 Nov 2007
 
 
show source | credits | sitemap | contact | advertising | mirror sites