pg_delete
(PHP 4 >= 4.3.0, PHP 5, PHP 7)
pg_delete — Удаляет записи
Описание
$connection
, string $table_name
, array $assoc_array
[, int $options
= PGSQL_DML_EXEC
] )
pg_delete() удаляет из таблицы записи, соответствующие ключам и значениям
массива assoc_array
. Если задан аргумент options
,
то массив assoc_array
будет предварительно обработан
функцией pg_convert(), вызванной с указанными
параметрами.
Список параметров
-
connection
-
Ресурс соединения с базой данных PostgreSQL.
-
table_name
-
Имя таблицы, из которой удаляются записи.
-
assoc_array
-
Ассоциативный массив, ключи которого соответствуют именам полей таблицы
table_name
, а значения соответствуют удаляемым значениям в этих колонках. -
options
-
Комбинация констант
PGSQL_CONV_FORCE_NULL
,PGSQL_DML_NO_CONV
,PGSQL_DML_ESCAPE
,PGSQL_DML_EXEC
,PGSQL_DML_ASYNC
илиPGSQL_DML_STRING
. Если константаPGSQL_DML_STRING
присутствует в аргументеoptions
, то функция вернет строку, содержащую запрос. Если установленыPGSQL_DML_NO_CONV
илиPGSQL_DML_ESCAPE
, то функция pg_convert() внутренне не вызывается.
Возвращаемые значения
Возвращает TRUE
в случае успешного завершения или FALSE
в случае возникновения ошибки. Возвращает строку, если в аргументе options
передана константа PGSQL_DML_STRING
.
Примеры
Пример #1 Пример использования pg_delete()
<?php
$db = pg_connect('dbname=foo');
// Это безопасно, поскольку $_POST автоматически конвертируется
$res = pg_delete($db, 'post_log', $_POST);
if ($res) {
echo "Данные из POST удалены: $res\n";
} else {
echo "Пользователь отправил неверные входные данные\n";
}
?>
Список изменений
Версия | Описание |
---|---|
5.6.0 |
Больше не является экспериментальной. Добавлена константа PGSQL_DML_ESCAPE ,
TRUE /FALSE и NULL типы данных теперь поддерживаются.
|
5.5.3/5.4.19 |
Исправлены прямые SQL-инъекции в table_name
и непрямые SQL-инъекции в идентификаторах.
|
Смотрите также
- pg_convert() - Преобразует значения ассоциативного массива в приемлемые для использования в SQL запросах
- PHP Руководство
- Функции по категориям
- Индекс функций
- Справочник функций
- Расширения для работы с базами данных
- Расширения для работы с базами данных отдельных производителей
- PostgreSQL
- pg_affected_rows
- pg_cancel_query
- pg_client_encoding
- pg_close
- pg_connect_poll
- pg_connect
- pg_connection_busy
- pg_connection_reset
- pg_connection_status
- pg_consume_input
- pg_convert
- pg_copy_from
- pg_copy_to
- pg_dbname
- pg_delete
- pg_end_copy
- pg_escape_bytea
- pg_escape_identifier
- pg_escape_literal
- pg_escape_string
- pg_execute
- pg_fetch_all_columns
- pg_fetch_all
- pg_fetch_array
- pg_fetch_assoc
- pg_fetch_object
- pg_fetch_result
- pg_fetch_row
- pg_field_is_null
- pg_field_name
- pg_field_num
- pg_field_prtlen
- pg_field_size
- pg_field_table
- pg_field_type_oid
- pg_field_type
- pg_flush
- pg_free_result
- pg_get_notify
- pg_get_pid
- pg_get_result
- pg_host
- pg_insert
- pg_last_error
- pg_last_notice
- pg_last_oid
- pg_lo_close
- pg_lo_create
- pg_lo_export
- pg_lo_import
- pg_lo_open
- pg_lo_read_all
- pg_lo_read
- pg_lo_seek
- pg_lo_tell
- pg_lo_truncate
- pg_lo_unlink
- pg_lo_write
- pg_meta_data
- pg_num_fields
- pg_num_rows
- pg_options
- pg_parameter_status
- pg_pconnect
- pg_ping
- pg_port
- pg_prepare
- pg_put_line
- pg_query_params
- pg_query
- pg_result_error_field
- pg_result_error
- pg_result_seek
- pg_result_status
- pg_select
- pg_send_execute
- pg_send_prepare
- pg_send_query_params
- pg_send_query
- pg_set_client_encoding
- pg_set_error_verbosity
- pg_socket
- pg_trace
- pg_transaction_status
- pg_tty
- pg_unescape_bytea
- pg_untrace
- pg_update
- pg_version
Коментарии
One should take care when checking the return value.
0 == false which is not equal with failed delete.
if(!$res)
echo "Nothing was deleted";