delphi+access数据库查询

shellbee 2012-03-16 09:25:10
我能用这样的代码么?
procedure TForm5.Button1Click(Sender: TObject);
begin

adotable1.close;
if radiobutton1.checked then
adotable1.sql.clear;
adotable1.sql.add('select*from 表2 where bianhao=:bianhao');
adotable1.parameters.parambyname('bianhao').value:=trim(edit1.text);
if edit1.text=''then
begin
application.messagebox('请输入商品编号','提示信息',64);
edit1.setfocus;
exit;
end;
adotable1.open;
end;
但运行的时候,错误指在adotable1.sql.clear;
希望大侠们帮帮忙。。小弟是初学者
...全文
115 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
shellbee 2012-03-16
  • 打赏
  • 举报
回复
提示是这样的。
Oraclers 2012-03-16
  • 打赏
  • 举报
回复
TADOTable 是没有SQL属性的。如果要用这个属性可用TADOQuery.
superlixiao78 2012-03-16
  • 打赏
  • 举报
回复
换一个adoquery试试。
kaikai_kk 2012-03-16
  • 打赏
  • 举报
回复
上面代码exit;可以去掉
kaikai_kk 2012-03-16
  • 打赏
  • 举报
回复
错误:
1.adotable是没有SQL属性的,只能设置Tablename直接关联表,要用SQL就改成adoquery吧
2.select*from 注意空格select * from
3.adotable1.close;最好放在if radiobutton1.checked then里面
4.if radiobutton1.checked then要加上begin...end
5.if edit1.text='' then判断放在if radiobutton1.checked then这个判断外面

最终代码:
procedure TForm5.Button1Click(Sender: TObject);
begin
if edit1.text=''then
begin
application.messagebox('请输入商品编号','提示信息',64);
edit1.setfocus;
exit;
end
else if radiobutton1.checked then
begin
with adoquery1 do
begin
close;
sql.clear;
sql.add('select * from 表2 where bianhao=:bianhao');
parameters.parambyname('bianhao').value:=trim(edit1.text);
open;
end;
end;
end;
我看见佛 2012-03-16
  • 打赏
  • 举报
回复
adotable1.sql.add('select*from 表2 where bianhao=:bianhao');->
adotable1.sql.Text :='select * from 表2 where bianhao=:bianhao';
小哥哥 2012-03-16
  • 打赏
  • 举报
回复
他没有把错误代码提示贴上来,怎么猜?可能是中文空格,可能是其他的,他的好像少了BEGIN END
我看见佛 2012-03-16
  • 打赏
  • 举报
回复
adotable1.sql.add('select*from 表2 where bianhao=:bianhao');->
adotable1.sql.add('select * from 表2 where bianhao=:bianhao');
select*from 连在一块了


如果错误仍在:改在Adoquery控件试试

2,497

社区成员

发帖
与我相关
我的任务
社区描述
Delphi 数据库相关
社区管理员
  • 数据库相关社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧