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

WinPgAP-SetUp之六_如何自動判斷已有某個User

答題得分者是:kevin2004
limary
初階會員


發表:41
回覆:109
積分:30
註冊:2007-01-11

發送簡訊給我
#1 引用回覆 回覆 發表時間:2008-08-16 07:07:56 IP:61.219.xxx.xxx 未訂閱
我要新增一個資料庫前,我必需確認我已經成功加入了一個User,這我要如何以
程式表現及執行這個功能,以讓我的流程能順暢執行?謝謝指點。
kevin2004
資深會員


發表:18
回覆:463
積分:416
註冊:2005-05-29

發送簡訊給我
#2 引用回覆 回覆 發表時間:2008-08-17 13:29:28 IP:61.219.xxx.xxx 未訂閱
用select * from pg_roles where...
------
Kevin
kevin2004
資深會員


發表:18
回覆:463
積分:416
註冊:2005-05-29

發送簡訊給我
#3 引用回覆 回覆 發表時間:2008-08-17 13:32:01 IP:61.219.xxx.xxx 未訂閱
以下是我自己寫的,不是公物碼。貼給你參考
function TPostgreSQLObject.FoundUser (
ThisMasterDbDsnName : string ;
SuperUserName : string ;
SuperUserPassWord : string ;
ThisUserName : string ) : Boolean ;
var
MyAdoConnection : TAdoConnection ;
MyAdoQuery : TAdoQuery ;
begin
try
MyAdoConnection := TAdoConnection.Create(Application);
MyAdoConnection.Mode := cmShareDenyNone ;
MyAdoConnection.LoginPrompt := False ;
MyAdoQuery := TAdoQuery.Create(Application);
try
MyAdoConnection.Close ;
MyAdoConnection.ConnectionString :=
GetODBCConnectionString ( ThisMasterDbDsnName ,
SuperUserName ,
SuperUserPassWord );
MyAdoConnection.Open ;
MyAdoQuery.Connection := MyAdoConnection ;
MyAdoQuery.SQL.Add(LowerCase(
'Select count(*) from pg_roles where rolname='''
ThisUserName '''' ));
MyAdoQuery.Open ;
Result := MyAdoQuery.Fields[0].AsInteger > 0 ;
except
on E:Exception do
begin
File_Error (
'有錯誤發生:PostgreSQL.FoundUser--001' cEnter2
'請記下相關訊息及編號' cEnter2
E.Message ) ;
Result := False ;
end ;
end ;
finally
MyAdoQuery.Close ;
FreeAndNil ( MyAdoQuery ) ;
MyAdoConnection.Close ;
FreeAndNil ( MyAdoConnection ) ;
end ;
end ;
function TPostgreSQLObject.FoundUser (
ThisAdoConnection : TAdoConnection ;
ThisUserName : string ) : Boolean ;
var
MyAdoQuery : TAdoQuery ;
begin
try
MyAdoQuery := TAdoQuery.Create(Application);
try
if Not ThisAdoConnection.Connected then
ThisAdoConnection.Open ;
MyAdoQuery.Connection := ThisAdoConnection ;
MyAdoQuery.SQL.Add(LowerCase(
'Select count(*) from pg_roles where rolname='''
ThisUserName '''' ));
MyAdoQuery.Open ;
Result := MyAdoQuery.Fields[0].AsInteger > 0 ;
except
on E:Exception do
begin
File_Error (
'有錯誤發生:PostgreSQL.FoundUser--101' cEnter2
'請記下相關訊息及編號' cEnter2
E.Message ) ;
Result := False ;
end ;
end ;
finally
MyAdoQuery.Close ;
FreeAndNil ( MyAdoQuery ) ;
end ;
end ;
------
Kevin
編輯記錄
kevin2004 重新編輯於 2008-08-17 14:23:23, 註解 無‧
limary
初階會員


發表:41
回覆:109
積分:30
註冊:2007-01-11

發送簡訊給我
#4 引用回覆 回覆 發表時間:2008-08-17 16:30:25 IP:61.219.xxx.xxx 未訂閱
    有點看不太懂,這個ThisMasterDbDsnName是什麼?以及為何有分兩個函式的
理由。可能要請前輩回國後再請前輩釋疑了。
祝前輩一路順風。
系統時間:2024-04-24 8:33:30
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!