TRY
  {
    // 创建进行存取的字符串
    sSql.Format("DRIVER={%s};DSN='';FIRSTROWHASNAMES=1;READONLY=FALSE;CREATE_DB=\"%s\";DBQ=%s",sDriver, sExcelFile, sExcelFile);    // 创建数据库 (既Excel表格文件)
    if( database.OpenEx(sSql,CDatabase::noOdbcDialog) )
    {
      // 创建表结构(姓名、年龄)
      sSql = "CREATE TABLE Exceldemo (Name TEXT,Age NUMBER)";
      database.ExecuteSQL(sSql);
}
database.Close();     if( database.OpenEx(sSql,CDatabase::noOdbcDialog) )
    {
      sSql = "INSERT INTO Exceldemo (Name,Age) VALUES ('徐景周',26)";
      database.ExecuteSQL(sSql);

    }    
    // 关闭数据库
    database.Close(); AfxMessageBox("Excel文件写入成功!");
  }
  CATCH_ALL(e)
  {
    TRACE1("Excel驱动没有安装: %s",sDriver);
  }
  END_CATCH_ALL;
为什么我第二次open不了数据库呢???我想先建一个excel文件数据库,再往里面插值

解决方案 »

  1.   

    逻辑有问题呀,第二次打开的sSQL已经不是连接字串了
      

  2.   

    if( database.OpenEx(sSql,CDatabase::noOdbcDialog) )
        {
          // 创建表结构(姓名、年龄)
          sSql = "CREATE TABLE Exceldemo (Name TEXT,Age NUMBER)";
          database.ExecuteSQL(sSql);
    }
    database.Close();
    这里面改变了sSql的值,所以打开出错.
      

  3.   

    我上面写错了,我把sSql变成连接字符串仍然不能open
      

  4.   

    打不开是什么错误?getlasterror看看