0

sqlite データベースにリンクしようとしている C++ 広告は初めてです。私はチュートリアルに従っていますが、sqlite3_open エラー Undefined Reference が発生しています。私は何を間違っていますか?

#include "database.h"
#include<stdio.h>
#include<sqlite3.h>
#include<stdlib.h>

database::database()
{
}

int database::test()
{
int retval;

// A prepered statement for fetching tables
sqlite3_stmt *stmt;

// Create a handle for database connection, create a pointer to sqlite3
sqlite3 *handle;

// try to create the database. If it doesnt exist, it would be created
// pass a pointer to the pointer to sqlite3, in short sqlite3**
retval = sqlite3_open("CC.sqlite",&handle);
// If connection failed, handle returns NULL
if(retval)
{
printf("Database connection failed\n");
return -1;
}
printf("Connection successful\n");
return 1;
}

.pro ファイル

#-------------------------------------------------
#
# Project created by QtCreator 2013-05-31T09:22:09
#
#-------------------------------------------------

QT       += core gui

greaterThan(QT_MAJOR_VERSION, 4): QT += widgets

TARGET = CC_Herd_Manager
TEMPLATE = app


SOURCES += main.cpp\
    mainwindow.cpp \
animal.cpp \
email.cpp \
owner.cpp \
phone.cpp \
equipment.cpp \
../CC_Cpp/cc_number.cpp \
../CC_Cpp/cc_date.cpp \
../CC_Cpp/cc_timestamp.cpp \
../CC_Cpp/cc_address.cpp \
database.cpp

HEADERS  += mainwindow.h \
animal.h \
email.h \
owner.h \
phone.h \
equipment.h\
../CC_Cpp/cc_number.h \
../Cpp/CC_Cpp/cc_date.h \
../Cpp/CC_Cpp/cc_timestamp.h \
../Cpp/CC_Cpp/cc_address.h \
database.h

FORMS    += mainwindow.ui

OTHER_FILES += \
DB_Install

エラー

/home/mongo/Cpp/CC_Herd_Manager/database.o:-1: In function `database::test()':
/home/mongo/Cpp/CC_Herd_Manager/database.cpp:23: error: undefined reference to     `sqlite3_open'
:-1: error: collect2: error: ld returned 1 exit status
4

1 に答える 1

4

システムの sqlite バージョン (おそらくこれが最適) に再度リンクする場合は、次の行を .pro ファイルに追加する必要があります。

LIBS += -lsqlite3

そしてそれはそれであるべきです。

また、sqlite のソース (「融合」と呼ばれる) をダウンロードして、プロジェクトに .c ファイルを追加することもできます。その場合は、ダウンロードしたヘッダー ファイルも使用する必要があります。ただし、コードでシステムのヘッダー ファイルを使用するため、システムのライブラリ バージョンを使用することをお勧めします。

于 2013-06-07T20:28:46.047 に答える