免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1470 | 回复: 5
打印 上一主题 下一主题

请教如何把sqlite嵌入到我的c程序里去 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-11-04 15:59 |只看该作者 |倒序浏览
偶想用sqlite嵌入进来,作为我程序的数据库
于是就弄了个简单的测试程序来做

在/home下建一个sqlite目录,
把sqlite3.h,sqlite-3.2.7.so.gz考下来,
#gzip -d sqlite-3.2.7.so.gz
然后自己写一个文件sqtest.c,内容如下:

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

static int callback(void *NotUsed, int argc, char **argv, char **azColName){
  int i;
  for(i=0; i<argc; i++){
    printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
  }
  printf("\n");
  return 0;
}

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

  if( argc!=3 ){
    fprintf(stderr, "Usage: %s DATABASE SQL-STATEMENT\n", argv[0]);
    exit(1);
  }
  rc = sqlite3_open(argv[1], &db);
  if( rc ){
    fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
    sqlite3_close(db);
    exit(1);
  }
  rc = sqlite3_exec(db, argv[2], callback, 0, &zErrMsg);
  if( rc!=SQLITE_OK ){
    fprintf(stderr, "SQL error: %s\n", zErrMsg);
  }
  sqlite3_close(db);
  return 0;
}

开始编译吧
#/usr/local/arm/2.95.3/bin/arm-linux-gcc -c sqtest.c
没有任何提示
#/usr/local/arm/2.95.3/bin/arm-linux-gcc -o sqtest  sqtest.o sqlite-3.2.7.so
(屏幕上出现提示:)
sqlite-3.2.7.so:could not read symbols: Invalid operation
collect2: ld returned 1 exit status
请问我上面的操作哪些操作有问题,或者告诉我正确的方法也行啊,不胜感激啊!

论坛徽章:
0
2 [报告]
发表于 2005-11-04 16:03 |只看该作者
可能是编译sqlite的平台不是arm。
还是找源码自己编译吧。

论坛徽章:
0
3 [报告]
发表于 2005-11-04 16:06 |只看该作者
嵌入式啊,你这个共享库一定也要是嵌入式编译器生成的才行,然后就和普通的gcc编译一样

论坛徽章:
0
4 [报告]
发表于 2005-11-04 16:37 |只看该作者
原帖由 er 于 2005-11-4 16:06 发表
嵌入式啊,你这个共享库一定也要是嵌入式编译器生成的才行,然后就和普通的gcc编译一样



你有没有编译个动态库出来过啊?我不会写这个make
sigh....

论坛徽章:
0
5 [报告]
发表于 2005-11-05 08:19 |只看该作者
你是华恒的客户吧,找华恒要

论坛徽章:
0
6 [报告]
发表于 2005-11-05 10:40 |只看该作者
写干什么的makefile呀。
down一个sqlitexx.tar.gz文件,然后tar zxvf sql*.tar.gz
然后./configure
make
make install

当然,前提是你的开发环境构建正常。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP