Что такое код pg_send_query

Содержание

pg_send_query

(PHP 4 >= 4.2.0, PHP 5)

pg_send_query � Sends asynchronous query

��������

pg_send_query() sends a query or queries asynchronously to the connection. Unlike pg_query() , it can send multiple queries at once to PostgreSQL and get the results one by one using pg_get_result() .

Script execution is not blocked while the queries are executing. Use pg_connection_busy() to check if the connection is busy (i.e. the query is executing). Queries may be cancelled using pg_cancel_query() .

Although the user can send multiple queries at once, multiple queries cannot be sent over a busy connection. If a query is sent while the connection is busy, it waits until the last query is finished and discards all its results.

������ ����������

PostgreSQL database connection resource.

The SQL statement or statements to be executed.

Data inside the query should be properly escaped.

������������ ��������

���������� TRUE � ������ ��������� ���������� ��� FALSE � ������ ������������� ������.

Use pg_get_result() to determine the query result.

�������

������ #1 pg_send_query() example

= pg_connect ( «dbname=publisher» ) or die( «Could not connect» );

if (! pg_connection_busy ( $dbconn )) <
pg_send_query ( $dbconn , «select * from authors; select count(*) from authors;» );
>

$res1 = pg_get_result ( $dbconn );
echo «First call to pg_get_result(): $res1 \n» ;
$rows1 = pg_num_rows ( $res1 );
echo » $res1 has $rows1 records\n\n» ;

$res2 = pg_get_result ( $dbconn );
echo «Second call to pg_get_result(): $res2 \n» ;
$rows2 = pg_num_rows ( $res2 );
echo » $res2 has $rows2 records\n» ;
?>

��������� ���������� ������� �������:

�������� �����

  • pg_query() — Execute a query
  • pg_cancel_query() — Cancel an asynchronous query
  • pg_get_result() — Get asynchronous query result
  • pg_connection_busy() — Get connection is busy or not

��� ����� ��� pg_send_query

dblink_send_query � ������� ����������� ������ � �������� ���� ������

���������

��������

dblink_send_query ������� ������ ��� ������������ ����������, �� ���� �� ���������� ��������� ����������. � ���� ������������ �� ������ ���� ������ ��� ������������� ����������� ������.

����� �������� �������� ������������ ������� ��������� ��� ���������� ����� ���������, ������� ������� dblink_is_busy , � � ����� �������� ������, ������ dblink_get_result . ����� ����� ���������� �������� �������� ����������� ������, ������ dblink_cancel_query .

���������

��� ������������� �����������. sql

�������� SQL, ������� �� ������ ��������� � �������� ���� ������, �������� select * from pg_class .

������������ ��������

���������� 1, ���� ������ ��� ������� ��������� �� ���������, ��� 0 � ��������� ������.

��� ����� ��� pg_send_query

pg_send_query — ���������� ����������� ������.

��������

bool pg_send_query (resource connection, string query)

bool pg_send_query (string query)

pg_send_query() ���������� ����������� ������ ���������� connection . � ������� �� pg_query() , ��� ����� ���������� ������������� ������ � PostgreSQL � �������� ���������� ���� �� ������, ��������� pg_get_result() . ���������� ������� �� ����������� ��� ���������� �������. ����������� pg_connection_busy() ��� �������� ��������� ���������� (�.�. ������ �����������). ������ ����� ���� ������ ������� pg_cancel_query() .

� �� �� ����� ������������ ����� ���������� ������������� ������ �� ���� ���. ������������ �� ����� ���������� ������������� ������ �� �������� ����������. ���� ������ ������������, ����� ���������� ������, �� �������, ���� ��������� ������ �� ���������� � �� �������� ��� ����������.

��� ����� ��� pg_send_query

(PHP 4 >= 4.2.0, PHP 5)

pg_send_query — Sends asynchronous query

Description bool pg_send_query ( resource connection, string query )
bool pg_send_query ( string query )

Although user can send multiple query at once, user cannot send multiple query over busy connection. If query is sent while connection is busy, it waits until last query is finished and discards all result.

Пример 1. Asynchronous Queries

= pg_connect ( «dbname=publisher» ) or die( «Could not connect» );

if (! pg_connection_busy ( $dbconn )) <
pg_send_query ( $dbconn , «select * from authors; select count(*) from authors;» );
>

$res1 = pg_get_result ( $dbconn );
echo «First call to pg_get_result(): $res1 \n » ;
$rows1 = pg_num_rows ( $res1 );
echo «$res1 has $rows1 records \n\n » ;

$res2 = pg_get_result ( $dbconn );
echo «second call to pg_get_result(): $res2 \n » ;
$rows2 = pg_num_rows ( $res2 );
echo «$res2 has $rows2 records \n » ;
?>

The above example would produce the following output:

first call to pg_get_result(): Resource id #3 Resource id #3 has 3 records second call to pg_get_result(): Resource id #4 Resource id #4 has 1 records

$conn = pg_connect ( «host=’127.0.0.1′ dbname=’test’ user=’usertest’ password=’passtest'» );

$fp = fopen ( ‘logo.gif’ , «r» );
$buffer = fread ( $fp , filesize ( ‘logo.gif’ ));
fclose ( $fp );

pg_exec ( $conn , «begin» );

$oid = pg_locreate ( $conn );

$rs = pg_exec ( $conn , «INSERT INTO test(tipo, images) VALUES(‘A1’, $oid);» );
$handle = pg_loopen ( $conn , $oid , «w» );

pg_lowrite ( $handle , $buffer );
pg_loclose ( $handle );

pg_exec ( $conn , «commit» );

$rs = pg_exec ( $conn , «SELECT images FROM test WHERE tipo = ‘A1’;» );
$row = pg_fetch_row ( $rs , 0 );

pg_exec ( $conn , «begin» );
$loid = pg_loopen ( $conn , $row [ 0 ], «r» );

header ( «Content-type: image/gif» );

pg_loreadall ( $loid );
pg_loclose ( $loid );

pg_exec ( $conn , «commit» );

pg_exec ( $conn , «begin» );

$loid = $row [ 0 ];
pg_lounlink ( $conn , $loid );

pg_exec ( $conn , «commit» );

pg_exec ( $conn , «DELETE FROM test WHERE tipo = ‘A1’;» );

Due to a bug, OLD API does not available with PHP 4.2.0 and 4.2.1.

PHP 4.2.2 will support OLD API again and will be kept long enough.

New API will be available PHP 4.2.0 to later versions.
yohgaki at php dot net
19-Jun-2002 04:00
Due to a bug, PHP 4.2.0 and 4.2.1 does not support pg_lo_import() old API. It’s fixed in PHP 4.2.2.

BTW, new API will be always available from PHP 4.2.0 to later versions. Older API will be kept long enough, also.
ceco at noxis dot net
15-May-2002 09:08
it works for me (php-4.2.1)

int pg_lo_import ( string pathname [, resource connection])

Илон Маск рекомендует:  Основы opengl

but
int pg_lo_import ( resource connection, string pathname )

don’t know the reason

If there is an error in one of your queries, the queries following it will not get executed, and there will *not* be an error message displayed. The only way I can think of to determine if an SQL error happened is to use pg_trace.

pg_send_query($connection,
«SELECT id FROM users;
SELECT * FROM customers;
[INVALID-SQL-STATEMENT];
SELECT name FROM countries;»);

while ($result = pg_get_result($connection))
$results[] = $result;

The $results array will only have two items in it.

pg_send_query(): �� ������� ���������� ���������� � ������� ����������?

� ���� ���� ������ ��������, �������, �������, ������ �������� ��������� ��������� �� ������ ����������� ������: pg_send_query(): �� ������� ���������� ���������� � �����

���, �������, ���������� �������� ������� ����� ����������, �� ������, ���� ��� ������� ���������� ������, ������� ���������� ������.

��� ��� �� �������?

Edit: ���� ��� ������� � Postgres �� ����� � ������ ������������� ������, �����������, ��� ��� ������ ������ ����������, � �� ���-�� ������ �� ��� �� ������� Postgres’ (��������, ��������, �� ��������� Postgres ���� � ������������ ��� ���-��)

�������������: ��������� � ���� ������, ��� ���������� INSERT �����������, ��� ��� �����, ����� ��� ������ �����������.

Edit: ������, ���, ��������, ���� ������������� � ���� 2013 ����: https://bugs.php.net/bug.php? >

������ 14 ���. 09 2009-05-14 18:42:21 Frank Farmer

6 �������

��� ������� pg_send_query() , ����������� ������� ����������� ���������� ������� � ����� ����������. ����� �� �������� ��� � ���� pgsql.c, �� ������ �����:

��� ������ �������� �������� � ����� �������, ����� ����, ��� �������� ������. ��� ������������� ������ ����������, ��� ���� ���������� INSERT �����������.

��� ���� ���� ������� PQ_SETNONBLOCKING ����������� � ���, ����� ���������� ���������� � ������������� �����, ����� ��������� ����������� ���������� � ������� ��� ������� � ����� ���������� �� ���������. �� documentation of PQsetnonblocking: (PQ_SETNONBLOCKING ��� ������ ��������� ���������� ��� ���� �������):

Sets the nonblocking status of the connection.

Sets the state of the connection to nonblocking if arg is 1, or blocking if arg is 0. Returns 0 if OK, -1 if error.

In the nonblocking state, calls to PQsendQuery, PQputline, PQputnbytes, and PQendcopy will not block but instead return an error if they need to be called again.

Note that PQexec does not honor nonblocking mode; if it is called, it will act in blocking fashion anyway.

���������� �� �������� PQsetnonblocking (� PostgeSQLs Fe-exec.c), ���� ��� �������, ������ ����� ����� �� :

��� ��� ���������� ���������� ��� ��� �����, ��� pqFlush �� ���� ������� ���������, ��������� ���������� �������� � �������� ������ ����������.

������ ������ ��� �� ����������, ��� ��� ��� ������, ����������, ������� ���������� ���������� ��� ����������� ������� � ����������� �� ��� (��� �������� ����� ��������).

��� ��������� ������ ������, ��� ��������, ��� � ��� ���� ���������� � ��������� �� �� ���������, � �� � ����������. � �� ����, �������� �� ��� �� ����������� ������, ������� ����� �������� ������������ ��� ����������. ���� �� ������ ��������� ������, �� ������ ������� ���������� � ���� ������ � ������������ �����/������.

������ 13 ���. 09 2009-10-13 21:15:27 Henrik Opel

pg_send_query (): �� ������� ���������� ���������� � ����� ����������?

� ���� ���� ������ ��������, �������, �������, ������ �������� ��������� ��������� �� ������ ����������� ������: pg_send_query (): �� ������� ���������� ���������� � ����� ����������

���, �������, ���������� �������� ������� ����� �����, �� ������, ���� �� ������� ���������� ������, ������� ���������� ������.

��� ��� �������?

Edit: ��� ��� ������� � Postgres ����� � ������ ������������� ������, ����������� , ��� ��� ������ ������ ����������, � �� ��� — �� ������ �� ��� �� ������� Postgres’ (�������� , �������� , �� ��������� Postgres ������������� � ����������� ��� ��� — ��)

��������: ��������� � ���� �������, ��� INSERT IGNORE ��������� �����������, ��� ��� �����, ����� ����������� ��� ������.

Edit: ������ , ��� , ��������, ���� ������������� � ���� 2013 ���� : https://bugs.php.net/bug.php? >

��� ������� pg_send_query() �� � ��������� ������� ����������� ���������� ������� � ����� ����������. ����� �� �������� ��� � ���� pgsql.c, �� ������ �����:

����� �������, ������ �������� �������� � ����� �������, ����� ����, ��� �������� ������. ��� ����������� � �����������, ��� ��� INSERT IGNORE ��������� �������� �������.

��� ���� ��� PQ_SETNONBLOCKING ������� ��������� ���������� � ������ ��� ���������� , ����� ����������� ���������� � �������� ��� ������� � ��������� �� ��������� ������������ ��������� ������������. �� ������������ PQsetnonblocking : (PQ_SETNONBLOCKING ��� ������ ��������� ���������� ��� ���� �������):

������������� ������ �������������� ����������.

������������� ��������� ���������� � �����������, ���� �������� ����� 1, ��� ������������, ���� �������� ����� 0. ���������� 0, ���� OK, -1, ���� ������.

� ������������� ���������, ������ PQsendQuery, PQputline, PQputnbytes � PQendcopy �� ����� �����������, �� ������ ����, ����� ���������� ������, ���� ��� ������ ���� ������� �����.

�������� ��������, ��� PQexec �� ���� �������������� ������; ���� �� ����������, �� ����� ����������� � ����������� ���� � ����� ������.

���������� �� �������� PQsetnonblocking (� PostgeSQLs Fe-exec.c), ���� ��� �������, ������ ����� ����� FAIL:

��� ��� ���������� ���������� ��� ��� �����, ��� pqFlush �� ���� ������� ���������, ��������� ���������� �������� � �������� ������ ����������.

������ ������ ��� �� ���������, ��� ��� ��� ��������, ����������, ������� ������ ���������� ��� ����������� ������� � ����������� �� ��� (��� �� ����� �������).

��� ��������� ������ ������, ������� ����� ��������, � ��� ���� ���������� � �� �� ���������, ���������� ��������� ����������. � �� ����, ���� ��� ����� �������� �� ����������� ������, ������� ����� �������� ������������ ��� ����������. ���� �� ������ ������ � ������������, �� �� ������� ���������� � ���� ������ � ������������ ����� / ������.

pg_send_query

(PHP 4 >= 4.2.0, PHP 5, PHP 7)

pg_send_query � Sends asynchronous query

Description

pg_send_query() sends a query or queries asynchronously to the connection . Unlike pg_query() , it can send multiple queries at once to PostgreSQL and get the results one by one using pg_get_result() .

Script execution is not blocked while the queries are executing. Use pg_connection_busy() to check if the connection is busy (i.e. the query is executing). Queries may be cancelled using pg_cancel_query() .

Although the user can send multiple queries at once, multiple queries cannot be sent over a busy connection. If a query is sent while the connection is busy, it waits until the last query is finished and discards all its results.

Илон Маск рекомендует:  chunk_split - Разбивает строку на фрагменты

Parameters

PostgreSQL database connection resource.

The SQL statement or statements to be executed.

Data inside the query should be properly escaped.

Return Values

Returns TRUE on success or FALSE on failure.

Use pg_get_result() to determine the query result.

Examples

Example #1 pg_send_query() example

= pg_connect ( «dbname=publisher» ) or die( «Could not connect» );

if (! pg_connection_busy ( $dbconn )) <
pg_send_query ( $dbconn , «select * from authors; select count(*) from authors;» );
>

$res1 = pg_get_result ( $dbconn );
echo «First call to pg_get_result(): $res1 \n» ;
$rows1 = pg_num_rows ( $res1 );
echo » $res1 has $rows1 records\n\n» ;

$res2 = pg_get_result ( $dbconn );
echo «Second call to pg_get_result(): $res2 \n» ;
$rows2 = pg_num_rows ( $res2 );
echo » $res2 has $rows2 records\n» ;
?>

The above example will output:

See Also

  • pg_query() — Execute a query
  • pg_cancel_query() — Cancel an asynchronous query
  • pg_get_result() — Get asynchronous query result
  • pg_connection_busy() — Get connection is busy or not

User Contributed Notes

pg_send_query would not stop your script from executing but it would stop the script from exiting.

= pg_connect ( ‘dbname=payroll’ );
pg_send_query ( ‘SELECT process_payroll()’ ); // Where process_payroll is a super long process
?>

You would still need to wait for the query to finish before the any display would be sent to the browser. And surprisingly, unlike pg_query this script would not generate the Maximum execution time error.

Regarding the failure to process them all now, then retrieve the results later, I found that all queries would return successfully if I added a further condition to your while loop in the «stack_query()» method.

By adding:
&& (pg_transaction_status($conn) === PGSQL_TRANSACTION_IDLE ) )

Every query executed with no errors.

= pg_connect ( «dbname=dbname host=localhost user=psql » );
if ( $conn === FALSE )
exit( «Can’t connect to db» );

$q = array();
// send some queries
foreach ( range ( 0 , 50 ) as $i )
stack_query ( $q , $conn , «SELECT ‘query $i ‘ AS str;» );
// receive them
while ( true )
<
$left = stack_query ( $q , $conn );
echo » $left left. » ;
$result = pg_get_result ( $conn );
if ( $left == 0 && $result === FALSE )
break;
$row = pg_fetch_assoc ( $result );
// depending on race conditions, you wont get all your original queries here.
echo «got $row [ str ] \n» ;
>

$conn = pg_connect ( «host=’127.0.0.1′ dbname=’test’ user=’usertest’ password=’passtest'» );

$fp = fopen ( ‘logo.gif’ , «r» );
$buffer = fread ( $fp , filesize ( ‘logo.gif’ ));
fclose ( $fp );

pg_exec ( $conn , «begin» );

$oid = pg_locreate ( $conn );

$rs = pg_exec ( $conn , «INSERT INTO test(tipo, images) VALUES(‘A1’, $oid );» );
$handle = pg_loopen ( $conn , $oid , «w» );

pg_lowrite ( $handle , $buffer );
pg_loclose ( $handle );

pg_exec ( $conn , «commit» );

$rs = pg_exec ( $conn , «SELECT images FROM test WHERE tipo = ‘A1’;» );
$row = pg_fetch_row ( $rs , 0 );

pg_exec ( $conn , «begin» );
$loid = pg_loopen ( $conn , $row [ 0 ], «r» );

header ( «Content-type: image/gif» );

pg_loreadall ( $loid );
pg_loclose ( $loid );

pg_exec ( $conn , «commit» );

pg_exec ( $conn , «begin» );

$loid = $row [ 0 ];
pg_lounlink ( $conn , $loid );

pg_exec ( $conn , «commit» );

pg_exec ( $conn , «DELETE FROM test WHERE tipo = ‘A1’;» );

Due to a bug, OLD API does not available with PHP 4.2.0 and 4.2.1.

PHP 4.2.2 will support OLD API again and will be kept long enough.

New API will be available PHP 4.2.0 to later versions.
yohgaki at php dot net
19-Jun-2002 04:00
Due to a bug, PHP 4.2.0 and 4.2.1 does not support pg_lo_import() old API. It’s fixed in PHP 4.2.2.

BTW, new API will be always available from PHP 4.2.0 to later versions. Older API will be kept long enough, also.
ceco at noxis dot net
15-May-2002 09:08
it works for me (php-4.2.1)

int pg_lo_import ( string pathname [, resource connection])

but
int pg_lo_import ( resource connection, string pathname )

don’t know the reason

If there is an error in one of your queries, the queries following it will not get executed, and there will *not* be an error message displayed. The only way I can think of to determine if an SQL error happened is to use pg_trace.

pg_send_query($connection,
«SELECT id FROM users;
SELECT * FROM customers;
[INVALID-SQL-STATEMENT];
SELECT name FROM countries;»);

while ($result = pg_get_result($connection))
$results[] = $result;

The $results array will only have two items in it.

Note that if you send a query without calling pg_get_result() for the previous one (supposing it has finished and the connection is not busy), the previous query will get discarded.

See for yourself (tested on php4.4.0, postgres8.0.4, Linux/FreeBSD) :

You will have to write a higher level of abstraction if you want a «send all queries now, receive them later» behaviour.

pg_send_query (): �� ������� ���������� ���������� � ����� ����������?

� ���� ���� ������� script, �������, ��� ��������������, ������� �������� � ��������� ������ ������ NOTICE: pg_send_query(): �� ������� ���������� ���������� � ������� ����������

�������, ��� �� ���������� ���������� ������� �����, �� ������, ������� �� �� ���������� ������, ������� ���������� ������.

��� ��� �� �������?

��������: � ������� postgres ��� ������� � ������ ������������� ������, �����������, ��� ��� ������ ������ ����������, � �� ���-�� �� ��� �� ������� postgres (��������, ��������, �� ��������� postgres ���� � ���������� ��� ���-�� � ���� ����)

��������:. ��������� � ���� ������, ��� ���������� INSERT �����������, ��� ��� �����, ����� ��� ������ �����������.

��������: ������, ��� ����� ���� ���������� � ���� 2013 ����: https://bugs.php.net/bug.php? >

6 �������

��� ������� pg_send_query() ������������� ������� ����������� ���������� ������� � ����� ����������. ��������� �������� ��� �� PHP pgsql.c, �� ������ �����:

����� �������, ������ ��������� � ����� ������� ����� ���������� �������� ������. ��� ������������� ������ ����������, ��� ���� ���������� INSERT �����������.

��� ���� ���� ������� PQ_SETNONBLOCKING ����������� � ���, ����� ��������� ���������� � ������������� �����, ����� ��������� ����������� ���������� � ������� ��� ������� � ����� ���������� �� ���������. �� ������������ �� PQsetnonblocking: (PQ_SETNONBLOCKING — ��� ������ ���������, ������������ ��� ���� �������):

������������� ������������� ������ ����������.

������������� ��������� ���������� ��� ��������������, ���� arg ����� 1, ��� ������������, ���� arg ����� 0. ���������� 0, ���� OK, -1, ���� ������.

Илон Маск рекомендует:  Что значит статус Онлайн и Оффлайн

� ������������� ��������� ������ PQsendQuery, PQputline, PQputnbytes, � PQendcopy �� ����� �����������, �� ������ ����� ���������� ������, ���� ��� ����������� ��� ���������� ������.

�������� ��������, ��� PQexec �� ���� ������������� �����; ���� �� ����������, ��� � ����� ������ ����� ����������� � ����������� �����.

���� �� ���������� �� �������� PQsetnonblocking (� PostgeSQLs fe-exec.c), ���� ��� ��������� ������� ������ ������:

����� �������, ���� ���������� �����-�� ������� ����������, ���� pqFlush �� ����������� �������, ������ ���������� �������� � �������� ������ ����������.

������ ������ ��� �� ����������, ��� ��� ��� script, ����������, ������� ���������� ���������� ��� ����������� ������� � ����������� �� ��� (��� �� ������ ����� ��������).

��� ��������� ������ ������, ��� ��������, ��� � ��� ���� ���������� � ���������, �������� �� ��������������. � �� ����, �������� �� ��� �� ����������� ������, ������� ����� �������� ������������ ��� ����������. ���� �� ������ ��������� ������, �� ������ ������� ���������� � ���� ������ � ������������ �����/������.

��� �������� ��� ������ SQL ��� ���������� ������� Postgres � php-�������

��� �������� ��� ������ SQL, �������� �23505 unique_violation� � Postgres � php. � ���� ��������� ����������������� ������ ��� �������������� ������ � �������� ���������� ��� ������ SQL, ������������ ��������.

� �� ���� ������������ pg_last_error, ������ ���, ���� ��������� �������� �������� ������, ������������ ���������� ����� ���� ����������. � � �� ���� ������������ pg_send_query, ������ ��� ����������� ���������� �� �������� � ���� ��������.

��� ������ �������, ��� �������� � ����� �� �������� ���������� ��� ������ SQL.

pg_send_query (): �� ������� ���������� ���������� � ����� ����������?

December 2020

9.3k ���

� ���� ���� ������ ��������, �������, �������, ������ �������� ��������� ��������� �� ������ ����������� ������: pg_send_query (): �� ������� ���������� ���������� � ����� ����������

���, �������, ���������� �������� ������� ����� �����, �� ������, ���� �� ������� ���������� ������, ������� ���������� ������.

��� ��� �������?

Edit: ��� ��� ������� � Postgres ����� � ������ ������������� ������, ����������� , ��� ��� ������ ������ ����������, � �� ��� — �� ������ �� ��� �� ������� Postgres’ (�������� , �������� , �� ��������� Postgres ������������� � ����������� ��� ��� — ��)

��������: ��������� � ���� �������, ��� ��������� INSERT �����������, ��� ��� �����, ����� ����������� ��� ������.

Edit: ������ , ��� , ��������, ���� ������������� � ���� 2013 ���� : https://bugs.php.net/bug.php? >

6 ������

� ������� ���� ����� �� ��������, � � ������� ������ Opels ������ �����, ��� PHP �� ����� ���� �� �����, ���� ����� ��� �������� ����� ���������� ���������� ������� � ����� ����������.

��� ����� ���������� ���������� � ������ ���������� ����������� ����������� � ���������� �������� ��������� ��� ���������� ������ �������� (�������� � ��������� � ����� ������, ��� ����������). � �������� ��������� � �����������, ��� ��� ������� �� ��������, � �������� �����������.

���� �� �� ����� ���� ����� ����������� ����� , � ����� ����������� ���� �� https://bugs.php.net/bug.php? >

� ���������� � ��� �� ���������� �� ������ � PHP 5.6.9

��� ���������� , ����� ���������� ���������� ������� pg_pconnect () �������� � pgsql.auto_reset_persistent ���������� � ��������� Off .

���������� ����� ��������, �����:

  1. PHP Session ��������
  2. ����������� � �� ������� ��������
  3. ���-������ / ������ �� ���������������

�� ������ ��������� php.ini ��� pgsql.auto_reset_persistent � ���������� ��� � On .

pgsql.auto_reset_persistent ��������, ������ ��� , ����� pg_pconnect () ����������, ������ ���������� �����������, ���� �� �������� � ����. ��� ������� ��������� ������, �� ��������� �� ������ ��� Fixies conncetion ��������.

������ , ��� �� ��������� ������������ pg_send_query() ������� �������� ����������� �������� � PostgreSQL. ���� ���� ������� , ����� ��� PHP ������ , ����� ���������� ���������� ������� ���� �� ����� �������� PostgreSQL ��������� ������ � ������� ��������� �����.

������ , ����������� � ������������ ��� pg_send_query() ������������ , ��� �� �� ������ ��������� ������ , ���� PostgreSQL ��� ���� ������ ������:

���� �� ������� , ��� �� ����������� pg_send_query() ������ pg_query() ? ���� �� ������ ��������� �������� , ����� ����������� �������� ���������� �������, � ����������� , (������ , �� ���������� ���) , ��� �� �� ������ ������ ��� ������.

� ������� ��� ������ ����. � ������ ��� �������� ����� ������������ ���-������� (Apache).

��� ����� ��������� , ���� �� ����������� ���� � ���������� ������������ ��������. ���� ��� ��� , �� ����� �� ������������ , PGSQL_CONNECT_FORCE_NEW ��� ���:

��� �������� ����� ������ ���������� � ����� ������ , �� ����� � ����: �� ������ ��������� �� ���������� �������� , ������� ��������� ��������� ��� ������ ���� , ��� ��� �� �������� ������������ pg_close() .

��� ������� pg_send_query() �� � ��������� ������� ����������� ���������� ������� � ����� ����������. ����� �� �������� ��� � ���� pgsql.c, �� ������ �����:

����� �������, ������ �������� �������� � ����� �������, ����� ����, ��� �������� ������. ��� ����������� � �����������, ��� ���� ��������� INSERT �������� �����������.

��� ���� ��� PQ_SETNONBLOCKING ������� ��������� ���������� � ������ ��� ���������� , ����� ����������� ���������� � �������� ��� ������� � ��������� �� ��������� ������������ ��������� ������������. �� ������������ PQsetnonblocking : (PQ_SETNONBLOCKING ��� ������ ��������� ���������� ��� ���� �������):

������������� ������ �������������� ����������.

������������� ��������� ���������� � �����������, ���� �������� ����� 1, ��� ������������, ���� �������� ����� 0. ���������� 0, ���� OK, -1, ���� ������.

� ������������� ���������, ������ PQsendQuery, PQputline, PQputnbytes � PQendcopy �� ����� �����������, �� ������ ����, ����� ���������� ������, ���� ��� ������ ���� ������� �����.

�������� ��������, ��� PQexec �� ���� �������������� ������; ���� �� ����������, �� ����� ����������� � ����������� ���� � ����� ������.

���������� �� �������� PQsetnonblocking (� PostgeSQLs Fe-exec.c), ���� ��� �������, ������ ����� ����� FAIL:

��� ��� ���������� ���������� ��� ��� �����, ��� pqFlush �� ���� ������� ���������, ��������� ���������� �������� � �������� ������ ����������.

������ ������ ��� �� ���������, ��� ��� ��� ��������, ����������, ������� ������ ���������� ��� ����������� ������� � ����������� �� ��� (��� �� ����� �������).

��� ��������� ������ ������, ������� ����� ��������, � ��� ���� ���������� � �� �� ���������, ���������� ��������� ����������. � �� ����, ���� ��� ����� �������� �� ����������� ������, ������� ����� �������� ������������ ��� ����������. ���� �� ������ ������ � ������������, �� �� ������� ���������� � ���� ������ � ������������ ����� / ������.

Понравилась статья? Поделиться с друзьями:
Кодинг, CSS и SQL