请问Sqlite 中 string和text 两种数据类型有什么区别

请问Sqlite 中 string和text 两种数据类型有什么区别,第1张

string是字符串,你向这个类型的数据位置写字符串的时候,传递的是什么字符串类型,它就以什么字符串类型保持。

text你可以理解为在库里建了个txt文档,向这个文档里写文字,它会以这个数据类型所设置的编码进行存储。

假设sqlite库中,A1是string,B1是text。我用VB向A1中写“abc”,向B1中写“abc”,那么a1中实际放的是Unicode格式的“abc”(VB默认的字符串格式为Unicode),而B1中放的是UTF-8格式的“abc”

char*转换

Qt下面,字符串都用QString,确实给开发者提供了方便,想想VC里面定义的各种变量类型,而且函数参数类型五花八门,经常需要今年新那个类型转换

Qt再使用第三方开源库时,由于库的类型基本上都是标准的类型,字符串遇的多的就是Char*类型

在Qt下怎样将QString转char*呢,需要用到QByteArray类,QByteArray类的说明详见Qt帮助文档。

因为char*最后都有一个‘/0’作为结束符,而采用QString::toLatin1()时会在字符串后面加上‘/0’

方法如下:

Qstring

str

char*

ch

QByteArray

ba

=

str.toLatin1()

ch=ba.data()

这样就完成了QString向char*的转化。经测试程序运行时不会出现bug

注意第三行,一定要加上,不可以str.toLatin1().data()这样一部完成,可能会出错。

补充:以上方法当QString里不含中文时,没有问题,但是QString内含有中文时,转换为char*就是乱码,采用如下方法解决:

方法1:

添加GBK编码支持:

#include

<QTextCodec>

QTextCodec::setCodecForTr(QTextCodec::codecForName("GBK"))

QTextCodec::setCodecForLocale(QTextCodec::codecForName("GBK"))

然后改变上面的第三行为:QByteArray

ba

=

str.toLoacl8Bit()

toLoacl8Bit支持中文

方法2:

先将QString转为标准库中的string类型,然后将string转为char*,如下:

std::string

str

=

filename.toStdString()

const

char*

ch

=

str.c_str()


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6718101.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-27
下一篇 2023-03-27

发表评论

登录后才能评论

评论列表(0条)

保存