delphi SQL操作

本文探讨了Access数据库中常见的SQL问题,包括表创建时的字段命名限制、字符型字段中的特殊字符处理方法、以及特定SQL语句在程序执行时可能遇到的问题及解决策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

create表 时不可以有类似Name之类的字段创建,否则报错,即使access数据库中执行正常

 
insert的字符型字段中不可以有英文单引号 ' 之类的存在,否则报错,可以用#39 代替,减少英文单引号 ' 的使用的增加易读性
 

1个SQL语句发现的2个问题  

 

sql语句:

select * into [;database=D:\测试数据\asdf.Mdb].table1   from  table1

 

表示将当前数据库中的table1  直接copy到路径D:\测试数据\asdf.Mdb中。

注意D:\测试数据\asdf.Mdb此数据库中不可以有 table1这个表

 

access中执行正常,程序里就出问题了。

第一个:

执行异常信息:不正常地定义参数对象。提供了不一致或不完整的信息

 

发现 

由于TADOQuery对象把":"后的字符当作变量来使用,导致数据识别错误。只要把TADOQuery.ParamCheck设置为False即可.

 

然后就遇到第二个:

执行异常信息:CommandText does not return a result set

 

发现公共函数对TADOQuery.SQL的处理默认是select开头则open,其他为excutesql。

 

实际应该是

TADOQuery打开操作:

如果执行的sql会返回数据集如用select命令就用open
如果执行的sql不会返回数据集如insert,update,delete就用execSQL

如果用Table的commandtext,则相应的为open和execute;

 

这里虽然是select开头的sql语句,却要用excutesql。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值