a372187663 2015-04-01 20:41 采纳率: 75%
浏览 2525
已采纳

C++builder DBGrid双击获取记录问题

图片说明
无论我双击001还是其他记录,该ADODataSet1->FieldByName("员工号")->AsString显示的就是001的值,不曾改变。代码如下
AnsiString Path;
AnsiString sqlstr = "Select 头像 from Photo where 员工号='"+ADODataSet1->FieldByName("员工号")->AsString+"'";
ADOQuery1->Close();
ADOQuery1->SQL->Clear();
ADOQuery1->SQL->Add(sqlstr);
ADOQuery1->Open();
Path = ADOQuery1->FieldByName("头像")->AsString;
Image1->Picture->LoadFromFile(Path);

  • 写回答

2条回答 默认 最新

  • 宝龙哥 2015-04-06 00:14
    关注

    这个要看你的代码是写在什么地方的了,试试下面的:

    void __fastcall TForm1::DBGrid1DblClick(TObject Sender)//双击
    {
    if(((TDBGrid
    )Sender)->DataSource->DataSet->Active==false || ((TDBGrid*)Sender)->DataSource->DataSet->RecordCount<=0)return;

    AnsiString Path;
    AnsiString sqlstr = "Select 头像 from Photo where 员工号='"+((TDBGrid*)Sender)->DataSource->DataSet->FieldByName("员工号")->AsString+"'";
    ADOQuery1->Close();
    ADOQuery1->SQL->Clear();
    ADOQuery1->SQL->Add(sqlstr);
    ADOQuery1->Open();
    Path = ADOQuery1->FieldByName("头像")->AsString;
    Image1->Picture->LoadFromFile(Path);

    }

    还有一点,你的员工号是文本类型的还是数字类型的,数字类型的话不要加''

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)
编辑
预览

报告相同问题?

悬赏问题

  • ¥15 fluent设置了自动保存后,会有几个时间点不保存
  • ¥20 激光照射到四象线探测器,通过液晶屏显示X、Y值
  • ¥15 这怎么做,怎么在我的思路下改下我这写的不对
  • ¥50 数据库开发问题求解答
  • ¥15 安装anaconda时报错
  • ¥20 如何用Python处理单元格内连续出现的重复词语?
  • ¥15 小程序有个导出到插件方式,我是在分包下引入的插件,这个export的路径对吗,我看官方文档上写的是相对路径
  • ¥20 希望有人能帮我完成这个设计( *ˊᵕˋ)
  • ¥100 将Intptr传入SetHdevmode()将Intptr传入后转换为DEVMODE的值与外部代码不一致
  • ¥50 基于ERA5数据计算VPD
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部