Sqlite添加自定义函数

使用C/C++操作sqlite数据库进行GIS数据转换时,sqlite不能在sql中定义枚举量和常量。当程序设计中需要很多枚举量的时候,比如道路表中道路类型列就是枚举量:0表示高速,1表示国道,2表示省道,3表示县道等,又不能在sql中定义这些枚举量,我们该怎么解决呢?

通过搜索引擎知道sqlite可以让用户自己扩展sql函数,感觉可以使用sqlite扩展函数来解决这个问题。sqlite扩展sql函数的方法和步骤:首先按sqlite扩展函数的原型定义自己的函数,然后使用sqlite3_create_function注册到sqlite中,然后就可以在sql中使用自己定义的函数了,就跟使用预定义好的sqlite核心函数一样。

例如,我们可以把高速类型定义成一个扩展函数,这个函数返回0:

 
 
  1. static void fun_ROAD_TYPE_HIGHWAY( sqlite3_context * context, int argc, sqlite3_value ** value ) { sqlite3_result_int64( context, 0 ); }; 

然后把它注册到sqlite中,注册名为ROAD_TYPE_HIGHWAY:

 
 
  1. sqlite3_create_function( db, "ROAD_TYPE_HIGHWAY", 0, SQLITE_ANY, 0, fun_ROAD_TYPE_HIGHWAY, 0, 0 ) 

注册完后我们就可以在sql语句中通过注册名ROAD_TYPE_HIGHWAY来使用这个函数了,如:选出所有高速的sql可以写成select * from road_table where road_type = ROAD_TYPE_HIGHWAY(),这样是不是好多了。

由于GIS数据库中的枚举量居多,如果每个都要手工写个函数并注册,这肯定是一个超级体力活,所以用perl写了一个根据c/c++头文件生成sqlite扩展函数的小程序:http://files.cnblogs.com/adgnat/sqlitefungen.7z

程序使用方法:

1.确保安装了perl5和vc。

2.下载程序并解压。

3.打开cmd.exe,并进入程序(sqlitefungen)目录。

4.运行vcvars32.bat初始化VC编译环境。

使用SQLite扩展函数来定义自己的函数

5.执行自动生成脚本:perl sqlitefungen.perl mydb.h,mydb.h可以换成自己定义的头文件。

使用SQLite扩展函数来定义自己的函数

6.执行完后头文件目录下将生成一个同名的dll文件,你可以在sqlite3.exe中使用.load命令或sql中使用load_extension函数来加载该dll,加载后就可以使用dll中定义的扩展函数了。

关于SQLite扩展函数的知识就介绍到这里,希望看完之后您能有所收获,因为您的收获就是我最大的快乐!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
sqlite3.exe是一个轻量级的关系型数据库管理系统,它由Richard Hipp创造并维护。它被广泛用于移动设备和Web浏览器之间的数据交换,也可以作为桌面应用程序的内置数据库。这个软件包包含了一个文本命令行界面工具,用于向SQLite数据库中输入和查询数据sqlite3.exe是SQLite的Windows控制台版本,它通常包含在SQLite的Windows档案中。SQLite是一个在本地客户端加密的嵌入式数据库,它不需要客户端/服务器结构和配置文件,所以它易于部署和使用,而且可以用在非常小和嵌入式的设备上,比如智能手机和平板电脑。 sqlite3.exe的一个重要特性是事务管理,它支持ACID属性,即原子性、一致性、隔离性和持久性。这意味着sqlite3.exe可以保证数据的完整性,避免数据丢失和损坏,还可以支持并发访问和多用户访问。此外,sqlite3.exe支持多种数据类型,包括文本、整数、实数、日期和二进制数据,它也支持多种SQL查询和操作,如SELECT、INSERT、UPDATE、DELETE、JOIN等。 sqlite3.exe还支持自定义函数和触发器,可以在数据库添加自定义函数和回调函数,在特定条件下执行操作。这个特性可以增强sqlite3.exe的灵活性和可扩展性,使得用户可以根据自己的需求来拓展数据库的功能。 总之,sqlite3.exe是一个功能强大、易于使用和部署的嵌入式数据库管理系统,它可以满足中小型企业和个人开发者的需求,可以用来存储、管理和查询各种类型的数据。如果你需要一个轻量级的数据库系统,那么sqlite3.exe是一个不错的选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值