sql从char数据类型到datetime数据类型的转换导致datetime值越界
发布网友
发布时间:2022-05-23 13:46
我来回答
共5个回答
热心网友
时间:2023-10-23 14:48
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::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();
热心网友
时间:2023-10-23 14:48
把Book_Create_Date改为Book_Create_Date.ToString("yyyy-MM-dd
HH:mm:ss"),因为字符型不能与日期型相加。如下:
string
sqlstr4
=
"update
tbBook
set
Book_Type='"
+
Book_Type
+
"',Book_Create_Date='"
+
Book_Create_Date.ToString("yyyy-MM-dd
HH:mm:ss")
+
"',Book_Money='"
+
Book_Money
+
"',Book_Remark='"
+
Book_Remark
+
"'
where
Book_ID='"
+
Book_ID
+
"'";
热心网友
时间:2023-10-23 14:49
2月
没有
31
号啊.
因此数据库在尝试把
'2013-2-31'
转换为
datetime
的时候,
就出错了。
热心网友
时间:2023-10-23 14:49
sql从char数据类型到datetime数据类型的转换导致datetime值越界
你用112,不就是yymmdd这样的吗,,, convert(varchar(6),opertime,112) 这样试试,是什么
热心网友
时间:2023-10-23 14:50
你用112,不就是yymmdd这样的吗,,,
convert(varchar(6),opertime,112)
这样试试,是什么