📄 rmd_dbisam.pas
字号:
{*****************************************}
{ }
{ Report Machine 2.0 }
{ Wrapper for DBIASM }
{ }
{*****************************************}
unit RMD_Dbisam;
interface
{$I RM.INC}
{$IFDEF DM_DBISAM}
uses
Classes, SysUtils, Forms, ExtCtrls, DB, Dialogs, Controls, StdCtrls,
RM_Class, RMD_DBWrap, DBISAMTb
{$IFDEF Delphi6}, Variants{$ENDIF};
type
TRMDDBISAMComponents = class(TComponent) // fake component
end;
TRMDDBISAMDatabase = class(TRMNonVisualControl)
private
FDatabase: TDBISAMDatabase;
procedure PropEditor(Sender: TObject);
protected
procedure SetPropValue(Index: string; Value: Variant); override;
function GetPropValue(Index: string): Variant; override;
public
constructor Create; override;
destructor Destroy; override;
procedure LoadFromStream(Stream: TStream); override;
procedure SaveToStream(Stream: TStream); override;
procedure DefineProperties; override;
procedure ShowEditor; override;
property Database: TDBISAMDatabase read FDatabase;
end;
{ TRMDDBISAMTable }
TRMDDBISAMTable = class(TRMDTable)
private
FTable: TDBISAMTable;
protected
function GetDatabases: string; override;
function GetTableNames: string; override;
procedure SetPropValue(Index: string; Value: Variant); override;
function GetPropValue(Index: string): Variant; override;
public
constructor Create; override;
procedure GetIndexNames(sl: TStrings); override;
procedure DefineProperties; override;
procedure LoadFromStream(Stream: TStream); override;
procedure SaveToStream(Stream: TStream); override;
end;
{ TRMDDBISAMQuery }
TRMDDBISAMQuery = class(TRMDQuery)
private
FQuery: TDBISAMQuery;
protected
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;
function GetDatabases: string; override;
procedure GetTableNames(DB: string; Strings: TStrings); override;
procedure SetPropValue(Index: string; Value: Variant); override;
function GetPropValue(Index: string): Variant; override;
function DoMethod(const MethodName: string; Par1, Par2, Par3: Variant): Variant; override;
public
constructor Create; override;
procedure GetTableFieldNames(const DB, TName: string; sl: TStrings); override;
procedure DefineProperties; override;
procedure LoadFromStream(Stream: TStream); override;
procedure SaveToStream(Stream: TStream); override;
published
end;
{$ENDIF}
implementation
{$IFDEF DM_DBISAM}
uses FileCtrl, RM_Const, RM_CmpReg, RM_utils;
{$R RMD_DBISAM.RES}
{------------------------------------------------------------------------------}
{------------------------------------------------------------------------------}
{TRMDDBISAMDatabase}
constructor TRMDDBISAMDatabase.Create;
begin
inherited Create;
FDatabase := TDBISAMDatabase.Create(RMDialogForm);
Component := FDatabase;
BaseName := 'DBISAMDatabase';
Bmp.LoadFromResourceName(hInstance, 'RMD_DBISAMDB');
Flags := Flags or flDontUndo;
end;
destructor TRMDDBISAMDatabase.Destroy;
begin
if Assigned(RMDialogForm) then
FDatabase.Free;
inherited Destroy;
end;
procedure TRMDDBISAMDatabase.DefineProperties;
begin
inherited DefineProperties;
AddProperty('Connected', [rmdtBoolean], nil);
AddProperty('DatabaseName', [rmdtString], nil);
AddProperty('Directory', [rmdtString, rmdtHasEditor], PropEditor);
end;
procedure TRMDDBISAMDatabase.SetPropValue(Index: string; Value: Variant);
begin
inherited SetPropValue(Index, Value);
Index := AnsiUpperCase(Index);
if Index = 'DATABASENAME' then
FDatabase.DatabaseName := Value
else if Index = 'DIRECTORY' then
FDatabase.Directory := Value
else if Index = 'CONNECTED' then
FDatabase.Connected := Value;
end;
function TRMDDBISAMDatabase.GetPropValue(Index: string): Variant;
begin
Index := AnsiUpperCase(Index);
Result := inherited GetPropValue(Index);
if Result <> Null then Exit;
if Index = 'DATABASENAME' then
Result := FDatabase.DatabaseName
else if Index = 'DIRECTORY' then
Result := FDatabase.Directory
else if Index = 'CONNECTED' then
Result := FDatabase.Connected;
end;
procedure TRMDDBISAMDatabase.LoadFromStream(Stream: TStream);
begin
inherited LoadFromStream(Stream);
FDatabase.DatabaseName := RMReadString(Stream);
FDatabase.Directory := RMReadString(Stream);
FDatabase.Connected := RMReadBoolean(Stream);
end;
procedure TRMDDBISAMDatabase.SaveToStream(Stream: TStream);
begin
LVersion := 0;
inherited SaveToStream(Stream);
RMWriteString(Stream, FDatabase.DatabaseName);
RMWriteString(Stream, FDatabase.Directory);
RMWriteBoolean(Stream, FDatabase.Connected);
end;
procedure TRMDDBISAMDatabase.ShowEditor;
begin
PropEditor(nil);
end;
procedure TRMDDBISAMDatabase.PropEditor(Sender: TObject);
var
str: string;
i: integer;
t: TRMView;
begin
if SelectDirectory('选择文件夹', '', str) then
begin
RMDesigner.BeforeChange;
for i := 0 to RMDesigner.Page.Objects.Count - 1 do
begin
t := RMDesigner.Page.Objects[i];
if (t.Selected) and (t is TRMDDBISAMDatabase) then
TRMDDBISAMDatabase(t).FDatabase.Directory := str;
end;
RMDesigner.AfterChange;
end;
end;
{------------------------------------------------------------------------------}
{------------------------------------------------------------------------------}
{TRMDDBISAMTable}
constructor TRMDDBISAMTable.Create;
begin
inherited Create;
FTable := TDBISAMTable.Create(RMDialogForm);
DataSet := FTable;
Component := FTable;
BaseName := 'DBISAMTable';
Bmp.LoadFromResourceName(hInstance, 'RMD_DBISAMTABLE');
end;
function TRMDDBISAMTable.GetDatabases: string;
var
i: Integer;
sl: TStringList;
begin
Result := '';
sl := TStringList.Create;
try
try
FTable.DBSession.GetDatabaseNames(sl);
sl.Sort;
for i := 0 to sl.Count - 1 do
Result := Result + sl[i] + ';';
except
end;
finally
sl.Free;
end;
end;
procedure TRMDDBISAMTable.GetIndexNames(sl: TStrings);
var
i: Integer;
begin
sl.Clear;
try
if (Length(FTable.TableName) > 0) and (FTable.IndexDefs <> nil) then
begin
FTable.IndexDefs.Update;
for i := 0 to FTable.IndexDefs.Count - 1 do
begin
if FTable.IndexDefs[i].Name <> '' then
sl.Add(FTable.IndexDefs[i].Name);
end;
end;
except
end;
end;
function TRMDDBISAMTable.GetTableNames: string;
var
i: Integer;
sl: TStringList;
begin
Result := '';
if FTable.DatabaseName <> '' then
begin
sl := TStringList.Create;
try
try
FTable.DBSession.GetTableNames(FTable.DatabaseName, sl);
sl.Sort;
for i := 0 to sl.Count - 1 do
Result := Result + sl[i] + ';';
except
end;
finally
sl.Free;
end;
end;
end;
procedure TRMDDBISAMTable.DefineProperties;
begin
inherited DefineProperties;
end;
procedure TRMDDBISAMTable.SetPropValue(Index: string; Value: Variant);
var
d: TComponent;
begin
inherited SetPropValue(Index, Value);
Index := AnsiUpperCase(Index);
if Index = 'INDEXNAME' then
FTable.IndexFieldNames := Value //FTable.IndexName := Value
else if Index = 'MASTERSOURCE' then
begin
d := RMFindComponent(FTable.Owner, Value);
FTable.MasterSource := RMGetDataSource(FTable.Owner, TDataSet(d));
end
else if Index = 'MASTERFIELDS' then
FTable.MasterFields := Value
else if Index = 'TABLENAME' then
begin
FTable.Close;
FTable.TableName := Value;
end
else if index = 'DATABASE' then
begin
FTable.Close;
FTable.DatabaseName := Value;
end
end;
function TRMDDBISAMTable.GetPropValue(Index: string): Variant;
begin
Index := AnsiUpperCase(Index);
Result := inherited GetPropValue(Index);
if Result <> Null then Exit;
if Index = 'INDEXNAME' then
Result := FTable.IndexFieldNames //Result := FTable.IndexName
else if Index = 'MASTERSOURCE' then
Result := RMGetDataSetName(FTable.Owner, FTable.MasterSource)
else if Index = 'MASTERFIELDS' then
Result := FTable.MasterFields
else if Index = 'TABLENAME' then
Result := FTable.TableName
else if Index = 'DATABASE' then
Result := FTable.DatabaseName;
end;
procedure TRMDDBISAMTable.LoadFromStream(Stream: TStream);
begin
inherited LoadFromStream(Stream);
end;
procedure TRMDDBISAMTable.SaveToStream(Stream: TStream);
begin
LVersion := 0;
inherited SaveToStream(Stream);
end;
{------------------------------------------------------------------------------}
{------------------------------------------------------------------------------}
{TRMDDBISAMQuery}
constructor TRMDDBISAMQuery.Create;
begin
inherited Create;
FQuery := TDBISAMQuery.Create(RMDialogForm);
DataSet := FQuery;
Component := FQuery;
BaseName := 'DBISAMQuery';
Bmp.LoadFromResourceName(hInstance, 'RMD_DBISAMQUERY');
end;
procedure TRMDDBISAMQuery.DefineProperties;
begin
inherited DefineProperties;
end;
procedure TRMDDBISAMQuery.SetPropValue(Index: string; Value: Variant);
var
d: TComponent;
begin
inherited SetPropValue(Index, Value);
Index := AnsiUpperCase(Index);
if index = 'DATABASE' then
begin
FQuery.Close;
FQuery.DatabaseName := Value;
end
else if Index = 'DATASOURCE' then
begin
d := RMFindComponent(FQuery.Owner, Value);
FQuery.DataSource := RMGetDataSource(FQuery.Owner, TDataSet(d));
end
else if index = 'PARAMS.COUNT' then
begin
end
else if Index = 'SQL' then
begin
FQuery.Close;
FQuery.SQL.Text := Value;
end
end;
function TRMDDBISAMQuery.GetPropValue(Index: string): Variant;
begin
Index := AnsiUpperCase(Index);
Result := inherited GetPropValue(Index);
if Result <> Null then Exit;
if Index = 'DATABASE' then
Result := FQuery.DatabaseName
else if Index = 'DATASOURCE' then
Result := RMGetDataSetName(FQuery.Owner, FQuery.DataSource)
else if Index = 'PARAMS.COUNT' then
Result := FQuery.Params.Count
else if Index = 'SQL' then
Result := FQuery.SQL.Text
else if Index = 'SQL.COUNT' then
Result := FQuery.SQL.Count
end;
function TRMDDBISAMQuery.DoMethod(const MethodName: string; Par1, Par2, Par3: Variant): Variant;
begin
Result := inherited DoMethod(MethodName, Par1, Par2, Par3);
if Result = Null then
Result := LinesMethod(FQuery.SQL, MethodName, 'SQL', Par1, Par2, Par3);
if MethodName = 'EXECSQL' then
begin
OnBeforeOpenQueryEvent(FQuery);
FQuery.ExecSQL;
end;
end;
procedure TRMDDBISAMQuery.LoadFromStream(Stream: TStream);
begin
inherited LoadFromStream(Stream);
end;
procedure TRMDDBISAMQuery.SaveToStream(Stream: TStream);
begin
LVersion := 0;
inherited SaveToStream(Stream);
end;
function TRMDDBISAMQuery.GetDatabases: string;
var
i: integer;
sl: TStringList;
begin
Result := '';
sl := TStringList.Create;
try
try
FQuery.DBSession.GetDatabaseNames(sl);
sl.Sort;
for i := 0 to sl.Count - 1 do
Result := Result + sl[i] + ';';
except
end;
finally
sl.Free;
end;
end;
procedure TRMDDBISAMQuery.GetTableNames(DB: string; Strings: TStrings);
var
sl: TStringList;
begin
Strings.Clear;
sl := TStringList.Create;
try
if FQuery.DatabaseName <> '' then
begin
try
FQuery.DBSession.GetTableNames(FQuery.DatabaseName, sl);
sl.Sort;
Strings.Assign(sl);
except
end;
end;
finally
sl.Free;
end;
end;
procedure TRMDDBISAMQuery.GetTableFieldNames(const DB, TName: string; sl: TStrings);
var
i: Integer;
lStrings: TStringList;
t: TDBISAMTable;
begin
lStrings := TStringList.Create;
t := TDBISAMTable.Create(RMDialogForm);
try
t.DatabaseName := FQuery.DatabaseName;
t.TableName := tName;
try
t.FieldDefs.UpDate;
for i := 0 to t.FieldDefs.Count - 1 do
lStrings.Add(t.FieldDefs.Items[i].Name);
lStrings.Sort;
sl.Assign(lStrings);
except;
end;
finally
lStrings.Free;
t.Free;
end;
end;
function TRMDDBISAMQuery.GetParamName(Index: Integer): string;
begin
Result := FQuery.Params[Index].Name;
end;
function TRMDDBISAMQuery.GetParamType(Index: Integer): TFieldType;
begin
Result := FQuery.Params[Index].DataType;
end;
procedure TRMDDBISAMQuery.SetParamType(Index: Integer; Value: TFieldType);
begin
FQuery.Params[Index].DataType := Value;
end;
function TRMDDBISAMQuery.GetParamKind(Index: Integer): TRMParamKind;
begin
Result := rmpkValue;
if not FQuery.Params[Index].Bound then
Result := rmpkAssignFromMaster;
end;
procedure TRMDDBISAMQuery.SetParamKind(Index: Integer; Value: TRMParamKind);
begin
if Value = rmpkAssignFromMaster then
begin
FQuery.Params[Index].Bound := False;
FParams.Delete(FParams.IndexOf(FQuery.Params[Index].Name));
end
else
begin
FQuery.Params[Index].Clear;
FQuery.Params[Index].Bound := True;
FParams[FQuery.Params[Index].Name] := '';
end;
end;
function TRMDDBISAMQuery.GetParamText(Index: Integer): string;
begin
Result := '';
if ParamKind[Index] = rmpkValue then
Result := FParams[FQuery.Params[Index].Name];
end;
procedure TRMDDBISAMQuery.SetParamText(Index: Integer; Value: string);
begin
if ParamKind[Index] = rmpkValue then
FParams[FQuery.Params[Index].Name] := Value;
end;
function TRMDDBISAMQuery.GetParamValue(Index: Integer): Variant;
begin
Result := FQuery.Params[Index].Value;
end;
procedure TRMDDBISAMQuery.SetParamValue(Index: Integer; Value: Variant);
begin
FQuery.Params[Index].Value := Value;
end;
initialization
RMRegisterControl(TRMDDBISAMDatabase, 'RMD_DBISAMDB', RMLoadStr(SInsertDB));
RMRegisterControl(TRMDDBISAMTable, 'RMD_DBISAMTABLE', RMLoadStr(SInsertTable));
RMRegisterControl(TRMDDBISAMQuery, 'RMD_DBISAMQUERY', RMLoadStr(SInsertQuery));
finalization
{$ENDIF}
end.
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -