⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rmd_ibx.pas

📁 这是一个功能强大
💻 PAS
📖 第 1 页 / 共 2 页
字号:
procedure TRMDIBQuery.GetTableNames(DB: string; Strings: TStrings);
var
  sl: TStringList;
  lDatabase: TIBDatabase;
begin
  sl := TStringList.Create;
  try
    try
      lDatabase := RMFindComponent(FQuery.Owner, DB) as TIBDatabase;
      if lDatabase = nil then exit;
      if not lDatabase.Connected then
        lDatabase.Connected := True;
      if lDatabase.Connected then
        lDatabase.GetTableNames(sl);
      sl.Sort;
      Strings.Assign(sl);
    except;
    end;
  finally
    sl.Free;
  end;
end;

procedure TRMDIBQuery.GetTableFieldNames(const DB, TName: string; sl: TStrings);
var
  i: Integer;
  lStrings: TStringList;
  t: TIBTable;
begin
  lStrings := TStringList.Create;
  t := TIBTable.Create(RMDialogForm);
  try
    t.Database := RMFindComponent(FQuery.Owner, DB) as TIBDataBase;
    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 TRMDIBQuery.GetParamCount: Integer;
begin
  Result := FQuery.ParamCount;
end;

function TRMDIBQuery.GetSQL: string;
begin
  Result := FQuery.SQL.Text;
end;

procedure TRMDIBQuery.SetSQL(aSql: string);
begin
  FQuery.Close;
  FQuery.SQL.Text := aSQL;
end;

function TRMDIBQuery.GetFilter: string;
begin
  Result := FQuery.Filter;
end;

procedure TRMDIBQuery.SetFilter(Value: string);
begin
  FQuery.Active := False;
  FQuery.Filter := Value;
  FQuery.Filtered := Value <> '';
end;

function TRMDIBQuery.GetDatabaseName: string;
begin
  Result := '';
  if FQuery.Database <> nil then
  begin
    Result := FQuery.Database.Name;
    if FQuery.Database.Owner <> FQuery.Owner then
      Result := FQuery.Database.Owner.Name + '.' + Result;
  end;
end;

procedure TRMDIBQuery.SetDatabaseName(const Value: string);
var
  liComponent: TComponent;
begin
  FQuery.Close;
  liComponent := RMFindComponent(FQuery.Owner, Value);
  if (liComponent <> nil) and (liComponent is TIBDatabase) then
    FQuery.Database := TIBDatabase(liComponent)
  else
    FQuery.Database := nil;
end;

function TRMDIBQuery.GetDataSource: string;
begin
  Result := RMGetDataSetName(FQuery.Owner, FQuery.DataSource)
end;

procedure TRMDIBQuery.SetDataSource(Value: string);
var
  liComponent: TComponent;
begin
  liComponent := RMFindComponent(FQuery.Owner, Value);
  if (liComponent <> nil) and (liComponent is TDataSet) then
    FQuery.DataSource := RMGetDataSource(FQuery.Owner, TDataSet(liComponent))
  else
    FQuery.DataSource := nil;
end;

function TRMDIBQuery.GetParamName(Index: Integer): string;
begin
  Result := FQuery.Params[Index].Name;
end;

function TRMDIBQuery.GetParamType(Index: Integer): TFieldType;
begin
  Result := FQuery.Params[Index].DataType;
end;

procedure TRMDIBQuery.SetParamType(Index: Integer; Value: TFieldType);
begin
  FQuery.Params[Index].DataType := Value;
end;

function TRMDIBQuery.GetParamKind(Index: Integer): TRMParamKind;
begin
  Result := rmpkValue;
  if not FQuery.Params[Index].Bound then
    Result := rmpkAssignFromMaster;
end;

procedure TRMDIBQuery.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 TRMDIBQuery.GetParamText(Index: Integer): string;
begin
  Result := '';
  if ParamKind[Index] = rmpkValue then
    Result := FParams[FQuery.Params[Index].Name];
end;

procedure TRMDIBQuery.SetParamText(Index: Integer; Value: string);
begin
  if ParamKind[Index] = rmpkValue then
    FParams[FQuery.Params[Index].Name] := Value;
end;

function TRMDIBQuery.GetParamValue(Index: Integer): Variant;
begin
  Result := FQuery.Params[Index].Value;
end;

procedure TRMDIBQuery.SetParamValue(Index: Integer; Value: Variant);
begin
  FQuery.Params[Index].Value := Value;
end;


{------------------------------------------------------------------------------}
{------------------------------------------------------------------------------}
{TRMDFormIBXPropEdit}

procedure TRMDFormIBXPropEdit.Localize;
begin
  Font.Name := RMLoadStr(SRMDefaultFontName);
  Font.Size := StrToInt(RMLoadStr(SRMDefaultFontSize));
  Font.Charset := StrToInt(RMLoadStr(SCharset));

  RMSetStrProp(GroupBox1, 'Caption', rmRes + 3230);
  RMSetStrProp(rdbLocal, 'Caption', rmRes + 3241);
  RMSetStrProp(rdbRemote, 'Caption', rmRes + 3242);
  RMSetStrProp(Label3, 'Caption', rmRes + 3233);
  RMSetStrProp(btnBrowse, 'Caption', rmRes + 3249);
  RMSetStrProp(GroupBox2, 'Caption', rmRes + 3237);
  RMSetStrProp(Label4, 'Caption', rmRes + 3246);
  RMSetStrProp(Label5, 'Caption', rmRes + 3247);
  RMSetStrProp(Label7, 'Caption', rmRes + 3248);
  RMSetStrProp(Label6, 'Caption', rmRes + 3237);

  btnOk.Caption := RMLoadStr(SOK);
  btnCancel.Caption := RMLoadStr(SCancel);
end;

procedure TRMDFormIBXPropEdit.btnBrowseClick(Sender: TObject);
begin
  if OpenDialog1.Execute then
    edtDatabase.Text := OpenDialog1.FileName;
end;

procedure TRMDFormIBXPropEdit.rdbLocalClick(Sender: TObject);
begin
  edtServer.Enabled := rdbRemote.Checked;
  cmbProtocol.Enabled := rdbRemote.Checked;
  lblServer.Enabled := rdbRemote.Checked;
  lblProtocol.Enabled := rdbRemote.Checked;
  btnBrowse.Enabled := rdbLocal.Checked;
end;

procedure TRMDFormIBXPropEdit.edtUserExit(Sender: TObject);
begin
  memParam.Lines.Values['user_name'] := edtUser.Text;
end;

procedure TRMDFormIBXPropEdit.edtPasswordExit(Sender: TObject);
begin
  memParam.Lines.Values['password'] := edtPassword.Text;
end;

procedure TRMDFormIBXPropEdit.edtSQLRoleExit(Sender: TObject);
begin
  memParam.Lines.Values['sql_role'] := edtSQLRole.Text;
end;

procedure TRMDFormIBXPropEdit.FormShow(Sender: TObject);
var
  aPos: integer;
  str: string;
begin
  memParam.Lines.Assign(FDatabase.Params);
  edtUser.Text := memParam.Lines.Values['user_name'];
  edtPassword.Text := memParam.Lines.Values['password'];
  edtSQLRole.Text := memParam.Lines.Values['sql_role'];

  if (Pos(':', FDatabase.DatabaseName) > 0) and (Pos(':\', FDatabase.DatabaseName) = 0) then // TCP
  begin
    rdbRemote.Checked := TRUE;
    cmbProtocol.ItemIndex := 0;
    aPos := Pos(':', FDatabase.DatabaseName);
    edtServer.Text := Copy(FDatabase.DatabaseName, 1, aPos - 1);
    edtDatabase.Text := Copy(FDatabase.DatabaseName, aPos + 1, 99999);
  end
  else if Pos('\\', FDatabase.DatabaseName) > 0 then // NetBEUI
  begin
    rdbRemote.Checked := TRUE;
    cmbProtocol.ItemIndex := 1;
    str := FDatabase.DatabaseName;
    Delete(str, 1, 2);
    aPos := Pos('\', str);
    edtServer.Text := Copy(str, 1, aPos - 1);
    edtDatabase.Text := Copy(str, aPos + 1, 99999);
  end
  else if Pos('@', FDatabase.DatabaseName) > 0 then // SPX
  begin
    rdbRemote.Checked := TRUE;
    cmbProtocol.ItemIndex := 2;
    aPos := Pos('@', FDatabase.DatabaseName);
    edtServer.Text := Copy(FDatabase.DatabaseName, 1, aPos - 1);
    edtDatabase.Text := Copy(FDatabase.DatabaseName, aPos + 1, 99999);
  end
  else
  begin
    rdbLocal.Checked := TRUE;
    cmbProtocol.ItemIndex := 0;
    edtDatabase.Text := FDatabase.DatabaseName;
  end;

  rdbLocalClick(nil);
end;

procedure TRMDFormIBXPropEdit.FormCloseQuery(Sender: TObject;
  var CanClose: Boolean);
begin
  if ModalResult = mrOK then
  begin
    FDatabase.Params.Assign(memParam.Lines);

    if rdbLocal.Checked then
      FDatabase.DatabaseName := edtDatabase.Text
    else
    begin
      case cmbProtocol.ItemIndex of
        0: // TCP
          FDatabase.DatabaseName := Format('%s:%s', [edtServer.Text, edtDatabase.Text]);
        1: // NetBEUI
          FDatabase.DatabaseName := Format('\\%s\%s', [edtServer.Text, edtDatabase.Text]);
        2: // SPX
          FDatabase.DatabaseName := Format('%s@%s', [edtServer.Text, edtDatabase.Text]);
      end;
    end;
  end;
end;

procedure TRMDFormIBXPropEdit.FormCreate(Sender: TObject);
begin
  Localize;
end;

{------------------------------------------------------------------------------}
{------------------------------------------------------------------------------}
type
  TDatabaseNameEditor = class(TELStringPropEditor)
  protected
    function GetAttrs: TELPropAttrs; override;
    procedure Edit; override;
  end;

  TDatabaseEditor = class(TELStringPropEditor)
  protected
    function GetAttrs: TELPropAttrs; override;
    procedure GetValues(AValues: TStrings); override;
  end;

  TIndexNameEditor = class(TELStringPropEditor)
  protected
    function GetAttrs: TELPropAttrs; override;
    procedure GetValues(AValues: TStrings); override;
  end;

  TTableNameEditor = class(TELStringPropEditor)
  protected
    function GetAttrs: TELPropAttrs; override;
    procedure GetValues(AValues: TStrings); override;
  end;

{------------------------------------------------------------------------------}
{------------------------------------------------------------------------------}
{ TDatabaseNameEditor }

function TDatabaseNameEditor.GetAttrs: TELPropAttrs;
begin
  Result := [praDialog];
end;

procedure TDatabaseNameEditor.Edit;
begin
  TRMDIBDatabase(GetInstance(0)).ShowEditor;
end;

{------------------------------------------------------------------------------}
{------------------------------------------------------------------------------}
{ TDatabaseEditor }

function TDatabaseEditor.GetAttrs: TELPropAttrs;
begin
  Result := [praValueList, praSortList];
end;

procedure TDatabaseEditor.GetValues(AValues: TStrings);
begin
  try
    RMGetComponents(RMDialogForm, TIBDatabase, AValues, nil);
  finally
  end;
end;

{------------------------------------------------------------------------------}
{------------------------------------------------------------------------------}
{ TIndexNameEditor }

function TIndexNameEditor.GetAttrs: TELPropAttrs;
begin
  Result := [praValueList, praSortList];
end;

procedure TIndexNameEditor.GetValues(AValues: TStrings);
var
  liTable: TRMDIBTable;
begin
  liTable := TRMDIBTable(GetInstance(0));
  liTable.GetIndexNames(aValues);
end;

{------------------------------------------------------------------------------}
{------------------------------------------------------------------------------}
{ TTableNameEditor }

function TTableNameEditor.GetAttrs: TELPropAttrs;
begin
  Result := [praValueList, praSortList];
end;

procedure TTableNameEditor.GetValues(AValues: TStrings);
var
  liTable: TIBTable;
begin
  liTable := TRMDIBTable(GetInstance(0)).FTable;
  if liTable.Database <> nil then
  begin
    liTable.DataBase.GetTableNames(AValues, False);
  end;
end;

{------------------------------------------------------------------------------}
{------------------------------------------------------------------------------}

procedure TRMDIBXQuery_ExecSql(var Value: Variant; Args: TJvInterpreterArgs);
begin
  TRMDIBQuery(Args.Obj).OnBeforeOpenQueryEvent(TRMDIBQuery(Args.Obj).FQuery);
  TRMDIBQuery(Args.Obj).FQuery.ExecSQL;
end;

const
	cReportMachine = 'RMD_IBX';

procedure RM_RegisterRAI2Adapter(RAI2Adapter: TJvInterpreterAdapter);
begin
  with RAI2Adapter do
  begin
    AddClass(cReportMachine, TRMDIBDatabase, 'TRMDIBDataset');
    AddClass(cReportMachine, TRMDIBTable, 'TRMDIBTable');
    AddClass(cReportMachine, TRMDIBQuery, 'TRMDIBQuery');

    AddGet(TRMDDataset, 'ExecSql', TRMDIBXQuery_ExecSql, 0, [0], varEmpty);
  end;
end;

initialization
//  RMRegisterControl(TRMDIBDatabase, 'RMD_IBXDB', RMLoadStr(SInsertDB) + '(IBX)');
//  RMRegisterControl(TRMDIBTable, 'RMD_IBXTABLE', RMLoadStr(SInsertTable) + '(IBX)');
//  RMRegisterControl(TRMDIBQuery, 'RMD_IBXQUERY', RMLoadStr(SInsertQuery) + '(IBX)');
  RMRegisterControls('IBX', 'RMD_IBXPATH', True,
    [TRMDIBDatabase, TRMDIBTable, TRMDIBQuery],
    ['RMD_IBXDB', 'RMD_IBXTABLE', 'RMD_IBXQUERY'],
    [RMLoadStr(SInsertDB), RMLoadStr(SInsertTable), RMLoadStr(SInsertQuery)]);

  RMRegisterPropEditor(TypeInfo(string), TRMDIBDatabase, 'DatabaseName', TDatabaseNameEditor);
  RMRegisterPropEditor(TypeInfo(string), TRMDIBDatabase, 'Params', TDatabaseNameEditor);

  RMRegisterPropEditor(TypeInfo(string), TRMDIBTable, 'DatabaseName', TDatabaseEditor);
  RMRegisterPropEditor(TypeInfo(string), TRMDIBTable, 'IndexName', TIndexNameEditor);
  RMRegisterPropEditor(TypeInfo(string), TRMDIBTable, 'TableName', TTableNameEditor);

  RMRegisterPropEditor(TypeInfo(string), TRMDIBQuery, 'DatabaseName', TDatabaseEditor);

  RM_RegisterRAI2Adapter(GlobalJvInterpreterAdapter);

finalization
{$ENDIF}

end.

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -