delphi Ado的一个bug

 在delphi中,Tadoquery在传参数时,如果传递的参数为中文,则有可能会被截断。

例如:

 qry.close;

 qry.sql.clear;

 qry.sql.add('insert into t(a)  values(:aa)');

qry.Parameters.ParamByName("aa").value := '中华人民共和国';

qry.executesql;

 

上面这段代码在执行时,在delphi7或者delphi2007,参数有可能被截断(并不是所有,看情况)。

解决的方法有两种,一种就说在参数赋值之前加下面语句

qry.Parameters.ParamByName("aa").size:=30

设置长度

 

第二种,就说改adodb.pas,这个网上有文章说明,大家可以搜索下,因为我怕改了会带来其它问题,所以一般用第一种方法。

 

其实出现截断字符串的情况,实际上是因为delphi算参数长度算错的原因,所以要修改计算参数长度的部分。第一种方法就说在赋值之前,就设置参数长度。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值