DBGrid能直接赋值吗?

castle 2003-05-28 10:15:12
我想在DBGrid中选定一行之后,能够把这一行的某个字段的值改一下,但不是在DBGrid里面直接改,而是通过赋值:
ADODataSet5.Edit ;
ADODataSet5.FieldByName('note_colf').AsInteger := **** ;
ADODataSet5.Post ;

提示错误:
缺少更新或刷新的键列信息

我怎样能实现这样的功能呢?
...全文
74 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
zjy6631 2003-06-03
  • 打赏
  • 举报
回复
我这儿没出现什么类似的问题。
unit Unit1;

interface

uses
SysUtils, WinTypes, WinProcs, Messages, Classes, Graphics, Controls,
Dialogs, Forms,StdCtrls, DB, ADODB, Grids, DBGrids,
dbgrid, Dta_sour;

type
TForm1 = class(TForm)
TDataSource1: TDataSource;
TDBGrid1: TDBGrid;
ADOConnection1: TADOConnection;
ADs1: TADODataSet;
Button1: TButton;
procedure Button1Click(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
end;

var
Form1: TForm1;

implementation

{$R *.DFM}

procedure TForm1.Button1Click(Sender: TObject);
begin
ADs1.Edit;
Ads1.FieldByName('Name').AsString:='HHHH';
Ads1.Post;
end;
castle 2003-06-03
  • 打赏
  • 举报
回复
还是不行.
microjuz 2003-06-03
  • 打赏
  • 举报
回复
缺少更新或刷新的键列信息
确保有取出该列,还有注意定位记录
castle 2003-05-28
  • 打赏
  • 举报
回复
ADODataSet5.Post发生的错误,因为是更改值,所以我觉得只要把改动的值写过就行了,不用把一行所有的值都写过吧?
castle 2003-05-28
  • 打赏
  • 举报
回复
还是同样的错误
timelyraining 2003-05-28
  • 打赏
  • 举报
回复
修改dbgrid属性:dgrowselect:=true;
shaoin 2003-05-28
  • 打赏
  • 举报
回复
在ADODataSet5.AfterPost 里做刷新不行吗
castle 2003-05-28
  • 打赏
  • 举报
回复
up

5,930

社区成员

发帖
与我相关
我的任务
社区描述
Delphi 开发及应用
社区管理员
  • VCL组件开发及应用社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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