全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1320
推到 Plurk!
推到 Facebook!

請問如何改資料結構

答題得分者是:cmj
shing.net
中階會員


發表:207
回覆:124
積分:66
註冊:2002-03-16

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-06-19 09:26:39 IP:211.74.xxx.xxx 未訂閱
請問如何用程式改資料結構中一欄位的size 資料庫為dbase 如Cust.dbf 其欄位Addr的size 30-->60 謝謝
channel
尊榮會員


發表:67
回覆:707
積分:854
註冊:2002-05-02

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-06-19 09:42:13 IP:211.21.xxx.xxx 未訂閱
引言: 請問如何用程式改資料結構中一欄位的size 資料庫為dbase 如Cust.dbf 其欄位Addr的size 30-->60 謝謝
var
  qry: TQuery;
begin
  qry := TQuery.Create(nil);
  qry.DatabaseName := 'Your DatabaseName or BDE Alias Name'
  with qry do
  try
    SQL.Clear;
    SQL.Add('ALTER TABLE CUST ALTER COLUMN ADDR varchar(60) NULL');
    ExecSQL;
  finally
    Free;
  end;
end;
~小弟淺見,參考看看~
------
~小弟淺見,參考看看~
shing.net
中階會員


發表:207
回覆:124
積分:66
註冊:2002-03-16

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-06-19 10:26:12 IP:211.74.xxx.xxx 未訂閱
引言:
引言: 請問如何用程式改資料結構中一欄位的size 資料庫為dbase 如Cust.dbf 其欄位Addr的size 30-->60 謝謝
var
  qry: TQuery;
begin
  qry := TQuery.Create(nil);
  qry.DatabaseName := 'Your DatabaseName or BDE Alias Name'
  with qry do
  try
    SQL.Clear;
    SQL.Add('ALTER TABLE CUST ALTER COLUMN ADDR varchar(60) NULL');
    ExecSQL;
  finally
    Free;
  end;
end;
~小弟淺見,參考看看~
其 Local sql 之語法沒有ALTER COLUMN 謝謝 ALTER TABLE table_reference DROP [COLUMN] column_reference | ADD [COLUMN] column_reference [,reference DROP [COLUMN] column_reference | ADD [COLUMN] column_reference...]
cmj
高階會員


發表:15
回覆:242
積分:226
註冊:2002-06-12

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-06-19 13:03:04 IP:211.76.xxx.xxx 未訂閱
引言: 請問如何用程式改資料結構中一欄位的size 資料庫為dbase 如Cust.dbf 其欄位Addr的size 30-->60 謝謝
利用TTable元件來做
procedure TForm1.Button26Click(Sender: TObject);
var i:integer;
    TbNameOld,TbNameNew,FdName:string;
begin
  TbNameOld:='D:\CUST';
  TbNameNew:='D:\CUSTNEW';
  TbOld.TableName:=TbNameOld;
  TbNew.TableName:=TbNameNew;
  TbOld.TableType:=ttDbase; //DBASE檔
  TbNew.TableType:=ttDbase;
  TbOld.Open;
  TbNew.FieldDefs.Clear;
  for i:=0 to TbOld.FieldDefs.Count-1 do
   begin
     FdName:=UpperCase(TbOld.FieldDefs[i].Name);
     TbNew.FieldDefs.Add(TbOld.FieldDefs[i].Name,
                          TbOld.FieldDefs[i].DataType,
                          TbOld.FieldDefs[i].Size,
                          TbOld.FieldDefs[i].Required);
     if FdName='ADDR' then  //要修改之欄位
        TbNew.FieldDefs[i].Size:=60;
   end;
  TbNew.CreateTable; //建新檔
  TbOld.Close;
  TbNew.BatchMove(TbOld,batAppend);  //資料轉移
  TbOld.RenameTable(TbNameOld 'OLD'); //原檔案改名
  TbNew.RenameTable(TbNameOld);       //新檔更名原檔名
end;    
系統時間:2024-06-01 23:10:55
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!