線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:1414
推到 Plurk!
推到 Facebook!

使用自訂函數執行ADO資料庫程式執行出現00000344錯誤

 
esp_pzj
初階會員


發表:32
回覆:70
積分:40
註冊:2007-02-09

發送簡訊給我
#1 引用回覆 回覆 發表時間:2007-02-28 18:00:33 IP:219.86.xxx.xxx 訂閱
請問各位高手:
我如何把ADO資料庫執行的程式放到自訂函數內:
編譯沒錯誤 執行時出現 Project Education.exe raised exception class EAccessViolation with message 'Access violation at address 00401E95 in module 'Education.exe'.Read of address 00000344'. Process stopped. Use Step or Run to continue.



以下是程式碼:
<textarea class="cpp" rows="10" cols="60" name="code"> //--------------------------------------------------------------------------- #include #pragma hdrstop #include "Unit1.h" #include "Unit2.h" //--------------------------------------------------------------------------- #pragma package(smart_init) #pragma resource "*.dfm" TForm_Personnel *Form_Personnel; //--------------------------------------------------------------------------- void ShowData(){ Form_Personnel->ADOQuery1->SQL->Clear(); Form_Personnel->ADOQuery1->SQL->Add("Select * from Personnel"); Form_Personnel->ADOQuery1->Open(); Form_Personnel->Ed_Id->Text= Form_Personnel->ADOQuery1->FieldByName("P_Id")->AsString; Form_Personnel->Ed_Account->Text= Form_Personnel->ADOQuery1->FieldByName("P_Account")->AsString; Form_Personnel->Ed_Cipher->Text= Form_Personnel->ADOQuery1->FieldByName("P_Cipher")->AsString; Form_Personnel->Ed_Birthday->Text= Form_Personnel->ADOQuery1->FieldByName("P_Birthday")->AsString; Form_Personnel->Ed_Address->Text= Form_Personnel->ADOQuery1->FieldByName("P_Address")->AsString; Form_Personnel->Ed_Movele->Text= Form_Personnel->ADOQuery1->FieldByName("P_Movele")->AsString; Form_Personnel->Ed_TEL->Text= Form_Personnel->ADOQuery1->FieldByName("P_TEL")->AsString; Form_Personnel->Ed_Liaison->Text= Form_Personnel->ADOQuery1->FieldByName("P_Liaison")->AsString; Form_Personnel->Ed_Department->Text= Form_Personnel->ADOQuery1->FieldByName("P_Department")->AsString; Form_Personnel->Ed_Professional->Text= Form_Personnel->ADOQuery1->FieldByName("P_Professional")->AsString; Form_Personnel->Ed_Plane->Text= Form_Personnel->ADOQuery1->FieldByName("P_Plane")->AsString; Form_Personnel->Ed_Workday->Text= Form_Personnel->ADOQuery1->FieldByName("P_Workday")->AsString; Form_Personnel->Ed_Departee->Text= Form_Personnel->ADOQuery1->FieldByName("P_Departee")->AsString; } //--------------------------------------------------------------------------- __fastcall TForm_Personnel::TForm_Personnel(TComponent* Owner) : TForm(Owner) { } //--------------------------------------------------------------------------- void __fastcall TForm_Personnel::FormClose(TObject *Sender, TCloseAction &Action) { Action=caFree; } //--------------------------------------------------------------------------- void __fastcall TForm_Personnel::FormCreate(TObject *Sender) { ShowData(); } </textarea>
------
學藝不精 謝多多指教
Stallion
版主


發表:52
回覆:1600
積分:1995
註冊:2004-09-15

發送簡訊給我
#2 引用回覆 回覆 發表時間:2007-02-28 18:36:49 IP:211.22.xxx.xxx 未訂閱
這是程式結構安排錯誤發生的問題。
當你的主FORM(TForm_Personnel:)還在CREATE的時候,你就要使用其上的子元件ADO元件去存取資料庫,然此時ADO元件尚未初始化!才發生此種錯誤。
建議將ADO元件放在單獨的DATAMODULE裡面,其後在專案檔裡面先將DATAMODULE這個FORM CREATE起來,之後在
Personnel這個單元裡面include ADO元件所在的DATAMODULE後,再引用其中的ADO元件來存取資料。
請參考~
系統時間:2024-04-26 15:23:06
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!