Поиск:

Ответ в темуСоздание новой темы Создание опроса
> SQLite и С++, Давайте поработаем здесь 
:(
    Опции темы
Coocky
Дата 4.8.2005, 17:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


GUI гуру
****


Профиль
Группа: Участник Клуба
Сообщений: 2879
Регистрация: 16.2.2004
Где: Украина. Запорожь е

Репутация: 2
Всего: 62




Нет, тут есть проблемка, все таки, запросы правильные...
Серега, ты хоть отвечай, а то я сам с собой болтаю....

Это сообщение отредактировал(а) Coocky - 4.8.2005, 17:53


--------------------
Верю в смерть после жизни, в любовь после секса ,в крем после бритья smile        
PM ICQ   Вверх
Coocky
Дата 4.8.2005, 17:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


GUI гуру
****


Профиль
Группа: Участник Клуба
Сообщений: 2879
Регистрация: 16.2.2004
Где: Украина. Запорожь е

Репутация: 2
Всего: 62



sergej.z
А вот действительно проблема
И так, запускаем твою прогу первый раз.Все нормально..
Теперь коменнтируем добавление записей..Я их удалю
Код

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

int myCallback(void*,int,char**, char**);
int main(int argc, char **argv){
  sqlite3 *db;
  char *zErrMsg = 0;
  int rc;

char * Name="Base";

    rc = sqlite3_open(Name,&db);

  rc=sqlite3_exec(db, "select * from test;", myCallback, NULL, &zErrMsg);
 if(rc!=SQLITE_OK)
  {
      printf( "%s\n", zErrMsg);
      return 1;
     }

  
   sqlite3_close(db);
  return 0;
}

static int myCallback(void *NotUsed, int columns, char **pazValue, char **pazColName){
 int i;
 for(i=0; i<columns; i++){
  printf("%s(%s)=%s |",pazColName[i],pazColName[i+columns],pazValue[i] ? pazValue[i]:"NULL");
 }
 printf("\n");

 return 0;


Вот тут и проблема, записи все пустые, такое ощущение, что все перезаписывется, в чем проблема?

Это сообщение отредактировал(а) Coocky - 4.8.2005, 17:50


--------------------
Верю в смерть после жизни, в любовь после секса ,в крем после бритья smile        
PM ICQ   Вверх
sergejzr
Дата 4.8.2005, 20:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Un salsero
Group Icon


Профиль
Группа: Админ
Сообщений: 13285
Регистрация: 10.2.2004
Где: Германия г .Ганновер

Репутация: 2
Всего: 360



Привет smile Я отвечать могу только рано утром и поздно вечером smile Уж сорри smile

Цитата(Coocky @ 4.8.2005, 16:48)
sergej.z
А вот действительно проблема
И так, запускаем твою прогу первый раз.Все нормально..
Теперь коменнтируем добавление записей..Я их удалю

Нет, всё нормально. Просто надо после добавления выполнить commit. Тогда все изменения действительно войдут в силу.
Я исправил код - пример. Обрати внимание на добавленный:
Код

/*
Добавлено!!!!!!
Commit - база перенимает все изменения
*/
rc=sqlite3_exec(db, "commit;", NULL, NULL, &zErrMsg);


Это главное. теперь пройдусь по предыдущим постам smile

Цитата(Coocky @ 4.8.2005, 11:19)
B в смысле библиотеку подключить sqlite3.dll?
А пример под либу можешь преписать? smile

Либу чтобы подключить, ничего переписывать не надо. Она ведь тоже самое, что и скомпилленые обьекты.
А вот чтобы длль подсоеденить, надо ессно писать подгрузку функций из неё. Если время будет, добавлю так же.

Цитата(Coocky @ 4.8.2005, 11:55)
Появилась библиотека
Dima.dll
Я так понял это моя база?

Ты имеешь ввиду понвился файл Dima.db smile
Да, это и есть файл базы.

Цитата(Coocky @ 4.8.2005, 11:55)
Вообще,sergej.z,
может вкратце описать создание базы, открытие, выполнение всех запросов, закрытие smile

Дык в примере вроде всё описано в комментарах
Цитата(Coocky @ 4.8.2005, 13:18)
Так, все нормально, теперь вопрос, как ходить по записям, кроме как
int myCallback(void*,int,char**, char**);

sqlite3_prepare(), sqlite3_step(). Примеры по линьку, который я давал в одном из первых сообщений. Время будет, добавлю свой пример. Пока очень занят..

Цитата(Coocky @ 4.8.2005, 15:49)
Все нормально i, возвращает ноль, а вот до функции дело не доходит...

Наверное записей нет таких.



--------------------
PM WWW IM ICQ Skype GTalk Jabber AOL YIM MSN   Вверх
Coocky
Дата 5.8.2005, 11:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


GUI гуру
****


Профиль
Группа: Участник Клуба
Сообщений: 2879
Регистрация: 16.2.2004
Где: Украина. Запорожь е

Репутация: 2
Всего: 62



sergej.z
Держи плюс smile
Да, и еще забыл спросить, нормально будет работать со статической компоновкой?
Я вроде у других проверял, так файл без расширения dll...
И еще,sergej.z, я что-то плохо понимаю, но не нахожу техх нюансов , в мануале, типа commit...
Если можно, напиши, а я пока по MFC пройдусь smile


--------------------
Верю в смерть после жизни, в любовь после секса ,в крем после бритья smile        
PM ICQ   Вверх
sergejzr
Дата 5.8.2005, 14:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Un salsero
Group Icon


Профиль
Группа: Админ
Сообщений: 13285
Регистрация: 10.2.2004
Где: Германия г .Ганновер

Репутация: 2
Всего: 360



Цитата(Coocky @ 5.8.2005, 10:13)
Да, и еще забыл спросить, нормально будет работать со статической компоновкой?

Да, конечно. У всего есть свои плюсы и минусы. например Длльку можно будет быстро заменить при апдейте, за это надо её всегда за собой таскать + подгружать каждый раз. Статическая компоновка позволит сделать один файл, но при обновлении самой SQLite Всё надо будет заного компилить. Хотя конечно, если тебя сегодняшняя версия устраивает, зачем вообще обновлять? smile
Цитата(Coocky @ 5.8.2005, 10:13)
И еще,sergej.z, я что-то плохо понимаю, но не нахожу техх нюансов , в мануале, типа commit...

Ну это вообще то теория баз данных. С библиотекой имеет мало общего, разве что последняя её имплементирует.
begin-> начало трансакции commit -> конец трансакции. Это в любой нормальной БД. Почитай какую нибудь литературу по теории БД.






--------------------
PM WWW IM ICQ Skype GTalk Jabber AOL YIM MSN   Вверх
sergejzr
Дата 5.8.2005, 16:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Un salsero
Group Icon


Профиль
Группа: Админ
Сообщений: 13285
Регистрация: 10.2.2004
Где: Германия г .Ганновер

Репутация: 2
Всего: 360



Итак пример первый теперь с возможностью динамической подгрузки и использования sqlite3_step();(пример 2)
Осталась небольшая непонятка. В callback поидее с расстоянием в columns должны лежать типы данных. Но это не так. Где их там взять - ума не приложу. sqlite3_step работает отлично. Да и я бы его рекомендовал конечно вместо callback. И интерфейс его в этой версии намного удобней smile



Код

#include <stdio.h>
#include <windows.h>

/*
Конечно SQLite можно загрузить из DLL или же Link Lib(?).
*/
#define  SQLITEDLL

#ifdef SQLITEDLL
#define SQLITE_OK      0  /* Successful result */
#define SQLITE_ERROR    1  /* SQL error or missing database */
#define SQLITE_ROW     100 /* sqlite_step() has another row ready */
#define SQLITE_DONE    101 /* sqlite_step() has finished executing */
#define SQLITE_DENY   1   /* Abort the SQL statement with an error */
#define SQLITE_IGNORE 2   /* Don't allow access, but don't generate an error */

typedef int (*sqlite3_callback)(void*,int,char**, char**);
typedef struct sqlite3 sqlite3;
typedef struct sqlite3_stmt sqlite3_stmt;
typedef int (*sqlite3_close_dll)(sqlite3 *);
typedef int (__cdecl * sqlite3_open_dll)(
  const char *filename,   /* Database filename (UTF-8) */
  sqlite3 **ppDb          /* OUT: SQLite db handle */
);
typedef int (__cdecl * sqlite3_exec_dll)(
  sqlite3*,                     /* An open database */
  const char *sql,              /* SQL to be executed */
  sqlite3_callback,             /* Callback function */
  void *,                       /* 1st argument to callback function */
  char **errmsg                 /* Error msg written here */
);

typedef int (__cdecl * sqlite3_errcode_dll)(sqlite3 *db);
typedef const char * (__cdecl * sqlite3_errmsg_dll)(sqlite3*);


typedef int (__cdecl * sqlite3_prepare_dll)(
  sqlite3 *db,            /* Database handle */
  const char *zSql,       /* SQL statement, UTF-8 encoded */
  int nBytes,             /* Length of zSql in bytes. */
  sqlite3_stmt **ppStmt,  /* OUT: Statement handle */
  const char **pzTail     /* OUT: Pointer to unused portion of zSql */
);
typedef int (__cdecl * sqlite3_column_count_dll)(sqlite3_stmt *pStmt);
typedef const void * (__cdecl * sqlite3_column_name_dll)(sqlite3_stmt*,int);
typedef const char * (__cdecl * sqlite3_column_decltype_dll)(sqlite3_stmt*,int);
typedef const unsigned char * (__cdecl * sqlite3_column_text_dll)(sqlite3_stmt*,int);

typedef int (__cdecl * sqlite3_step_dll)(sqlite3_stmt*);
typedef int (__cdecl * sqlite3_finalize_dll)(sqlite3_stmt *pStmt);

sqlite3_exec_dll sqlite3_exec;
sqlite3_open_dll sqlite3_open;
sqlite3_close_dll    sqlite3_close;

sqlite3_errmsg_dll    sqlite3_errmsg;
sqlite3_prepare_dll   sqlite3_prepare;
sqlite3_step_dll   sqlite3_step;
sqlite3_finalize_dll sqlite3_finalize;

sqlite3_column_count_dll sqlite3_column_count;
sqlite3_column_name_dll sqlite3_column_name;
sqlite3_column_decltype_dll sqlite3_column_decltype;
sqlite3_column_text_dll sqlite3_column_text;

HINSTANCE    SQLiteDLL;
#else
#include "sqlite3.h"
#endif
int myCallback(void*,int,char**, char**);
int init();
void finish();

int main(int argc, char **argv){
  sqlite3 *db;
  char *zErrMsg = 0;
  int rc;
   if( init()!=0)
 {
 printf("DLL's not loaded ");
 return 1;
 }

  
  /*arg1: Моя_БД.db есть файл БД. Если его несуществует, SQLite сама его создаст.
   arg2: указатель на структуру нашего БД
../Где_Угодно/Моя_БД.db
*/
  //  argv[1]="test.bd";
 rc = sqlite3_open(argv[1], &db);
 /*
 Если было невозможно создать файлик то rc содержит номер ошибки.
*/
 if( rc ){
    fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
    sqlite3_close(db);
    return 1;
  }
 /*
Всё в порядке, можно работать!
В SQLite существует два способа получения результата БД.
1. exec/callback
        Функция callback будет вызываться SQLite с каждой строкой от ResultSet'a
        Чем то похоже Listener на в JAVA
2. compile/step/finalize
        в этом случае можно забирать ResultSet строка за строкой
Пока не разобрался с новой версией :)
*/
 /*
рассмотрим sqlite_exec
arg1: Наша БД
arg2: SQL statement
arg3: Функция callback (Здесь нам не нужна).
arg4: Аргумент, который будет передаваться в функцию callback. Например вектор, в который мы хотим добавлять результат,
  или вообще указатель на какой нибудь обьект (Здесь нам не нужeн).
arg5: Сообщение об ошибке. Его можно распечатать, но только если возвращённый rc!=0.
Накидаем табличку
*/
 rc=sqlite3_exec(db, "create table test(num integer,name string);", NULL, NULL, &zErrMsg);
 /*
if(rc!=SQLITE_OK)
{
 printf( "%s\n", zErrMsg);
    return 1;
}
*/
 /*
 При импорте данных очень важно начать с begin иначе БД будет тормозить.
   Обьяснение: Все записи будут осуществляться в памяти и только с commit писаться на диск.
   После этого SQLite проверит, всё ли записано правильно.
   Без beginn'a это будет осуществляться при каждой записи
*/
 rc=sqlite3_exec(db, "begin;", NULL, NULL, &zErrMsg);
 for(int i=0;i<10;i++)
     {
 /*
 На оригинальность не претендую :)
*/
 char sqlText[200];
 sprintf(sqlText,"insert into test values(%i,'name_%i');",i,i);
 rc=sqlite3_exec(db, sqlText, NULL, NULL, &zErrMsg);
  if(rc!=SQLITE_OK)
      {
      printf( "%s\n", zErrMsg);
    break;
      }
    }
/*
Добавлено!!!!!!
Commit - база перенимает все изменения
*/
rc=sqlite3_exec(db, "commit;", NULL, NULL, &zErrMsg);
 /*
произведём селект способом 1:
*/
 printf("\n exec/callback \n");
 rc=sqlite3_exec(db, "select * from test;", myCallback, NULL, &zErrMsg);
 if(rc!=SQLITE_OK)
  {
      printf( "%s\n", zErrMsg);
      return 1;
     }
  
/*
  произведём SELECT способом 2:
*/
 const char *sqlText="select * from test;";
 /*
 ppVm непрозрачная структура виртуальной машины. В некоторых случаях я исползьовал несколько таких машин,
   чтобы опрашивать несколько разных ResultSet'ов.
*/
 sqlite3_stmt *ppVm;
 /*
 рассмотрим sqlite_compile
 arg1:Наша БД
 arg2:SQL statement
 arg3:Длинна запроса. Если -1, то SQLite сама определит её
 arg4:Виртуальная машинка.
 arg5:Остаток запроса после выполнения.
*/
 rc=sqlite3_prepare(db, sqlText,-1,&ppVm,&sqlText);
 if(rc!=SQLITE_OK)
       {
       printf( "%s\n", zErrMsg);
     return 1;
      }
    printf("\n compile/step/finalize \n");

    /*sqlite3_column_count отдаст количество колонок в результате*/
    int colcount=sqlite3_column_count(ppVm);
  /*
    рассмотрим sqlite_step
    arg1:Виртуальная машинка
    Она везде передаётся. Таким образом можно выполнять кучу запросов одновременно.
 */
 
 while(sqlite3_step(ppVm)!=SQLITE_DONE)
 {

  for(int i=0;i<colcount;i++)
  {
  
  printf("%s(%s)=%s |",sqlite3_column_name(ppVm,i), sqlite3_column_decltype(ppVm,i), sqlite3_column_text(ppVm,i));
  }
 printf("\n");

 }
 /*destructor Виртуальной машины*/
 rc=sqlite3_finalize(ppVm);

 

  sqlite3_close(db);
  finish();
  return 0;
}

static int myCallback(void *NotUsed, int columns, char **pazValue, char **pazColName){
 int i;
 for(i=0; i<columns; i++){
     /*
     Раньше был отступ в columns для типов данных..Сейчас вроде по другому, но как, пока не разобрался..
     */
  printf("%s(%s)=%s |",pazColName[i],pazColName[i+columns],pazValue[i] ? pazValue[i]:"NULL");
 }
 printf("\n");
finish();
 return 0;
}

int init()
{
#ifdef SQLITEDLL
 HINSTANCE    SQLiteDLL = LoadLibrary("sqlite3.dll");
     sqlite3_exec=((sqlite3_exec_dll) GetProcAddress (SQLiteDLL, "sqlite3_exec"));
     sqlite3_open=((sqlite3_open_dll) GetProcAddress (SQLiteDLL, "sqlite3_open"));
     sqlite3_step=((sqlite3_step_dll) GetProcAddress (SQLiteDLL, "sqlite3_step"));
     sqlite3_finalize=((sqlite3_finalize_dll) GetProcAddress (SQLiteDLL, "sqlite3_finalize"));
     sqlite3_close=((sqlite3_close_dll) GetProcAddress (SQLiteDLL, "sqlite3_close"));

    sqlite3_errmsg=((sqlite3_errmsg_dll) GetProcAddress (SQLiteDLL, "sqlite3_errmsg"));
    sqlite3_prepare=((sqlite3_prepare_dll) GetProcAddress (SQLiteDLL, "sqlite3_prepare"));
    sqlite3_column_count=((sqlite3_column_count_dll) GetProcAddress (SQLiteDLL, "sqlite3_column_count"));
    sqlite3_column_name=((sqlite3_column_name_dll) GetProcAddress (SQLiteDLL, "sqlite3_column_name"));
    sqlite3_column_decltype=((sqlite3_column_decltype_dll) GetProcAddress (SQLiteDLL, "sqlite3_column_decltype"));
    sqlite3_column_text=((sqlite3_column_text_dll) GetProcAddress (SQLiteDLL, "sqlite3_column_text"));
    


     return SQLiteDLL==NULL ? 1:0;
#endif
 return 0;
}


void finish()
{
#ifdef SQLITEDLL
 if(SQLiteDLL!=NULL)
 FreeLibrary(SQLiteDLL);
#endif
}



--------------------
PM WWW IM ICQ Skype GTalk Jabber AOL YIM MSN   Вверх
Coocky
Дата 5.8.2005, 18:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


GUI гуру
****


Профиль
Группа: Участник Клуба
Сообщений: 2879
Регистрация: 16.2.2004
Где: Украина. Запорожь е

Репутация: 2
Всего: 62



sergej.z
Найди ошибку...
(не создается первичный ключ)
Код

// TestSQL.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"
#include <stdio.h>
#include "sqlite3.h"
#include <windows.h>
int myCallback1(void*,int,char**, char**);
int _tmain(int argc, _TCHAR* argv[])
{
sqlite3 *db;
  char *zErrMsg = 0;
  int rc;


char*name="Dima2.db";
  
 rc = sqlite3_open(name, &db);
 
 if( rc ){
    fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
   
    return 1;
  }
 
 printf( "%s\n", zErrMsg);

 


if(rc!=SQLITE_OK)
{
 printf( "%s\n", zErrMsg);
    return 1;
}



 rc=sqlite3_exec(db, "create table sites(Id integer auto_increment,proj_name string,primary key(\"Id\"));", NULL, NULL,NULL);
rc=sqlite3_exec(db, "begin;", NULL, NULL, &zErrMsg);
rc=sqlite3_exec(db, "insert into sites (\"proj_name\") values ('Google');", NULL, NULL,NULL);


rc=sqlite3_exec(db, "insert into sites (\"proj_name\") values ('Yahoo');", NULL, NULL,NULL);

rc=sqlite3_exec(db, "insert into sites (\"proj_name\") values ('MSN');", NULL, NULL,NULL);

rc=sqlite3_exec(db, "insert into sites (\"proj_name\") values ('Altheweb');", NULL, NULL,NULL);

rc=sqlite3_exec(db, "insert into sites (\"proj_name \") values ('Altavista');", NULL, NULL,NULL);
rc=sqlite3_exec(db, "insert into sites (\"proj_name\") values ('HotBot');", NULL, NULL,NULL);

rc=sqlite3_exec(db, "insert into sites (\"proj_name\") values ('Teoma');", NULL, NULL,NULL);

rc=sqlite3_exec(db, "insert into sites (\"proj_name\") values ('AOL');", NULL, NULL,NULL);
rc=sqlite3_exec(db, "commit;", NULL, NULL, NULL);
 rc=sqlite3_exec(db, "select * from sites;", myCallback1, NULL, &zErrMsg);
 if(rc!=SQLITE_OK)
  {
      printf( "%s\n", zErrMsg);
      return 1;
     }

  
 
  return 0;
}

static int myCallback1(void *NotUsed, int columns, char **pazValue, char **pazColName){
 int i;
 for(i=0; i<columns; i++){
  printf("%s(%s)=%s |",pazColName[i],pazColName[i+columns],pazValue[i] ? pazValue[i]:"NULL");
 }
 printf("\n");


    return 0;
}




Это сообщение отредактировал(а) Coocky - 5.8.2005, 18:15


--------------------
Верю в смерть после жизни, в любовь после секса ,в крем после бритья smile        
PM ICQ   Вверх
sergejzr
Дата 5.8.2005, 18:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Un salsero
Group Icon


Профиль
Группа: Админ
Сообщений: 13285
Регистрация: 10.2.2004
Где: Германия г .Ганновер

Репутация: 2
Всего: 360



Вообще в SQLite все типы - string.
И существует только int primary key.

Остальные декларации полей просто чисто для информации. Можешь туда писать что хочешь, всё игнорируется. Вообще, прежде чес работать с базой прочитай про Syntax.
А я пока попробую наваять тебе запросы smile
Добавлено @ 18:31
Так же SQLite сам генерит ID для просмотра тебе надо написать например:

select *,ROWID from ..... итд.
Добавлено @ 18:35
Когда добавляешь NULL вместо ключа, он генерится автоматом.
Вот так это надо делать:
Код


int myCallback1(void*,int,char**, char**);
int _tmain(int argc, char* argv[])
{
sqlite3 *db;
  char *zErrMsg = 0;
  int rc;
char*name="Dima2.db";
  
 rc = sqlite3_open(name, &db);
 
 if( rc ){
    fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
   
    return 1;
  }
 
 printf( "%s\n", zErrMsg);
 
if(rc!=SQLITE_OK)
{
 printf( "%s\n", zErrMsg);
    return 1;
}
 rc=sqlite3_exec(db, "create table project(Id integer primary key autoincrement,Name_proj string);", NULL, NULL,NULL);
rc=sqlite3_exec(db, "create table blinks(Id integer primary key autoincrement,proj_name string,site_id integer,number string,data integer);", NULL, NULL,NULL);
rc=sqlite3_exec(db, "create table ldomain(Id integer primary key autoincrement,proj_name string,site_id integer,number string,data integer);", NULL, NULL,NULL);
rc=sqlite3_exec(db, "create table ipage(Id integer primary key autoincrement,proj_name string,site_id integer,number string,data integer);", NULL, NULL,NULL);    
rc=sqlite3_exec(db, "create table  curl(Id integer primary key autoincrement,proj_name string,site_id integer,number string,data integer);", NULL, NULL,NULL);
rc=sqlite3_exec(db, "create table kranking(Id integer primary key autoincrement,site_id integer,key_id integer,number string,data integer);", NULL, NULL,NULL);
rc=sqlite3_exec(db, "create table keywords(Id integer primary key autoincrement,key string);", NULL, NULL,NULL);
rc=sqlite3_exec(db, "create table sites(Id integer primary key autoincrement,proj_name string);", NULL, NULL,NULL);
rc=sqlite3_exec(db, "begin;", NULL, NULL, &zErrMsg);
rc=sqlite3_exec(db, "insert into sites (\"proj_name\") values (NULL,'Google');", NULL, NULL,NULL);
rc=sqlite3_exec(db, "insert into sites (\"proj_name\") values (NULL,'Yahoo');", NULL, NULL,NULL);
rc=sqlite3_exec(db, "insert into sites (\"proj_name\") values (NULL,'MSN');", NULL, NULL,NULL);
rc=sqlite3_exec(db, "insert into sites (\"proj_name\") values (NULL,'Altheweb');", NULL, NULL,NULL);
rc=sqlite3_exec(db, "insert into sites (\"proj_name \") values (NULL,'Altavista');", NULL, NULL,NULL);
rc=sqlite3_exec(db, "insert into sites (\"proj_name\") values (NULL,'HotBot');", NULL, NULL,NULL);
rc=sqlite3_exec(db, "insert into sites (\"proj_name\") values (NULL,'Teoma');", NULL, NULL,NULL);
rc=sqlite3_exec(db, "insert into sites (\"proj_name\") values (NULL,'AOL');", NULL, NULL,NULL);
rc=sqlite3_exec(db, "commit;", NULL, NULL, NULL);
 rc=sqlite3_exec(db, "select * from sites;", myCallback1, NULL, &zErrMsg);
 if(rc!=SQLITE_OK)
  {
      printf( "%s\n", zErrMsg);
      return 1;
     }
  
 
  return 0;
}
static int myCallback1(void *NotUsed, int columns, char **pazValue, char **pazColName){
 int i;
 for(i=0; i<columns; i++){
  printf("%s(%s)=%s |",pazColName[i],pazColName[i+columns],pazValue[i] ? pazValue[i]:"NULL");
 }
 printf("\n");
    return 0;
}



--------------------
PM WWW IM ICQ Skype GTalk Jabber AOL YIM MSN   Вверх
Coocky
Дата 5.8.2005, 21:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


GUI гуру
****


Профиль
Группа: Участник Клуба
Сообщений: 2879
Регистрация: 16.2.2004
Где: Украина. Запорожь е

Репутация: 2
Всего: 62



sergej.z
Спасибо!
Цитата

Вообще, прежде чес работать с базой прочитай про Syntax.

Не веришь, как я горю с проектом smile
Поэтому и пользуюсь этим топиком, в своих целях, а заодно и для других. smile
Кстати я тоже не стою на месте, и уже знаю ответы на многие вопросы при работе с SQLite в среде МФС ( а проблем хватает!), но они уже решены.. smile
Кстати, насчет скорости, сложные запросы еще не делал, а вот код при создании базы и таблиц немного подвисат. Не сильно, на секунду. но все же. Но думаю это в порядке вещей.. smile
Добавлено @ 22:00
Цитата
В callback поидее с расстоянием в columns должны лежать типы данных. Но это не так. Где их там взять - ума не приложу. sqlite3_step работает отлично.

Вообще-то callback-нормальный вариант, хотя немного неудобный, для каждого запроса(который отличается от предыдущего) приходится добавлять новую фукнцию, если я хочу присвоить другим переменным даные, хотя написав сво класс от этого можно избавится.. smile


--------------------
Верю в смерть после жизни, в любовь после секса ,в крем после бритья smile        
PM ICQ   Вверх
Coocky
Дата 6.8.2005, 11:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


GUI гуру
****


Профиль
Группа: Участник Клуба
Сообщений: 2879
Регистрация: 16.2.2004
Где: Украина. Запорожь е

Репутация: 2
Всего: 62



sergej.z
а пример твой не рабочий... smile
Добавлено @ 11:03
А вот если NULL убрать, то рабочий.. smile


--------------------
Верю в смерть после жизни, в любовь после секса ,в крем после бритья smile        
PM ICQ   Вверх
Vatel
Дата 7.8.2005, 06:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 3
Регистрация: 6.8.2005

Репутация: нет
Всего: нет



Добрый день, пробовал компилировать helloword'ик, у меня не вышло.

Компилятор Borland C++ v.5.02
выдал такой вот Message

Info :Compiling D:\SQLProject\gendb.c
Warn : gendb.c(95,2):Parameter 'argc' is never used
Warn : gendb.c(76,2):'rc' is assigned a value that is never used
Warn : gendb.c(103,2):Parameter 'NotUsed' is never used
Warn : gendb.c(105,2):Undefined structure 'sqlite3'
Warn : gendb.c(105,2):Undefined structure 'sqlite3_stmt'
Warn : gendb.c(105,2):Undefined structure 'sqlite3_context'
Warn : gendb.c(105,2):Undefined structure 'Mem'
Info :Linking D:\SQLProject\gendb.exe
Error: Error: Unresolved external '_sqlite3_open' referenced from D:\SQLPROJECT\GENDB.OBJ
Error: Error: Unresolved external '_sqlite3_errmsg' referenced from D:\SQLPROJECT\GENDB.OBJ
Error: Error: Unresolved external '_sqlite3_exec' referenced from D:\SQLPROJECT\GENDB.OBJ
Error: Error: Unresolved external '_sqlite3_close' referenced from D:\SQLPROJECT\GENDB.OBJ

Подскажите в чем загвостка

Это сообщение отредактировал(а) Vatel - 7.8.2005, 06:45
PM MAIL   Вверх
sergejzr
Дата 7.8.2005, 13:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Un salsero
Group Icon


Профиль
Группа: Админ
Сообщений: 13285
Регистрация: 10.2.2004
Где: Германия г .Ганновер

Репутация: 2
Всего: 360



Цитата(Coocky @ 6.8.2005, 10:01)
А вот если NULL убрать, то рабочий.. smile

Да, autoincrement не нужен NULL smile Это я перемудрил.


Vatel, пишет ведь,
Цитата(Vatel @ 7.8.2005, 05:37)
Error: Error: Unresolved external '_sqlite3_open' referenced from D:\SQLPROJECT\GENDB.OBJ
Error: Error: Unresolved external '_sqlite3_errmsg' referenced from D:\SQLPROJECT\GENDB.OBJ
Error: Error: Unresolved external '_sqlite3_exec' referenced from D:\SQLPROJECT\GENDB.OBJ
Error: Error: Unresolved external '_sqlite3_close' referenced from D:\SQLPROJECT\GENDB.OBJ

Я вверху уже писал, что *.с файлы надо добавлять в проект отдельно.
Цитата(sergej @ 3.8.2005, 19:20)
Компилер ругается на unresolved symbols. Открываем таб FileView и правой кнопкой мыши в меню выбираем "add Files to Project". Забираем ВСЕ *.с файлы кроме: shell.c и tclsqlite.c

В Бильдере естественно это не FileView , но в меню возможность добавки файлов конечно же имеется.

Для начала попробуйте запустить с ДЛЛь
Код

#include <stdio.h>
#include <windows.h>
/*
Конечно SQLite можно загрузить из DLL или же Link Lib(?).
*/
#define  SQLITEDLL
#ifdef SQLITEDLL
#define SQLITE_OK      0  /* Successful result */
#define SQLITE_ERROR    1  /* SQL error or missing database */
#define SQLITE_ROW     100 /* sqlite_step() has another row ready */
#define SQLITE_DONE    101 /* sqlite_step() has finished executing */
#define SQLITE_DENY   1   /* Abort the SQL statement with an error */
#define SQLITE_IGNORE 2   /* Don't allow access, but don't generate an error */
typedef int (*sqlite3_callback)(void*,int,char**, char**);
typedef struct sqlite3 sqlite3;
typedef struct sqlite3_stmt sqlite3_stmt;
typedef int (*sqlite3_close_dll)(sqlite3 *);
typedef int (__cdecl * sqlite3_open_dll)(
  const char *filename,   /* Database filename (UTF-8) */
  sqlite3 **ppDb          /* OUT: SQLite db handle */
);
typedef int (__cdecl * sqlite3_exec_dll)(
  sqlite3*,                     /* An open database */
  const char *sql,              /* SQL to be executed */
  sqlite3_callback,             /* Callback function */
  void *,                       /* 1st argument to callback function */
  char **errmsg                 /* Error msg written here */
);
typedef int (__cdecl * sqlite3_errcode_dll)(sqlite3 *db);
typedef const char * (__cdecl * sqlite3_errmsg_dll)(sqlite3*);
typedef int (__cdecl * sqlite3_prepare_dll)(
  sqlite3 *db,            /* Database handle */
  const char *zSql,       /* SQL statement, UTF-8 encoded */
  int nBytes,             /* Length of zSql in bytes. */
  sqlite3_stmt **ppStmt,  /* OUT: Statement handle */
  const char **pzTail     /* OUT: Pointer to unused portion of zSql */
);
typedef int (__cdecl * sqlite3_column_count_dll)(sqlite3_stmt *pStmt);
typedef const void * (__cdecl * sqlite3_column_name_dll)(sqlite3_stmt*,int);
typedef const char * (__cdecl * sqlite3_column_decltype_dll)(sqlite3_stmt*,int);
typedef const unsigned char * (__cdecl * sqlite3_column_text_dll)(sqlite3_stmt*,int);
typedef int (__cdecl * sqlite3_step_dll)(sqlite3_stmt*);
typedef int (__cdecl * sqlite3_finalize_dll)(sqlite3_stmt *pStmt);
sqlite3_exec_dll sqlite3_exec;
sqlite3_open_dll sqlite3_open;
sqlite3_close_dll    sqlite3_close;
sqlite3_errmsg_dll    sqlite3_errmsg;
sqlite3_prepare_dll   sqlite3_prepare;
sqlite3_step_dll   sqlite3_step;
sqlite3_finalize_dll sqlite3_finalize;
sqlite3_column_count_dll sqlite3_column_count;
sqlite3_column_name_dll sqlite3_column_name;
sqlite3_column_decltype_dll sqlite3_column_decltype;
sqlite3_column_text_dll sqlite3_column_text;
HINSTANCE    SQLiteDLL;
#else
#include "sqlite3.h"
#endif
int myCallback(void*,int,char**, char**);
int init();
void finish();
int main(int argc, char **argv){
  sqlite3 *db;
  char *zErrMsg = 0;
  int rc;
   if( init()!=0)
 {
 printf("DLL's not loaded ");
 return 1;
 }
  
  /*arg1: Моя_БД.db есть файл БД. Если его несуществует, SQLite сама его создаст.
   arg2: указатель на структуру нашего БД
../Где_Угодно/Моя_БД.db
*/
  //  argv[1]="test.bd";
 rc = sqlite3_open(argv[1], &db);
 /*
 Если было невозможно создать файлик то rc содержит номер ошибки.
*/
 if( rc ){
    fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
    sqlite3_close(db);
    return 1;
  }
 /*
Всё в порядке, можно работать!
В SQLite существует два способа получения результата БД.
1. exec/callback
        Функция callback будет вызываться SQLite с каждой строкой от ResultSet'a
        Чем то похоже Listener на в JAVA
2. compile/step/finalize
        в этом случае можно забирать ResultSet строка за строкой
Пока не разобрался с новой версией :)
*/
 /*
рассмотрим sqlite_exec
arg1: Наша БД
arg2: SQL statement
arg3: Функция callback (Здесь нам не нужна).
arg4: Аргумент, который будет передаваться в функцию callback. Например вектор, в который мы хотим добавлять результат,
  или вообще указатель на какой нибудь обьект (Здесь нам не нужeн).
arg5: Сообщение об ошибке. Его можно распечатать, но только если возвращённый rc!=0.
Накидаем табличку
*/
 rc=sqlite3_exec(db, "create table test(num integer,name string);", NULL, NULL, &zErrMsg);
 /*
if(rc!=SQLITE_OK)
{
 printf( "%s\n", zErrMsg);
    return 1;
}
*/
 /*
 При импорте данных очень важно начать с begin иначе БД будет тормозить.
   Обьяснение: Все записи будут осуществляться в памяти и только с commit писаться на диск.
   После этого SQLite проверит, всё ли записано правильно.
   Без beginn'a это будет осуществляться при каждой записи
*/
 rc=sqlite3_exec(db, "begin;", NULL, NULL, &zErrMsg);
 for(int i=0;i<10;i++)
     {
 /*
 На оригинальность не претендую :)
*/
 char sqlText[200];
 sprintf(sqlText,"insert into test values(%i,'name_%i');",i,i);
 rc=sqlite3_exec(db, sqlText, NULL, NULL, &zErrMsg);
  if(rc!=SQLITE_OK)
      {
      printf( "%s\n", zErrMsg);
    break;
      }
    }
/*
Добавлено!!!!!!
Commit - база перенимает все изменения
*/
rc=sqlite3_exec(db, "commit;", NULL, NULL, &zErrMsg);
 /*
произведём селект способом 1:
*/
 printf("\n exec/callback \n");
 rc=sqlite3_exec(db, "select * from test;", myCallback, NULL, &zErrMsg);
 if(rc!=SQLITE_OK)
  {
      printf( "%s\n", zErrMsg);
      return 1;
     }
  
/*
  произведём SELECT способом 2:
*/
 const char *sqlText="select * from test;";
 /*
 ppVm непрозрачная структура виртуальной машины. В некоторых случаях я исползьовал несколько таких машин,
   чтобы опрашивать несколько разных ResultSet'ов.
*/
 sqlite3_stmt *ppVm;
 /*
 рассмотрим sqlite_compile
 arg1:Наша БД
 arg2:SQL statement
 arg3:Длинна запроса. Если -1, то SQLite сама определит её
 arg4:Виртуальная машинка.
 arg5:Остаток запроса после выполнения.
*/
 rc=sqlite3_prepare(db, sqlText,-1,&ppVm,&sqlText);
 if(rc!=SQLITE_OK)
       {
       printf( "%s\n", zErrMsg);
     return 1;
      }
    printf("\n compile/step/finalize \n");
    /*sqlite3_column_count отдаст количество колонок в результате*/
    int colcount=sqlite3_column_count(ppVm);
  /*
    рассмотрим sqlite_step
    arg1:Виртуальная машинка
    Она везде передаётся. Таким образом можно выполнять кучу запросов одновременно.
 */
 
 while(sqlite3_step(ppVm)!=SQLITE_DONE)
 {
  for(int i=0;i<colcount;i++)
  {
  
  printf("%s(%s)=%s |",sqlite3_column_name(ppVm,i), sqlite3_column_decltype(ppVm,i), sqlite3_column_text(ppVm,i));
  }
 printf("\n");
 }
 /*destructor Виртуальной машины*/
 rc=sqlite3_finalize(ppVm);
 
  sqlite3_close(db);
  finish();
  return 0;
}
static int myCallback(void *NotUsed, int columns, char **pazValue, char **pazColName){
 int i;
 for(i=0; i<columns; i++){
     /*
     Раньше был отступ в columns для типов данных..Сейчас вроде по другому, но как, пока не разобрался..
     */
  printf("%s(%s)=%s |",pazColName[i],pazColName[i+columns],pazValue[i] ? pazValue[i]:"NULL");
 }
 printf("\n");
finish();
 return 0;
}
int init()
{
#ifdef SQLITEDLL
 HINSTANCE    SQLiteDLL = LoadLibrary("sqlite3.dll");
     sqlite3_exec=((sqlite3_exec_dll) GetProcAddress (SQLiteDLL, "sqlite3_exec"));
     sqlite3_open=((sqlite3_open_dll) GetProcAddress (SQLiteDLL, "sqlite3_open"));
     sqlite3_step=((sqlite3_step_dll) GetProcAddress (SQLiteDLL, "sqlite3_step"));
     sqlite3_finalize=((sqlite3_finalize_dll) GetProcAddress (SQLiteDLL, "sqlite3_finalize"));
     sqlite3_close=((sqlite3_close_dll) GetProcAddress (SQLiteDLL, "sqlite3_close"));
    sqlite3_errmsg=((sqlite3_errmsg_dll) GetProcAddress (SQLiteDLL, "sqlite3_errmsg"));
    sqlite3_prepare=((sqlite3_prepare_dll) GetProcAddress (SQLiteDLL, "sqlite3_prepare"));
    sqlite3_column_count=((sqlite3_column_count_dll) GetProcAddress (SQLiteDLL, "sqlite3_column_count"));
    sqlite3_column_name=((sqlite3_column_name_dll) GetProcAddress (SQLiteDLL, "sqlite3_column_name"));
    sqlite3_column_decltype=((sqlite3_column_decltype_dll) GetProcAddress (SQLiteDLL, "sqlite3_column_decltype"));
    sqlite3_column_text=((sqlite3_column_text_dll) GetProcAddress (SQLiteDLL, "sqlite3_column_text"));
    
     return SQLiteDLL==NULL ? 1:0;
#endif
 return 0;
}
void finish()
{
#ifdef SQLITEDLL
 if(SQLiteDLL!=NULL)
 FreeLibrary(SQLiteDLL);
#endif
}

Сама sqlite3.dll должна лежать там же, где проект или в windows\system
PS: Прицепил обновлённый файл примера.


--------------------
PM WWW IM ICQ Skype GTalk Jabber AOL YIM MSN   Вверх
sergejzr
Дата 8.8.2005, 20:16 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Un salsero
Group Icon


Профиль
Группа: Админ
Сообщений: 13285
Регистрация: 10.2.2004
Где: Германия г .Ганновер

Репутация: 2
Всего: 360



Ув. Vatel, когда скомпилите проект, выложите плиз helloword'ик сюда для примера smile


--------------------
PM WWW IM ICQ Skype GTalk Jabber AOL YIM MSN   Вверх
Vatel
Дата 10.8.2005, 14:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 3
Регистрация: 6.8.2005

Репутация: нет
Всего: нет



Добрый день, попробовал запустить исходничек с Dll, заработало.

Делал так: Создавал директорию, туда сбрасывал примерчик от 7.8.2005, 13:34 и Dll'ку.
(больше ничего делать не пришлось)


Сейчас сижу разбираюсь, вот состряпал по аналогии свой helloWorld'ик.
прога перебирающая все html-файлы в директории
на основе их сама заполняет БД, Можно вводить SQL - запросы с консоли результаты будут выводится в файл в html - формате.


Код

#include <windows.h>
#include <stdio.h>
#define SQLITE_OK        0   /* Successful result                               */
#define SQLITE_ERROR     1   /* SQL error or missing database                   */
#define SQLITE_ROW     100   /* sqlite_step() has another row ready             */
#define SQLITE_DONE    101   /* sqlite_step() has finished executing            */
#define SQLITE_DENY      1   /* Abort the SQL statement with an error           */
#define SQLITE_IGNORE    2   /* Don't allow access, but don't generate an error */

char outputBuff[14096]="<html><head><title>Result</title></head><body bgColor=#fff55f>";

typedef int (*sqlite3_callback)(void*,int,char**, char**);
typedef struct sqlite3 sqlite3;
typedef struct sqlite3_stmt sqlite3_stmt;
typedef int (*sqlite3_close_dll)(sqlite3 *);
typedef int (__cdecl * sqlite3_open_dll)(
  const char *filename,      /* Database filename (UTF-8) */
  sqlite3 **ppDb             /* OUT: SQLite db handle     */
);
typedef int (__cdecl * sqlite3_exec_dll)(
  sqlite3*,                     /* An open database */
  const char *sql,              /* SQL to be executed */
  sqlite3_callback,             /* Callback function */
  void *,                       /* 1st argument to callback function */
  char **errmsg                 /* Error msg written here */
);
typedef int (__cdecl * sqlite3_errcode_dll)(sqlite3 *db);
typedef const char * (__cdecl * sqlite3_errmsg_dll)(sqlite3*);
typedef int (__cdecl * sqlite3_prepare_dll)(
  sqlite3 *db,            /* Database handle */
  const char *zSql,       /* SQL statement, UTF-8 encoded */
  int nBytes,             /* Length of zSql in bytes. */
  sqlite3_stmt **ppStmt,  /* OUT: Statement handle */
  const char **pzTail     /* OUT: Pointer to unused portion of zSql */
);
typedef int (__cdecl * sqlite3_column_count_dll)(sqlite3_stmt *pStmt);
typedef const void * (__cdecl * sqlite3_column_name_dll)(sqlite3_stmt*,int);
typedef const char * (__cdecl * sqlite3_column_decltype_dll)(sqlite3_stmt*,int);
typedef const unsigned char * (__cdecl * sqlite3_column_text_dll)(sqlite3_stmt*,int);
typedef int (__cdecl * sqlite3_step_dll)(sqlite3_stmt*);
typedef int (__cdecl * sqlite3_finalize_dll)(sqlite3_stmt *pStmt);
sqlite3_exec_dll               sqlite3_exec;
sqlite3_open_dll               sqlite3_open;
sqlite3_close_dll              sqlite3_close;
sqlite3_errmsg_dll             sqlite3_errmsg;
sqlite3_prepare_dll            sqlite3_prepare;
sqlite3_step_dll               sqlite3_step;
sqlite3_finalize_dll           sqlite3_finalize;
sqlite3_column_count_dll       sqlite3_column_count;
sqlite3_column_name_dll        sqlite3_column_name;
sqlite3_column_decltype_dll    sqlite3_column_decltype;
sqlite3_column_text_dll        sqlite3_column_text;
HINSTANCE    SQLiteDLL;
int init()
{
HINSTANCE  SQLiteDLL = LoadLibrary("sqlite3.dll");
sqlite3_exec=((sqlite3_exec_dll) GetProcAddress (SQLiteDLL, "sqlite3_exec"));
sqlite3_open=((sqlite3_open_dll) GetProcAddress (SQLiteDLL, "sqlite3_open"));
sqlite3_step=((sqlite3_step_dll) GetProcAddress (SQLiteDLL, "sqlite3_step"));
sqlite3_finalize=((sqlite3_finalize_dll) GetProcAddress (SQLiteDLL, "sqlite3_finalize"));
sqlite3_close=((sqlite3_close_dll) GetProcAddress (SQLiteDLL, "sqlite3_close"));
sqlite3_errmsg=((sqlite3_errmsg_dll) GetProcAddress (SQLiteDLL, "sqlite3_errmsg"));
sqlite3_prepare=((sqlite3_prepare_dll) GetProcAddress (SQLiteDLL, "sqlite3_prepare"));
sqlite3_column_count=((sqlite3_column_count_dll) GetProcAddress (SQLiteDLL, "sqlite3_column_count"));
sqlite3_column_name=((sqlite3_column_name_dll) GetProcAddress (SQLiteDLL, "sqlite3_column_name"));
sqlite3_column_decltype=((sqlite3_column_decltype_dll) GetProcAddress (SQLiteDLL, "sqlite3_column_decltype"));
sqlite3_column_text=((sqlite3_column_text_dll) GetProcAddress (SQLiteDLL, "sqlite3_column_text"));
return SQLiteDLL==NULL ? 1:0;
}
void finish()
{
 if(SQLiteDLL!=NULL)
 FreeLibrary(SQLiteDLL);
}
//******************************************************************************
//
//Процедура извлечения из файла содержимого тега <Title>
//
//******************************************************************************
int GetTitleStr(char *Pach,char *Title){
HANDLE InFile;
char lpBuffer[1024];
DWORD BytesRead;
char tegname[]="Title";
char *ptr;
int q;
Title[0]=0;
InFile=CreateFile(Pach,GENERIC_READ,FILE_SHARE_READ,NULL,OPEN_EXISTING,FILE_ATTRIBUTE_TEMPORARY,NULL);
ReadFile(InFile,lpBuffer,1024,&BytesRead,NULL);
strupr(lpBuffer);strupr(tegname);
ptr = strstr(lpBuffer,tegname);
if(ptr==NULL)return 1;
while(ptr[0]!='>')
    {
   if(ptr>lpBuffer+BytesRead-2)return 1;
   ptr++;
   }
ptr++;
q=0;
while(ptr[0]!='<')
{
if(q==255)break;
if(ptr>lpBuffer+BytesRead-2)break;
Title[q]=ptr[0];
ptr++;
q++;
}
Title[q]=0;
return 0;
}
//******************************************************************************
static int myCallback(void *NotUsed, int columns, char **pazValue, char **pazColName){
 int i;
 char temp[300];
 strcat(outputBuff,"<Table cellSpacing=5 cellPadding=10  bgColor=#eeeeff border=3><tr>");
 for(i=0; i<columns; i++){
 //if(columns==)
 printf("%s |",pazValue[i]);
 sprintf(temp,"<td>%s</td>",pazValue[i]);
 strcat(outputBuff,temp);}
 printf("\n");
 strcat(outputBuff,"</tr></table>");
 //finish();
 return 0;}

int main(int argc, char **argv)
{
HANDLE hStdInputHandle,hStdOutputHandle,File,OutFile;
AllocConsole();
SetConsoleTitle("Finder");
hStdInputHandle=GetStdHandle(STD_INPUT_HANDLE);
hStdOutputHandle=GetStdHandle(STD_OUTPUT_HANDLE);
char s[255];
int q,w;
sqlite3 *db;
char *zErrMsg = 0;
int rc;
DWORD dw;
int i = 0;
char strTitle[255];
char strSourse[255];
char sqlText[200];
char strFileName[255]="D:\\*.htm";
char OutputFile[]="d:\\TempV.htm";
WIN32_FIND_DATA FindData;

if( init()!=0){ printf("DLL's not loaded ");getchar();return 1; }
rc = sqlite3_open("FilesDB.bd", &db);
 if( rc ){
           fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
           sqlite3_close(db);
         getchar();
           return 1;
           }
rc=sqlite3_exec(db, "create table Files(num integer,Pach string,Title string);", NULL, NULL, &zErrMsg);





//***********************************************************Заполнение Таблицы.
rc=sqlite3_exec(db, "begin;", NULL, NULL, &zErrMsg);
File=FindFirstFile(strFileName,&FindData);
if(File!=INVALID_HANDLE_VALUE)
    {
   GetTitleStr(FindData.cFileName,strTitle);
   sprintf(sqlText,"insert into Files values(%i,'%s','%s');",i,FindData.cFileName,strTitle);
   rc=sqlite3_exec(db, sqlText, NULL, NULL, &zErrMsg);
   i++;
   if(rc!=SQLITE_OK){ printf( "%s\n", zErrMsg);}
   while(FindNextFile(File,&FindData))
      {
         GetTitleStr(FindData.cFileName,strTitle);
         sprintf(sqlText,"insert into Files values(%i,'%s','%s');",i,FindData.cFileName,strTitle);
         rc=sqlite3_exec(db, sqlText, NULL, NULL, &zErrMsg);i++;
            if(rc!=SQLITE_OK){ printf( "%s\n", zErrMsg); break;   }
         }
   }
rc=sqlite3_exec(db, "commit;", NULL, NULL, &zErrMsg);
//*****************************************************************************


   printf("Find?: >");
   gets(s);
  // q=0;w=q;
  //DeleteFile(OutputFile);
   OutFile=CreateFile(OutputFile,GENERIC_WRITE,FILE_SHARE_READ,NULL,CREATE_ALWAYS,NULL,NULL);

 rc=sqlite3_exec(db, s, myCallback, NULL, &zErrMsg);
//  rc=sqlite3_exec(db, "select * from files where num >6", myCallback, NULL, &zErrMsg);
 if(rc!=SQLITE_OK)  {      printf( "%s\n", zErrMsg);    getchar();  return 1;     }
 strcat(outputBuff,"</body></html>\n");

 printf("\n%s",outputBuff);

 WriteFile(OutFile,outputBuff,strlen(outputBuff),&dw,NULL);
 CloseHandle(OutFile);

 // Здесь будет код заставляющий Inet-Browser отобразить сгенерированный нами файл.



  getchar();
  sqlite3_close(db);
  finish();
  return 0;
}

PM MAIL   Вверх
sergejzr
Дата 10.8.2005, 14:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Un salsero
Group Icon


Профиль
Группа: Админ
Сообщений: 13285
Регистрация: 10.2.2004
Где: Германия г .Ганновер

Репутация: 2
Всего: 360



Прекрасно! Рад, что получилось smile
Всё же попробуйте статиком скомпилить, чтобы длльку не таскать за собой (в этом конечно большое преимущество SQLite)


--------------------
PM WWW IM ICQ Skype GTalk Jabber AOL YIM MSN   Вверх
Страницы: (4) Все 1 [2] 3 4 
Ответ в темуСоздание новой темы Создание опроса
Правила форума "C++: Базы данных"
chipset

Данный форум предназначен для обсуждения вопросов прямым образом связанных с C++ и БД. Так, вопросы только по C++ следует задавать в C++:Общие вопросы а вопросы по абстрактным БД в Базах данных или в соответствующих под-форумах.

Благодарим за понимание.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, chipset.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Базы данных | Следующая тема »


 




[ Время генерации скрипта: 0.1667 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.