从 char 数据类型到 datetime 数据类型的转换导致 datetime 值越界 5

源错误:行71:Sql="selecta.day,a.realnamefrom(selectdatediff(d,getdate(),ltrim(year(getdate... 源错误:

行 71: Sql = "select a.day,a.realname from (select datediff(d,getdate(),ltrim(year(getdate()))+'-'+ltrim(month(birthday))+'-'+ltrim(day(birthday))) as day,realname from users where birthday is not null) a where a.day>=0 and a.day<=6 order by a.day";
行 72: db.GetReader(Sql, out rdr);
行 73: while (rdr.Read())
行 74: {
行 75: Label_Birthday.Text = "1";

源文件:
d:\webfiles\MasterPage\PersonalMasterPage.master.cs 行: 73
展开
 我来答
翱记蹈cP
2015-04-22 · TA获得超过349个赞
知道大有可为答主
回答量:1261
采纳率:0%
帮助的人:836万
展开全部
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();
追问
怎么添加啊 亲
添加GBK编码支持:怎么添加
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式