📄 rmd_bde.pas
字号:
{*****************************************}
{ }
{ Report Machine v2.0 }
{ Wrapper for BDE }
{ }
{*****************************************}
unit RMD_BDE;
interface
{$I RM.INC}
{$IFDEF DM_BDE}
uses
Windows, Classes, SysUtils, Forms, Dialogs, ExtCtrls, StdCtrls, Controls, DB,
DBTables, RM_Class, RMD_DBWrap
{$IFDEF USE_INTERNAL_JVCL}
, rm_JvInterpreter, rm_JvInterpreter_DbTables
{$ELSE}
, JvInterpreter, JvInterpreter_DbTables
{$ENDIF}
{$IFDEF COMPILER6_UP}, Variants{$ENDIF};
type
TRMDBDEComponents = class(TComponent) // fake component
end;
{ TRMDBDEDatabase }
TRMDBDEDatabase = class(TRMDialogComponent)
private
FDatabase: TDatabase;
function GetConnected: Boolean;
procedure SetConnected(Value: Boolean);
function GetAliasName: string;
procedure SetAliasName(Value: string);
function GetDriverName: string;
procedure SetDriverName(Value: string);
function GetLoginPrompt: Boolean;
procedure SetLoginPrompt(Value: Boolean);
function GetParams: TStrings;
procedure SetParams(Value: TStrings);
function GetDatabaseName: string;
procedure SetDatabaseName(Value: string);
protected
public
constructor Create; override;
destructor Destroy; override;
procedure LoadFromStream(aStream: TStream); override;
procedure SaveToStream(aStream: TStream); override;
procedure ShowEditor; override;
property Database: TDatabase read FDatabase;
published
property Connected: Boolean read GetConnected write SetConnected;
property AliasName: string read GetAliasName write SetAliasName;
property DriverName: string read GetDriverName write SetDriverName;
property LoginPrompt: Boolean read GetLoginPrompt write SetLoginPrompt;
property Params: TStrings read GetParams write SetParams;
property DatabaseName: string read GetDatabaseName write SetDatabaseName;
end;
{ TRMDBDETable }
TRMDBDETable = class(TRMDTable)
private
FTable: TTable;
protected
function GetTableName: string; override;
procedure SetTableName(Value: string); override;
function GetFilter: string; override;
procedure SetFilter(Value: string); override;
function GetIndexName: string; override;
procedure SetIndexName(Value: string); override;
function GetIndexFieldNames: string; override;
procedure SetIndexFieldNames(Value: string); override;
function GetMasterFields: string; override;
procedure SetMasterFields(Value: string); override;
function GetMasterSource: string; override;
procedure SetMasterSource(Value: string); override;
function GetDatabaseName: string; override;
procedure SetDatabaseName(const Value: string); override;
procedure GetIndexNames(sl: TStrings); override;
function GetIndexDefs: TIndexDefs; override;
public
constructor Create; override;
procedure LoadFromStream(aStream: TStream); override;
procedure SaveToStream(aStream: TStream); override;
published
property IndexName;
end;
{ TRMDBDEQuery}
TRMDBDEQuery = class(TRMDQuery)
private
FQuery: TQuery;
protected
function GetParamCount: Integer; override;
function GetSQL: string; override;
procedure SetSQL(Value: string); override;
function GetFilter: string; override;
procedure SetFilter(Value: string); override;
function GetDatabaseName: string; override;
procedure SetDatabaseName(const Value: string); override;
function GetDataSource: string; override;
procedure SetDataSource(Value: string); override;
function GetParamName(Index: Integer): string; override;
function GetParamType(Index: Integer): TFieldType; override;
procedure SetParamType(Index: Integer; Value: TFieldType); override;
function GetParamKind(Index: Integer): TRMParamKind; override;
procedure SetParamKind(Index: Integer; Value: TRMParamKind); override;
function GetParamText(Index: Integer): string; override;
procedure SetParamText(Index: Integer; Value: string); override;
function GetParamValue(Index: Integer): Variant; override;
procedure SetParamValue(Index: Integer; Value: Variant); override;
procedure GetDatabases(sl: TStrings); override;
procedure GetTableNames(DB: string; Strings: TStrings); override;
procedure GetTableFieldNames(const DB, TName: string; sl: TStrings); override;
public
constructor Create; override;
procedure LoadFromStream(aStream: TStream); override;
procedure SaveToStream(aStream: TStream); override;
published
property DataSource;
end;
{ TDBEditForm }
TRMDFormBDEDBProp = class(TForm)
GroupBox1: TGroupBox;
Label1: TLabel;
cmbAliasName: TComboBox;
Label2: TLabel;
cmbDriverName: TComboBox;
Label3: TLabel;
memDatabaseParams: TMemo;
btnDefaultsParam: TButton;
btnClearParam: TButton;
btnOK: TButton;
btnCancel: TButton;
Label4: TLabel;
edtDBName: TEdit;
btnPath: TButton;
procedure cmbAliasNameChange(Sender: TObject);
procedure cmbAliasNameDropDown(Sender: TObject);
procedure cmbDriverNameChange(Sender: TObject);
procedure cmbDriverNameDropDown(Sender: TObject);
procedure btnDefaultsParamClick(Sender: TObject);
procedure btnClearParamClick(Sender: TObject);
procedure btnOKClick(Sender: TObject);
procedure btnPathClick(Sender: TObject);
procedure FormCreate(Sender: TObject);
private
FDatabase: TDatabase;
function Edit: Boolean;
procedure Localize;
end;
{$ENDIF}
implementation
{$IFDEF DM_BDE}
{$R *.DFM}
{$R RMD_BDE.RES}
uses BdeConst, BDE, RM_Utils, RM_Const, RM_DsgCtrls, RM_Common, RM_PropInsp, RM_Insp;
{------------------------------------------------------------------------------}
{------------------------------------------------------------------------------}
{TRMDBDEDatabase}
constructor TRMDBDEDatabase.Create;
begin
inherited Create;
BaseName := 'Database';
FBmpRes := 'RMD_BDEDB';
FDatabase := TDataBase.Create(RMDialogForm);
DontUndo := True;
FComponent := FDatabase;
end;
destructor TRMDBDEDatabase.Destroy;
begin
if Assigned(RMDialogForm) then
begin
FreeAndNil(FDatabase);
end;
inherited Destroy;
end;
procedure TRMDBDEDatabase.LoadFromStream(aStream: TStream);
var
s: string;
begin
inherited LoadFromStream(aStream);
RMReadWord(aStream);
FDatabase.DatabaseName := RMReadString(aStream);
s := RMReadString(aStream);
if s <> '' then
FDatabase.AliasName := s;
s := RMReadString(aStream);
if s <> '' then
FDatabase.DriverName := s;
FDatabase.LoginPrompt := RMReadBoolean(aStream);
RMReadMemo(aStream, FDatabase.Params);
FDatabase.Connected := RMReadBoolean(aStream);
end;
procedure TRMDBDEDatabase.SaveToStream(aStream: TStream);
begin
inherited SaveToStream(aStream);
RMWriteWord(aStream, 0);
RMWriteString(aStream, FDatabase.DatabaseName);
RMWriteString(aStream, FDatabase.AliasName);
RMWriteString(aStream, FDatabase.DriverName);
RMWriteBoolean(aStream, FDatabase.LoginPrompt);
RMWriteMemo(aStream, FDatabase.Params);
RMWriteBoolean(aStream, FDatabase.Connected);
end;
function TRMDBDEDatabase.GetConnected: Boolean;
begin
Result := FDatabase.Connected;
end;
procedure TRMDBDEDatabase.SetConnected(Value: Boolean);
begin
FDatabase.Connected := Value;
end;
function TRMDBDEDatabase.GetAliasName: string;
begin
Result := FDatabase.AliasName;
end;
procedure TRMDBDEDatabase.SetAliasName(Value: string);
begin
FDatabase.AliasName := Value;
end;
function TRMDBDEDatabase.GetDriverName: string;
begin
Result := FDatabase.DriverName;
end;
procedure TRMDBDEDatabase.SetDriverName(Value: string);
begin
FDatabase.DriverName := Value;
end;
function TRMDBDEDatabase.GetLoginPrompt: Boolean;
begin
Result := FDatabase.LoginPrompt;
end;
procedure TRMDBDEDatabase.SetLoginPrompt(Value: Boolean);
begin
FDatabase.LoginPrompt := Value;
end;
function TRMDBDEDatabase.GetParams: TStrings;
begin
Result := FDatabase.Params;
end;
procedure TRMDBDEDatabase.SetParams(Value: TStrings);
begin
FDatabase.Params.Assign(Value);
end;
function TRMDBDEDatabase.GetDatabaseName: string;
begin
Result := FDatabase.DatabaseName;
end;
procedure TRMDBDEDatabase.SetDatabaseName(Value: string);
begin
FDatabase.DatabaseName := Value;
end;
procedure TRMDBDEDatabase.ShowEditor;
var
tmp: TRMDFormBDEDBProp;
begin
tmp := TRMDFormBDEDBProp.Create(nil);
try
tmp.FDatabase := Self.FDatabase;
if tmp.Edit then
begin
RMDesigner.BeforeChange;
RMDesigner.AfterChange;
end;
finally
tmp.Free;
end;
end;
{------------------------------------------------------------------------------}
{------------------------------------------------------------------------------}
{TRMDBDETable}
constructor TRMDBDETable.Create;
begin
inherited Create;
BaseName := 'Table';
FBmpRes := 'RMD_BDETABLE';
FTable := TTable.Create(RMDialogForm);
DataSet := FTable;
FComponent := FTable;
FIndexBased := True;
end;
procedure TRMDBDETable.LoadFromStream(aStream: TStream);
begin
inherited LoadFromStream(aStream);
RMReadWord(aStream);
end;
procedure TRMDBDETable.SaveToStream(aStream: TStream);
begin
inherited SaveToStream(aStream);
RMWriteWord(aStream, 0);
end;
procedure TRMDBDETable.GetIndexNames(sl: TStrings);
begin
try
if Length(FTable.TableName) > 0 then
begin
FTable.GetIndexNames(sl);
end;
except
end;
end;
function TRMDBDETable.GetIndexDefs: TIndexDefs;
begin
Result := FTable.IndexDefs;
end;
function TRMDBDETable.GetDatabaseName: string;
begin
Result := FTable.DatabaseName;
end;
procedure TRMDBDETable.SetDatabaseName(const Value: string);
begin
FTable.Active := False;
FTable.DatabaseName := Value;
end;
function TRMDBDETable.GetTableName: string;
begin
Result := FTable.TableName;
end;
procedure TRMDBDETable.SetTableName(Value: string);
begin
FTable.Active := False;
FTable.TableName := Value;
end;
function TRMDBDETable.GetFilter: string;
begin
Result := FTable.Filter;
end;
procedure TRMDBDETable.SetFilter(Value: string);
begin
FTable.Active := False;
FTable.Filter := Value;
FTable.Filtered := Value <> '';
end;
function TRMDBDETable.GetIndexName: string;
begin
Result := FTable.IndexName;
end;
procedure TRMDBDETable.SetIndexName(Value: string);
begin
FTable.Active := False;
FTable.IndexName := Value;
end;
function TRMDBDETable.GetIndexFieldNames: string;
begin
Result := FTable.IndexFieldNames;
end;
procedure TRMDBDETable.SetIndexFieldNames(Value: string);
begin
FTable.IndexFieldNames := Value;
end;
function TRMDBDETable.GetMasterFields: string;
begin
Result := FTable.MasterFields;
end;
procedure TRMDBDETable.SetMasterFields(Value: string);
begin
FTable.MasterFields := Value;
end;
function TRMDBDETable.GetMasterSource: string;
begin
Result := RMGetDataSetName(FTable.Owner, FTable.MasterSource)
end;
procedure TRMDBDETable.SetMasterSource(Value: string);
var
liComponent: TComponent;
begin
liComponent := RMFindComponent(FTable.Owner, Value);
if (liComponent <> nil) and (liComponent is TDataSet) then
FTable.MasterSource := RMGetDataSource(FTable.Owner, TDataSet(liComponent))
else
FTable.MasterSource := nil;
end;
{------------------------------------------------------------------------------}
{------------------------------------------------------------------------------}
{TRMDBDEQuery}
constructor TRMDBDEQuery.Create;
begin
inherited Create;
BaseName := 'Query';
FBmpRes := 'RMD_BDEQUERY';
FQuery := TQuery.Create(RMDialogForm);
DataSet := FQuery;
FComponent := FQuery;
end;
procedure TRMDBDEQuery.LoadFromStream(aStream: TStream);
begin
inherited LoadFromStream(aStream);
RMReadWord(aStream);
end;
procedure TRMDBDEQuery.SaveToStream(aStream: TStream);
begin
inherited SaveToStream(aStream);
RMWriteWord(aStream, 0);
end;
function TRMDBDEQuery.GetParamCount: Integer;
begin
Result := FQuery.ParamCount;
end;
function TRMDBDEQuery.GetSQL: string;
begin
Result := FQuery.SQL.Text;
end;
procedure TRMDBDEQuery.SetSQL(Value: string);
begin
FQuery.SQL.Text := Value;
end;
function TRMDBDEQuery.GetDatabaseName: string;
begin
Result := FQuery.DatabaseName;
end;
procedure TRMDBDEQuery.SetDatabaseName(const Value: string);
begin
FQuery.Active := False;
FQuery.DatabaseName := Value;
end;
function TRMDBDEQuery.GetFilter: string;
begin
Result := FQuery.Filter;
end;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -