CString.Format 问题

Yanger_xy 2010-04-22 02:26:45
void CdataDlg::OnBnClickedButton2()
{
// TODO: 在此添加控件通知处理程序代码
CString strSql = "";
strSql.Format("adf'%s'", "asd");//这段代码没错
strSql.Format("insert into TerrainTable(IndexId, PointIndex, PtX, PtY, PtZ, Layername, color) values (%d, %d, %.4f, %.4f, %.4f, '%s', %d)",
1, 1, 10.222, 1010, 1.54, "sf", 1);//这段代码却出错????????!!!!
MessageBox(strSql);
}
...全文
238 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
尹成 2010-04-22
  • 打赏
  • 举报
回复
错误是1010这个整数你有%.4f输出
因为在有些关键小数点本来就是逗号,而是1010后的数据错位了,只要把1010改成1010.0就可以了
这不是鸭头 2010-04-22
  • 打赏
  • 举报
回复
azure110 2010-04-22
  • 打赏
  • 举报
回复
转义符..
lijianli9 2010-04-22
  • 打赏
  • 举报
回复
strSql.Format("insert into TerrainTable(IndexId, PointIndex, PtX, PtY, PtZ, Layername, color) values ('%d', '%d', '%.4f', '%.4f', '%.4f','%s','%d')",
1, 1, 10.222, 1010.0, 1.54,"asd",1);//这段代码却出错????????!!!!
Jasonli8205 2010-04-22
  • 打赏
  • 举报
回复
.Format("insert into TerrainTable(IndexId, PointIndex, PtX, PtY, PtZ, Layername, color) values (%d, %d, %.4f, %.4f, %.4f, '%s', %d)", 1, 1, 10.222, 1010.0, 1.54, "sf", 1)
WaistCoat10 2010-04-22
  • 打赏
  • 举报
回复
要用转义字符\
Yanger_xy 2010-04-22
  • 打赏
  • 举报
回复
楼上的代码在%s出加了转义字符,但是
这段代码strSql.Format("adf'%s'", "asd");也没加转义字符,但运行也没错.
而改成下面的较长的字符串没有加转义字符就出错.费解!费解!
strSql.Format("insert into TerrainTable(IndexId, PointIndex, PtX, PtY, PtZ, Layername, color) values (%d, %d, %.4f, %.4f, %.4f, '%s', %d)",
1, 1, 10.222, 1010.12, 1.54, "sf", 1);//这段代码却出错????????!!!!
oysoft 2010-04-22
  • 打赏
  • 举报
回复
错误是1010这个整数你有%.4f输出
因为在有些关键小数点本来就是逗号,而是1010后的数据错位了,只要把1010改成1010.0就可以了。

void CdataDlg::OnBnClickedButton2()
{
// TODO: 在此添加控件通知处理程序代码
CString strSql = "";
strSql.Format("adf'%s'", "asd");//这段代码没错
strSql.Format("insert into TerrainTable(IndexId, PointIndex, PtX, PtY, PtZ, Layername, color) values (%d, %d, %.4f, %.4f, %.4f, '%s', %d)",
1, 1, 10.222, 1010.0, 1.54, "sf", 1);//这段代码却出错????????!!!!应该是1010.0
MessageBox(strSql);
}
Eleven 2010-04-22
  • 打赏
  • 举报
回复

CString strSql = "";
strSql.Format("adf\'%s\'", "asd");//Õâ¶Î´úÂëû´í
strSql.Format("insert into TerrainTable(IndexId, PointIndex, PtX, PtY, PtZ, Layername, color)"
"values (%d, %d, %.4f, %.4f, %.4f, \'%s\', %d)",
1, 1, 10.222, (float)1010, 1.54, "sf", 1);//Õâ¶Î´úÂëÈ´³ö´í????????!!!!
AfxMessageBox(strSql);
社会栋梁 2010-04-22
  • 打赏
  • 举报
回复
错误信息是什么?

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧