许可优化
许可优化
产品
产品
解决方案
解决方案
服务支持
服务支持
关于
关于
软件库
当前位置:服务支持 >  软件文章 >  Borland C++ Builder (BCB)动态创建ACCESS的MDB数据表

Borland C++ Builder (BCB)动态创建ACCESS的MDB数据表

阅读数 2
点赞 0
article_banner

用BCB连过数据库的朋友可能都踩过这个坑——同样是建表,SQL Server和Access的写法居然不一样!

比如你想在SQL Server里判断表存不存在,存在就先删掉再建,一条SQL搞定:
if object_id('表名') is not null drop table 表名
然后直接CREATE TABLE。是不是很丝滑?

但换到Access数据库,这招就失灵了。Access压根不认object_id这种写法,你硬塞进去只会报错。怎么办?我自己的经验是:分两步走,而且必须加异常保护。

第一步,删表。但麻烦在于:表可能不存在。如果不存在还执行drop table,程序直接崩。
所以得这么写:
AnsiString SqlStr = "drop table " + TABLENAME;
执行前清空SQL,加上try{ qryData->ExecSQL(); } catch(...) { }。这样即使表不存在,也不会中断程序。

第二步,建表。同样用try包起来:
CREATE TABLE TABLENAME ( ID int IDENTITY (1,1) NOT NULL, Name varChar(100) NOT NULL, PRIMARY KEY (ID) )

这里有个小坑得提醒你:字段类型千万别用char(100),否则Access可能会报“记录过大”。实测用varchar(100)就稳稳的。为啥?因为Access对固定长度字符串的处理比较死板,可变长度更友好。

所以,如果你还在用BCB维护老项目,这套“先删后建+异常吞掉+类型用varchar”的组合拳,建议直接拿去用。你说麻烦?是有点,但总比程序动不动闪退强,对吧?


免责声明:本文系网络转载或改编,未找到原创作者,版权归原作者所有。如涉及版权,请联系删

相关文章
QR Code
微信扫一扫,欢迎咨询~
customer

online

联系我们
武汉格发信息技术有限公司
湖北省武汉市经开区科技园西路6号103孵化器
电话:155-2731-8020 座机:027-59821821
邮件:tanzw@gofarlic.com
Copyright © 2023 Gofarsoft Co.,Ltd. 保留所有权利
遇到许可问题?该如何解决!?
评估许可证实际采购量? 
不清楚软件许可证使用数据? 
收到软件厂商律师函!?  
想要少购买点许可证,节省费用? 
收到软件厂商侵权通告!?  
有正版license,但许可证不够用,需要新购? 
联系方式 board-phone 155-2731-8020
close1
预留信息,一起解决您的问题
* 姓名:
* 手机:

* 公司名称:

姓名不为空

姓名不为空

姓名不为空
手机不正确

手机不正确

手机不正确
公司不为空

公司不为空

公司不为空