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);
}

解决方案 »

  1.   


    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);
      

  2.   

    错误是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);
    }
      

  3.   

    楼上的代码在%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);//这段代码却出错????????!!!!
      

  4.   

    .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)
      

  5.   

     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);//这段代码却出错????????!!!!