如何使用VC6编译sqlite3

(一)---------------------------------------------------------------------------------------------

引言:

使用VC6编译sqlite-source-3_6_22的编译方法。

一.创建Win32动态链接库工程
1.打开VC新建一个“Win32 Dynamic-Link Library”工程,命名为:sqlite3;

2.在接下来的对话框中选择"An empty DLL project",点 FINISH->OK;

二.将文件添加进工程
将sqlite-source-3_6_22里的文件添加到sqlite3工程中:

1.将sqlite-source-3_6_22下的所有*.C文件添加在工程的Source File中

2.将sqlite-source-3_6_22下的所有*.h文件添加在工程的Source File中

三.按F7进行编译
出现如下错误:

d:/learn/sqlite3/tclsqlite.c(28) : fatal error C1083: Cannot open include file: 'tcl.h': No such file or directory

说明:tclsqlite.c用于生成基于TCL的API,如果要编译,这需要另外下载tcl.h;shell.c用于生成命令行模式的sqlite.exe;

四.删除掉文件tclsqlite.c
再此处去掉文件tclsqlite.c,不让此文件参加编译,按F7重新编译

出现如下错误

fts3_tokenizer.obj : error LNK2005: _sqlite3_api already defined in fts3.obj

rtree.obj : error LNK2005: _sqlite3_extension_init already defined in fts3.obj

rtree.obj : error LNK2005: _sqlite3_api already defined in fts3.obj

五.编译通过方案
1.编译通过的方案一:
添加编译选项SQLITE_CORE 和SQLITE_ENABLE_FTS3

以及SQLITE_ENABLE_RTREE,再次按F7进行编译

 

2.编译通过的方法二:
2.1添加编译选项
如果仅仅添加SQLITE_ENABLE_FTS3和以及SQLITE_ENABLE_RTREE两个编译选项,不添加SQLITE_CORE编译选项;

2.2修改文件sqlite3ext.h
在文件sqlite3ext.h的

#define SQLITE_EXTENSION_INIT1     const sqlite3_api_routines *sqlite3_api = 0;

行下面添加,添加如下内容:

#define EXTERN_SQLITE_EXTENSION_INIT1     extern const sqlite3_api_routines *sqlite3_api = 0;

2.3修改fts3.c和fts3_tokenizer.c两个文件
在fts3.c和fts3_tokenizer.c此2个文件里,将SQLITE_EXTENSION_INIT1修改为EXTERN_SQLITE_EXTENSION_INIT1,具体如下:

#ifndef SQLITE_CORE

  #include "sqlite3ext.h" 

  EXTERN_SQLITE_EXTENSION_INIT1

#else

  #include "sqlite3.h"

#endif

2.4修改文件rtree.c
将rtee.c文件的里,将SQLITE_EXTENSION_INIT1修改为extern const sqlite3_api_routines *sqlite3_api即可,具体如下:

#ifndef SQLITE_CORE

  #include "sqlite3ext.h" 

  extern const sqlite3_api_routines *sqlite3_api; 

#else

  #include "sqlite3.h"

#endif

 

附注说明:
1. rTree.c是建立数据库R树索引的模块;

2. fts3*.c是全文索引模块

 (二)-----------------------------------------------------------------------------------------------------------

1.先从官网获取sqlite-amalgamation-3_6_22.zip;

2.接着从官网获取sqlitedll-3_6_22.zip

下载编译好的DLL,这里有我们需要的sqlite3.def该文件

3.打开VC新建一个“Win32 Dynamic-Link Library”工程,命名为:sqlite3;

4.在接下来的对话框中选择"An empty DLL project",点 FINISH->OK;

5.将sqlite-amalgamation-3_6_22文件夹下的sqlite3.h以及sqlite3.c两个文件复制到工程文件夹下;

       将sqlitedll-3_6_22文件夹下的sqlite3.def该文件复制到工程文件夹下;

6.在工程的Source Files中添加sqlite3.c文件;

7.在工程的Include Files中添加sqlite3.h文件;

8.在工程的Resource Files中添加sqlite3.def文件;

9.针对如下问题:

sqlite3.def : error LNK2001: unresolved external symbol sqlite3_column_database_name

sqlite3.def : error LNK2001: unresolved external symbol sqlite3_column_database_name16

sqlite3.def : error LNK2001: unresolved external symbol sqlite3_column_origin_name

sqlite3.def : error LNK2001: unresolved external symbol sqlite3_column_origin_name16

sqlite3.def : error LNK2001: unresolved external symbol sqlite3_column_table_name

sqlite3.def : error LNK2001: unresolved external symbol sqlite3_column_table_name16

sqlite3.def : error LNK2001: unresolved external symbol sqlite3_table_column_metadata

Debug/sqlite3.lib : fatal error LNK1120: 7 unresolved externals

在菜单【Project】-【Settings…】-【C/C++】标签下的Category【General】下

Preprocessor definitions下:

新增2个编译选项,分别是:

THREADSAFE

SQLITE_ENABLE_COLUMN_METADATA

10.往工程中添加sqlite3.def文件就是为生成sqlite3.lib文件;

sqlite3.lib是与sqlite3.dll动态链接库文件一起提供给软件开发者的;

软件概述 UG(Unigraphics NX)是一款由西门子(Siemens PLM Software)开发的交互式CAD/CAM/CAE系统。作为全球领先的产品工程解决方案,它集成了产品设计、工程仿真与制造加工于一体。其功能强大且应用广泛,能够轻松实现各种复杂实体和造型的构造,为模具、汽车、航空航天及通用机械等行业提供了高性能的机械设计与制图灵活性。 软件基础信息 • 支持系统: 64位 Windows 10、Windows 11 核心功能模块 一、创新设计:高效、灵活、无缝协同 全链路产品设计 涵盖从2D布局、3D建模、装配设计到图纸文档记录的各个环节,大幅提升设计吞吐量,缩短交付周期超35%。 强大的同步建模技术 打破数据壁垒,可无缝导入并直接修改来自其他CAD系统的几何模型,是跨平台协同设计的理想选择。 复杂装配管理 专为大型复杂产品打造,即使面对成千上万的零件也能从容应对,快速识别并解决数字样机中的干涉等问题。 集成设计验证 内置自动验证功能,实时监控设计是否符合公司及行业标准;结合PLM数据可视化合成,辅助工程师做出更明智的决策。 二、综合仿真(Simcenter 3D):精准预测,降低试错成本 极速前后处理 依托先进的几何引擎,将强大的分析命令与几何编辑紧密集成,相比传统有限元工具,可缩短高达70%的仿真建模时间。 全方位结构分析 在同一环境中集成线性静力学、动态、疲劳及非线性分析,底层由业界顶尖的NX Nastran解算器提供支持,确保计算的高精度与可靠性。 声学与热管理分析 提供内外声学仿真以优化音质、降低噪音;具备一流的热传导仿真能力,帮助电子产品和工业机械实现最佳热管理方案。 多物理场耦合 简化了结构动力学、热传导、流体流动等复杂物理现象的模拟过程,消除外部数据传输错误,真实还原产品运行工况。 三、智能制造(CAM):打通从计划到车间的数字主线 全面的制造解决方案 提供从工装设计、CAM编程到机床控制器(如Sinumerik)的一体化支持,助力制定更科学的生产决策。 深度集成的PLM环境 借助Teamcenter实现数据和流程的统一管理,避免多数据库冲突,支持重用验证过的加工工艺与刀具库。 车间级互联 通过DNC系统与车间无缝对接,直接将加工数据和刀具清单下发至CNC机床,实现计划与生产的紧密结合。 提质增效 优化NC编程与刀具路径,提升表面精加工水平与零件精度;减少人为错误,显著提高新机床部署成功率及制造资源利用率。 总结 UG NX 2023作为一款集成化的产品工程解决方案,通过其强大的设计、仿真和制造功能,为现代制造业提供了完整的数字化产品开发平台。无论是复杂产品的设计验证,还是精密制造的流程优化,UG NX 2023都能为工程师团队提供高效、可靠的解决方案,助力企业提升产品创新能力和市场竞争力。 适用领域 模具设计、汽车制造、航空航天、通用机械、消费电子等
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值