求贤!!这种情况下:如何动态改变表的结构? ( 积分: 5 )

  • 主题发起人 主题发起人 ruoxi_shuai
  • 开始时间 开始时间
R

ruoxi_shuai

Unregistered / Unconfirmed
GUEST, unregistred user!
现有一DBF数据库,一表为工资结构组成T1,另一表为工资数据组成T2,其中,T1中的一列的列值是T2的字段名,现要求T1中的数据变化时T2也随之自动变化,即T1种插入、删除、修改一条记录时,T2也会相应的插入、删除、修改与之对应的字段,该怎么办比较好,不用存储过程可以实现吗?请指教!!!
我编了如下的程序:
//删除T1种的一条记录时,其中T1对应了一DBGRID
if key = Vk_delete then
begin
flag:=messagedlg('您确定要删除当前纪录吗?',mtconfirmation,[mbyes,mbno],0);
if flag=6 then
s_delete:=adotable1.Fields[0].AsString;
with adoquery1 do //adoquery1连接T2
begin
close;
sql.Clear;
sql.Add('alter table GZSJK ');
sql.Add('drop column '+s_delete+' ascade');
ExecSQL;
end;
ADOtable1.Delete;
end;
//T1插入一条记录时,向T2中增加字段
procedure TForm_JG.DBGrid1DblClick(Sender: TObject);
var
feild_N,field_T:string;
length,point_count:integer;
begin
adotable1.Post;
feild_N:=adotable1.Fields[0].AsString;
field_T:=adotable1.Fields[2].AsString;
length:=adotable1.Fields[3].AsInteger;
point_count:=adotable1.Fields[4].AsInteger;
with adoquery1 do
begin
close;
sql.Clear;
sql.Add('alter table GZSJK ');
if field_T='C' then
begin
sql.Add('add column '+feild_N+' varchar(:a) ');
Parameters.ParamByName('a').Value := length;
end;
if field_T='N' then
begin
sql.Add('add column '+feild_N+' numeric(:c,:d)');
Parameters.ParamByName('c').Value := length;
Parameters.ParamByName('d').Value := point_count;
end;
ExecSQL;
end;
showmessage('添加记录已保存,并更新到GZSJK中!');
end;

我觉得原理上对,可运行有错,求各位提供更好的方法!
 
怎么没人答复????
 
if fkind='新增' then
begin
sqlstr:='select 1 from syscolumns where id= OBJECT_ID(''clv_employee'') and name='+QuotedStr(atblist.fieldbyname('itemname').AsString) ;
fdm.Exec_SqlOpen(sqlstr);
if Fdm.CommAdoQry.IsEmpty then
begin
sqlstr:='alter table clv_employee '+char(13)+' add '+ atblist.fieldbyname('itemname').AsString+' decimal(18,6) DEFAULT 0';
fdm.Exec_Sql(sqlstr);
sqlstr:='alter table clv_CollectRecord_temp '+char(13)+' add '+ atblist.fieldbyname('itemname').AsString+' decimal(18,6) DEFAULT 0';
fdm.Exec_Sql(sqlstr);
sqlstr:=' insert into clv_TableAssert(TableName, TableChinese, Fieldname, FieldChinese, Flag)values('
+'''clv_CollectRecord_TEMP'',''考勤记录汇总表'','+QuotedStr(atblist.fieldbyname('itemname').AsString)
+','+QuotedStr(atblist.fieldbyname('itemname').AsString)+',2)';
fdm.Exec_Sql(sqlstr);
end;
end
else
begin
sqlstr:='EXECUTE sp_rename N'+quotedstr('clv_employee.'+foldname)+', N'+quotedstr(atblist.fieldbyname('itemname').AsString)+', ''COLUMN''';
fdm.Exec_Sql(sqlstr);
sqlstr:='EXECUTE sp_rename N'+quotedstr('clv_CollectRecord_temp.'+foldname)+', N'+quotedstr(atblist.fieldbyname('itemname').AsString)+', ''COLUMN''';
fdm.Exec_Sql(sqlstr);
sqlstr:=' update clv_TableAssert set Fieldname='+quotedstr(atblist.fieldbyname('itemname').AsString)
+',FieldChinese='+ quotedstr(atblist.fieldbyname('itemname').AsString)
+' where Fieldname='+quotedstr(foldname) ;
fdm.Exec_Sql(sqlstr);

end;


这是我当年写考勤用的,不过是SQL的数据库
 
后退
顶部