微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SQLite 用户自定义函数举例

sqlite 用户自定义函数举例
作者:tamsyn 来源:dongqiang@gmail.com 时间:2007-3-20 【 字体: 〖 双击滚屏 〗

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <time.h>
#include <malloc.h>
#include <assert.h>
#include <sqlite3.h>

#define SELECT_QUERY"SELECT host_id,geturl(desc) FROM host_table;

void host2url_func( sqlite3_context * ctx,int argc,sqlite3_value ** argv )
{
if ( argc != 1 ) return;
char * httpurl = NULL;
switch( sqlite3_value_type( argv[ 0 ] ) )
{
case sqlITE_NULL:
{
sqlite3_result_text( ctx,"NULL",4,sqlITE_STATIC );
break;
}
case sqlITE_TEXT:
{
httpurl = ( char * ) malloc( strlen( sqlite3_value_text( argv[0] ) ) + 8 );
if ( httpurl == 0 ) return;
sprintf( httpurl,"http://%s",sqlite3_value_text( argv[ 0 ] ) );
sqlite3_result_text( ctx,httpurl,strlen( httpurl ),sqlITE_TRANSIENT );
free( httpurl );
httpurl = NULL;
break;
}
default:
sqlite3_result_text( ctx,"about:blank",11,sqlITE_STATIC );
}
}

static int callback(void *NotUsed,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);
}

sqlite3_create_function( db,"geturl",1,sqlITE_ANY,NULL,host2url_func,NULL );
rc = sqlite3_exec(db,argv[2],callback,&zErrMsg);

if( rc!=sqlITE_OK ){
fprintf(stderr,"sql error: %s/n",zErrMsg);
}

sqlite3_close(db);
return 0;

}

原文地址:https://www.jb51.cc/sqlite/203228.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐