AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi SQL-DMO / SMO Alternativen in D6
Thema durchsuchen
Ansicht
Themen-Optionen

SQL-DMO / SMO Alternativen in D6

Ein Thema von süden · begonnen am 3. Okt 2012 · letzter Beitrag vom 3. Okt 2012
Antwort Antwort
süden

Registriert seit: 20. Feb 2009
Ort: Lindau (Bodensee)
75 Beiträge
 
Delphi 2007 Professional
 
#1

SQL-DMO / SMO Alternativen in D6

  Alt 3. Okt 2012, 09:13
Datenbank: SQL Server • Version: 2008 • Zugriff über: ADO
Hallo, ich habe mich an den SQL-Server herangewagt und bin dabei, ein Programm von Access zu SQL-Server umzustellen.
Entwicklungsumgebung XP, SQL 2005, Inno-Setup.
> Läuft.
Auf W7, SQL 2008 gibt es Fehlermeldungen.

Nun habe ich gelesen, dass SQL-DMO durch SMO ersetzt wurde,
und Delphi 6 das nicht unterstützt.

Wie gesagt ich bin noch Anfänger was den Server betrifft und habe mich an die tausende Skripte gehalten, die im Netz und in den Büchern zu finden sind - alle SQL-DMO.
Kann ich alle Kicken!?

In einem der wenigen Beiträge zu diesem Thema (was Delphi betrifft) habe ich gelesen, dass man alles mit SQL-Anweisungen erledigen kann.
Da bin ich jetzt überfordert.

ZB.: Server im Netzwerk? Läuft der Server? Einbinden einer DB? Backup? Properties? usw.

Wie mache ich das?
Habt Ihr darüber einen Link für mich? Oder eine Buchempfehlung?

Gruß imsueden
  Mit Zitat antworten Zitat
Benutzerbild von Bummi
Bummi

Registriert seit: 15. Jun 2010
Ort: Augsburg Bayern Süddeutschland
3.470 Beiträge
 
Delphi XE3 Enterprise
 
#2

AW: SQL-DMO / SMO Alternativen in D6

  Alt 3. Okt 2012, 10:42
Für einen Teil der Fragen hätte ich zumindest Teillösungen
Delphi-Quellcode:

var
  i:Integer;

begin
ListAvailableSQLServers(Memo1.lines);
  for I := 0 to Memo1.lines.Count - 1 do
    begin
        TcpClient1.Close;
        TcpClient1.RemoteHost := Memo1.lines[i];
        try
          TcpClient1.Open;
          if TcpClient1.Connected then Memo1.lines[i] := Memo1.lines[i] + ' Active'
          else Memo1.lines[i] := Memo1.lines[i] + ' Not Active';
        except
          Memo1.lines[i] := Memo1.lines[i] + ' ERROR';
        end;
    end;
   TcpClient1.Close;
end;



procedure ListAvailableSQLServers(Names : TStrings);
var
  RSCon: ADORecordsetConstruction;
  Rowset: IRowset;
  SourcesRowset: ISourcesRowset;
  SourcesRecordset: _Recordset;
  SourcesName, SourcesType: TField;

    function PtCreateADOObject
             (const ClassID: TGUID): IUnknown;
    var
      Status: HResult;
      FPUControlWord: Word;
    begin
      asm
       FNSTCW FPUControlWord
      end;
      Status := CoCreateInstance(
                  CLASS_Recordset,
                  nil,
                  CLSCTX_INPROC_SERVER or
                  CLSCTX_LOCAL_SERVER,
                  IUnknown,
                  Result);
      asm
        FNCLEX
        FLDCW FPUControlWord
      end;
      OleCheck(Status);
    end;
begin
  SourcesRecordset :=
      PtCreateADOObject(CLASS_Recordset)
      as _Recordset;
  RSCon :=
      SourcesRecordset
      as ADORecordsetConstruction;
  SourcesRowset :=
      CreateComObject(ProgIDToClassID('SQLOLEDB Enumerator'))
      as ISourcesRowset;
  OleCheck(SourcesRowset.GetSourcesRowset(
       nil,
       IRowset, 0,
       nil,
       IUnknown(Rowset)));
  RSCon.Rowset := RowSet;
  with TADODataSet.Create(nil) do
  try
    Recordset := SourcesRecordset;
    SourcesName := FieldByName('SOURCES_NAME');
    SourcesType := FieldByName('SOURCES_TYPE');
    Names.BeginUpdate;
    try
      while not EOF do
      begin
        if
           (SourcesType.AsInteger = DBSOURCETYPE_DATASOURCE)
           and (SourcesName.AsString <> '') then
          Names.Add(SourcesName.AsString);
        Next;
      end;
    finally
      Names.EndUpdate;
    end;
  finally
    Free;
  end;
end;
Datenbanken erstellen/ändern ... sollte IMHO eh klar sein ??
Datenbankstrukturen/Fremdschlüssel/ (Sichten - Prozeduren - Funktionen) als Scripte(Struktur), Rechte etc. bekommt man auch alles über SQL.

Wenn Du da was brauchst, sag Bescheid dann hänge ich meine Rechteverwaltung und meinen DB-Dokumenter (ist schon etwas älter und Du müsstest um das HTML Geraffel herumlesen) an.
Miniaturansicht angehängter Grafiken
bild-5.jpg   bild-6.jpg   bild-7.jpg   bild-8.jpg  
Angehängte Dateien
Dateityp: zip MSSQL_DOKU_EXE.zip (630,2 KB, 8x aufgerufen)
Thomas Wassermann H₂♂
Das Problem steckt meistens zwischen den Ohren
DRY DRY KISS
H₂ (wenn bei meinen Snipplets nichts anderes angegeben ist Lizenz: WTFPL)

Geändert von Bummi ( 3. Okt 2012 um 11:27 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort

 

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:15 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz