常规的数据操作:
见上图,数据保存在.ClientDataSet1数据集中,为了将参数逐条保存在Txt文件中,做了对ClientDataSet(DBGridEh)的循环写盘和读盘操作:
但是,原代码通过数据集循环 ,直接写入磁盘,出现:
(1)ClientDataSet1不可再操作,比如对它进行再赋值。
(2)甚至出现“Access violation at address 00402452 in module 'MedicalRec.exe'.Read of address FFFFFFC”出错信息提示。
为此,解决问题。
一、上网查内存越界,按网上办法
通过重新注册Windows的动态链接库。:
(1)运行 -> cmd,
(2)命令行执行:for %1 in (%windir%\system32\*.dll) do regsvr32.exe /s %1 。
不起作用。
二、相关操作代码
1、TClientDataSet三层运用,客户端,读取数据。
procedure TSys_Config_Frm.sButton7Click(Sender: TObject);
var S1,SQL:string;
begin
S1:=sEdit1.Text;
SQL:='select 排序,选择,主题,副题,名称,T,共性,备注,ITEMS,分支,ID from 系统配置 '+
'where (分支='+#39+sFCID+#39+') and (主题='+#39+S1+#39+') '+
'order by 主题,名称';
DataModule1.ClientDataSet1.Active:=False;
DataModule1.ClientDataSet1.DataRequest(SQL);
DataModule1.ClientDataSet1.Active:=True;
ClientDataSet1.Data:=DataModule1.ClientDataSet1.Data;
DataModule1.ClientDataSet1.Active:=False;
DBGridEh1.DataSource:=DataSource1;
DBGridEh1.Columns.Items[0].Width:=36;
DBGridEh1.Columns.Items[1].Width:=36;
DBGridEh1.Columns.Items[2].Width:=80;
DBGridEh1.Columns.Items[3].Width:=50;
DBGridEh1.Columns.Items[4].Width:=200;
DBGridEh1.Columns.Items[5].Width:=36;
DBGridEh1.Columns.Items[6].Width:=36;
ClientDataSet1.Fields[1].DisplayLabel:='√';
DBGridEh1.Columns[1].Title.Alignment := taCenter; // 标题居中
DBMemo1.DataSource:=DataSource1;
DBMemo1.DataField:='Items';
DBMemo2.DataSource:=DataSource1;
DBMemo2.DataField:='备注';
end;
2、当ClientDataSet数据集,单独一行数据段读写磁盘中Txt文件后,正常。
procedure TSys_Config_Frm.Button13Click(Sender: TObject);
var FileName:string;
S1,S2:string;
MyList:TStringList;
begin
MyList:=TStringList.Create;
S1:=Trim(ClientDataSet1.FieldByName('主题').AsString);
S2:=Trim(ClientDataSet1.FieldByName('名称').AsString);
Try
FileName:=Edit1.Text+'\'+S1+'_'+S2+'.txt';
if FileExists(FileName) then
begin
MyList.LoadFromFile(FileName);
DBGridEh1.DataSource.DataSet.Edit;
ClientDataSet1.FieldByName('ITEMS').AsString:=MyList.text;
DBGridEh1.DataSource.DataSet.Post;
end;
finally
end;
MyList.Free;
end;
3、当ClientDataSet数据集循环中,某字段读写磁盘中Txt文件后,就不能对ClientDataSet重新赋值。
procedure TSys_Config_Frm.Button28Click(Sender: TObject);
var S1,S2,S3,FileName:string;
MyList:TStringList;
T:boolean;
begin
MyList:=TStringList.Create;
with ClientDataSet1 do
begin
First;
While Not Eof do
begin
S1:=Trim(FieldByName('主题').AsString);
S2:=Trim(FieldByName('名称').AsString);
T:=FieldByName('选择').AsBoolean;
if Checkbox2.Checked then
begin
if T and (S1<>'') and (S2<>'') then
begin
FileName:=Edit1.Text+'\'+S1+'_'+S2+'.txt';
if FileExists(FileName) then
begin
MyList.LoadFromFile(FileName);
Edit;
FieldByName('ITEMS').AsString:=MyList.text;
Post;
end;
end
end
else begin
if (S1<>'') and (S2<>'') then
begin
FileName:=Edit1.Text+'\'+S1+'_'+S2+'.txt';
if FileExists(FileName) then
begin
MyList.LoadFromFile(FileName);
Edit;
FieldByName('ITEMS').AsString:=MyList.text;
Post;
end;
end
end;
Next;
end;
First;
end;
MyList.Free;
end;
经过一个下午的努力。
如下:数据集循环时,不直接读写磁盘,需是调用另一个对单条数据进行读写的操作。经测试,通过。不再出现类似的问题。
代码:
procedure TSys_Config_Frm.sButton8Click(Sender: TObject);
begin
with ClientDataSet1 do
begin
First;
While Not Eof do
begin
if FieldByName('选择').AsBoolean then
Button13Click(Sender); // 读入一条
Next;
end;
First;
end;
end;
procedure TSys_Config_Frm.sButton10Click(Sender: TObject);
begin
with ClientDataSet1 do
begin
First;
While Not Eof do
begin
if FieldByName('选择').AsBoolean then
Button14Click(Sender); // 写入一条
Next;
end;
First;
end;
end;
真正的原理,不得而知。有知道的同仁,告知一下。