加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

SQLITE Open时的一个Trick

发布时间:2020-12-12 20:30:11 所属栏目:百科 来源:网络整理
导读:sqlite3_open如果没有打开现有的db文件,他是会在当前环境下新建一个数据库文件的,返回值一切正常,但是你下面的sqlite3_prepare就会报错误。 而在vs工程里面,默认的路径会建立在你的工程目录下面。 所以百思不得其解的时候,想一下是不是打开db文件错误了

sqlite3_open如果没有打开现有的db文件,他是会在当前环境下新建一个数据库文件的,返回值一切正常,但是你下面的sqlite3_prepare就会报错误。

而在vs工程里面,默认的路径会建立在你的工程目录下面。

所以百思不得其解的时候,想一下是不是打开db文件错误了?

Sqlite是不支持中文编码GB2312的,必须使用编码转换,好在网路上这方面的资料甚为丰富。顺便提一句,VAssistX的功能好生强大。

/*
sqlite编码转换 
在vs2008sp1下编译通过测试成功
*/


__inline void Gb2312_2_Unicode(unsigned short* dst,const char * src)
{
	::MultiByteToWideChar(CP_ACP,MB_PRECOMPOSED,src,2,(LPWSTR)(dst),1);
}
__inline void Unicode_2_UTF8(char* dst,unsigned short* src)
{
	char* pchar = (char *)src;

	dst[0] = (0xE0 | ((pchar[1] & 0xF0) >> 4));
	dst[1] = (0x80 | ((pchar[1] & 0x0F) << 2)) + ((pchar[0] & 0xC0) >> 6);
	dst[2] = (0x80 | ( pchar[0] & 0x3F));
}
__inline void UTF8_2_Unicode(unsigned short* dst,const char * src)
{
	char* uchar = (char *)dst;

	uchar[1] = ((src[0] & 0x0F) << 4) + ((src[1] >> 2) & 0x0F);
	uchar[0] = ((src[1] & 0x03) << 6) + (src[2] & 0x3F);
}
__inline void Unicode_2_GB2312(char* dst,unsigned short uData)
{
	WideCharToMultiByte(CP_ACP,NULL,(LPCWSTR)(&uData),1,dst,sizeof(unsigned short),NULL);
}

int GB2312_2_UTF8(char * buf,int buf_len,const char * src,int src_len)
{
	if (0 == src_len)
		src_len = strlen(src);
	int j = 0;
	for (int i = 0; i < src_len;)
	{
		if (j >= buf_len - 1)
			break;
		if (src[i] >= 0)
		{
			buf[j++] = src[i++];
		}
		else
		{
			unsigned short w_c = 0;
			Gb2312_2_Unicode(&w_c,src + i);
			char tmp[4] = "";
			Unicode_2_UTF8(tmp,&w_c);

			buf[j+0] = tmp[0];
			buf[j+1] = tmp[1];
			buf[j+2] = tmp[2];

			i += 2;
			j += 3;
		}
	}
	buf[j] = '';
	return j;
}
int UTF8_2_GB2312(char * buf,int src_len)
{
	if (0 == src_len)
		src_len = strlen(src);

	int j = 0;
	for (int i = 0; i < src_len;)
	{
		if (j >= buf_len - 1)
			break;
		if (src[i] >= 0)
		{
			buf[j++] = src[i++];
		}
		else
		{
			unsigned short w_c = 0;
			UTF8_2_Unicode(&w_c,src + i);

			char tmp[4] = "";
			Unicode_2_GB2312(tmp,w_c);

			buf[j+0] = tmp[0];
			buf[j+1] = tmp[1];

			i += 3;
			j += 2;
		}
	}

	buf[j] = '';

	return j;
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读