zval *pgsql_link, *values;
char *table, *sql = NULL;
int table_len;
- ulong option = PGSQL_DML_EXEC;
+ ulong option = PGSQL_DML_EXEC, return_sql;
PGconn *pg_link;
+ PGresult *pg_result;
+ ExecStatusType status;
+ pgsql_result_handle *pgsql_handle;
int id = -1, argc = ZEND_NUM_ARGS();
if (zend_parse_parameters(argc TSRMLS_CC, "rsa|l",
if (php_pgsql_flush_query(pg_link TSRMLS_CC)) {
php_error_docref(NULL TSRMLS_CC, E_NOTICE, "Detected unhandled result(s) in connection");
}
- if (php_pgsql_insert(pg_link, table, values, option, &sql TSRMLS_CC) == FAILURE) {
+ return_sql = option & PGSQL_DML_STRING;
+ if (option & PGSQL_DML_EXEC) {
+ /* return resource when executed */
+ option = option & ~PGSQL_DML_EXEC;
+ if (php_pgsql_insert(pg_link, table, values, option|PGSQL_DML_STRING, &sql TSRMLS_CC) == FAILURE) {
+ RETURN_FALSE;
+ }
+ pg_result = PQexec(pg_link, sql);
+ if ((PGG(auto_reset_persistent) & 2) && PQstatus(pg_link) != CONNECTION_OK) {
+ PQclear(pg_result);
+ PQreset(pg_link);
+ pg_result = PQexec(pg_link, sql);
+ }
+ efree(sql);
+
+ if (pg_result) {
+ status = PQresultStatus(pg_result);
+ } else {
+ status = (ExecStatusType) PQstatus(pg_link);
+ }
+
+ switch (status) {
+ case PGRES_EMPTY_QUERY:
+ case PGRES_BAD_RESPONSE:
+ case PGRES_NONFATAL_ERROR:
+ case PGRES_FATAL_ERROR:
+ PHP_PQ_ERROR("Query failed: %s", pg_link);
+ PQclear(pg_result);
+ RETURN_FALSE;
+ break;
+ case PGRES_COMMAND_OK: /* successful command that did not return rows */
+ default:
+ if (pg_result) {
+ pgsql_handle = (pgsql_result_handle *) emalloc(sizeof(pgsql_result_handle));
+ pgsql_handle->conn = pg_link;
+ pgsql_handle->result = pg_result;
+ pgsql_handle->row = 0;
+ ZEND_REGISTER_RESOURCE(return_value, pgsql_handle, le_result);
+ return;
+ } else {
+ PQclear(pg_result);
+ RETURN_FALSE;
+ }
+ break;
+ }
+ } else if (php_pgsql_insert(pg_link, table, values, option, &sql TSRMLS_CC) == FAILURE) {
RETURN_FALSE;
}
- if (option & PGSQL_DML_STRING) {
+ if (return_sql) {
RETURN_STRING(sql, 0);
}
RETURN_TRUE;
#if HAVE_PGSQL
+#define PHP_PGSQL_API_VERSION 20140217
+
extern zend_module_entry pgsql_module_entry;
#define pgsql_module_ptr &pgsql_module_entry
#define PGSQL_DML_STRING (1<<11) /* Return query string */
#define PGSQL_DML_ESCAPE (1<<12) /* No convert, but escape only */
+
/* exported functions */
PHP_PGSQL_API int php_pgsql_meta_data(PGconn *pg_link, const char *table_name, zval *meta, zend_bool extended TSRMLS_DC);
PHP_PGSQL_API int php_pgsql_convert(PGconn *pg_link, const char *table_name, const zval *values, zval *result, ulong opt TSRMLS_DC);
pg_insert($db, $table_name, $fields) or print "Error in test 1\n";
echo pg_insert($db, $table_name, $fields, PGSQL_DML_STRING)."\n";
echo pg_insert($db, $table_name, $fields, PGSQL_DML_STRING|PGSQL_DML_ESCAPE)."\n";
+var_dump( pg_insert($db, $table_name, $fields, PGSQL_DML_EXEC) ); // Return resource
echo "Ok\n";
?>
---EXPECT--
+--EXPECTF--
INSERT INTO "php_pgsql_test" ("num","str","bin") VALUES (1234,E'AAA',E'\\x424242');
INSERT INTO "php_pgsql_test" ("num","str","bin") VALUES ('1234','AAA','BBB');
+resource(%d) of type (pgsql result)
Ok
\ No newline at end of file