PQescapeLiteral не определен? - PullRequest
1 голос
/ 07 января 2011

Это самый простой пример libpq, который я мог придумать, чтобы проиллюстрировать мою проблему. Цель здесь - просто распечатать экранированную строку.

#include <iostream>
#include <libpq-fe.h>
#include <string.h>

using namespace std;

int main(){
    PGconn *db;
    char connstring[] = "dbname=TheInternet";
    db = PQconnectdb(connstring);
    char url[] = "http://www.goo'gle.com/";
    cout<<PQescapeLiteral(db, (const char *)url, (size_t) strlen(url))<<"\n";
}

Когда я компилирую с:

g++ PQescapeLiteral_test.cpp -lpq 

или даже с:

g++ PQescapeLiteral.cpp -I/usr/include/pgsql:/usr/include/pgsql/server:/usr/include/pgsql/server/libpq -lpq

Я получаю ошибку:

PQescapeLiteral.cpp: In function ‘int main()’:
PQescapeLiteral.cpp:12: error: ‘PQescapeLiteral’ was not declared in this scope

Я нашел PQescapeLiteral в руководстве по pgsql 9.0 в разделе 31.3.4. Экранирование строк для включения в команды SQL. У меня самая последняя версия libpq и libpq-devel от yum, поэтому я почти уверен, что она должна быть определена.

Если кто-то может указать мне правильное направление, я буду признателен.

1 Ответ

1 голос
/ 07 января 2011

У меня отлично работает, с заголовками PostgreSQL 9.0.1.Какую версию заголовочных файлов и библиотек postgresql вы используете?PQescapeLiteral, очевидно, был добавлен в 9.0: http://developer.postgresql.org/pgdocs/postgres/release-9-0.html#AEN104548

Где вы ожидаете, что libpq.so будет?Вы показываете команду компилятора с ключами -I, чтобы найти файлы заголовков в нестандартном месте, но нет соответствующего ключа -L, чтобы найти библиотеку.

...