当前位置: 首页 > 图文教程 > 开发语言 > VC++ > VC++:小编谈用ODBC创建表

VC++
在类VC的界面实现中加入目录树
软件换肤技术在 BCB 中的实现
利用非模窗口生成MDI介面
报表输出轻松搞定
Windows 中不规则窗体的编程实现
解说Win32的窗口子类化
使用测试优先方法开发用户界面
一个简单的登录对话框的实现
一个简单的日记本程序
从资源中加载皮肤
一个在RichEdit中添加表情图象的类
ActiveSkin 4.3 软件换肤在VC中的实现
一种另类“关于(About)”对话框的动态显示方法
对话框打印预览及打印
关于如何换肤、子类化的解决方案
制作 MSN、QQ 的消息提示窗口
如何对 BCGControlBarPro 进行换肤
定制个性化的对话框窗口类
改变窗口中的光标形状
更新MFC中的视图,跟踪.NET Framework中的事件

VC++:小编谈用ODBC创建表


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-12-26   浏览: 235 ::
收藏到网摘: n/a

下编要和大家分享的是用ODBC创建表,大家知道由于ODBC类不支持DDL,所以只有通过ODBC API来创建表。程序需要调用Cdatabase :: ExecuteSQL来直接执行SQL语句。

 

  下面小编给出了创建表的一个例子,该程序先自动注册了一个名为MYDBFoxPro 2.5数据源,然后创建了一个名为OFFICES的表(OFFICES.DBF文件),在这个表中有OfficeIDOfficeName两个TEXT型字段,长度分别为410个字节。注意,如果要使用这段代码,则需要包含afxdb.hodbcinst.h

 

#include “afxdb.h”

 

#include "odbcinst.h"

 

. . .

 

CDatabase db;

 

if(!SQLConfigDataSource(NULL,ODBC_ADD_DSN, "Microsoft FoxPro Driver (*.dbf)",

 

"DSN=MYDB\0"

 

"DefaultDir=c:\\mydir\0"

 

"FIL=FoxPro 2.5\0"

 

"DriverId=280\0"))

 

{

 

AfxMessageBox("Can't add DSN!");

 

return ;

 

}

 

TRY

 

{

 

db.Open("MYDB");

 

db.ExecuteSQL("CREATE TABLE OFFICES (OfficeID TEXT(4)"

 

",OfficeName TEXT(10))"); }

 

CATCH(CDBException, e)

 

{

 

AfxMessageBox(e->m_strError);

 

return;

 

}

 

END_CATCH

 

ExecuteSQL执行了一个实实在在的SQL语句CREATE来创建表,看来用户应该找本SQL方面的书研究研究。要注意一个数据库中的表名必须是唯一的,如果要创建的表已经存在,则ExecuteSQL会产生一个异常。希望小编的总结能够带给大家帮助。