AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Prüfen ob Datenbank auf MSSQL Server vorhanden
Thema durchsuchen
Ansicht
Themen-Optionen

Prüfen ob Datenbank auf MSSQL Server vorhanden

Ein Thema von winnionkel · begonnen am 22. Nov 2006 · letzter Beitrag vom 22. Nov 2006
Antwort Antwort
winnionkel

Registriert seit: 9. Dez 2005
Ort: Roßlau
63 Beiträge
 
Delphi 7 Enterprise
 
#1

Prüfen ob Datenbank auf MSSQL Server vorhanden

  Alt 22. Nov 2006, 12:37
Datenbank: MSSQL Server • Version: 2005 • Zugriff über: ADO
Hallo,

vielleicht könnt ihr mir helfen.
Ich suche eine Möglichkeit, festzustellen, ob meine Datenbank schon am MSSQL Server angefügt ist.

Mit der ADOConnection muß ich ja schon bei Prog Start, im ConnectionString die Datenbank angeben.
Beim Öffnen der ADOConnection fange ich dann die Fehlercodes ab. Ist die DB nicht angefügt,
bekomme ich den Fehlercode 4060.
Aber irgendwie möchte ich mich nicht darauf verlassen, das dieser FehlerCode immer die gleiche Nr hat.

Ich bin bei ADO schon sehr oft reingefallen.

Gibt es vielleicht noch eine andere Möglichkeit, dies festzustellen.
Vielleicht über die Systemdatenbank ?

Gruß winni
Winfried
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#2

Re: Prüfen ob Datenbank auf MSSQL Server vorhanden

  Alt 22. Nov 2006, 12:46
Hallo Winni,

du kannst dich mit der Master-DB verbinden und dort die Prozedur sp_databases() ausführen.

Freundliche Grüße
  Mit Zitat antworten Zitat
NormanNG

Registriert seit: 1. Feb 2006
294 Beiträge
 
Delphi 2007 Professional
 
#3

Re: Prüfen ob Datenbank auf MSSQL Server vorhanden

  Alt 22. Nov 2006, 13:11
Hi Winni,


oder du holst dir die Datenbank-ID bei aktiver Verbindung zur Master-Datenbank:

select db_id('dbname') Das Select liefert eine zahl zurück, wenn die DB vorhanden ist...
Gruß
Norman
  Mit Zitat antworten Zitat
Heffalump

Registriert seit: 3. Aug 2005
278 Beiträge
 
RAD-Studio 2009 Ent
 
#4

Re: Prüfen ob Datenbank auf MSSQL Server vorhanden

  Alt 22. Nov 2006, 13:57
select * from dbo.sysdatabases (gegen die master.db)
  Mit Zitat antworten Zitat
NormanNG

Registriert seit: 1. Feb 2006
294 Beiträge
 
Delphi 2007 Professional
 
#5

Re: Prüfen ob Datenbank auf MSSQL Server vorhanden

  Alt 22. Nov 2006, 14:30
Hi,

Zitat von Heffalump:
select * from dbo.sysdatabases (gegen die master.db)
das ist aber ziemlich genau das, was sp_databases() macht, mit dem Nachteil, das der Zugriff auf die Systemtabellen erlaubt sein muss.
Gruß
Norman
  Mit Zitat antworten Zitat
winnionkel

Registriert seit: 9. Dez 2005
Ort: Roßlau
63 Beiträge
 
Delphi 7 Enterprise
 
#6

Re: Prüfen ob Datenbank auf MSSQL Server vorhanden

  Alt 22. Nov 2006, 17:25
Ich prüfe das ja beim Start meines Programms. Und mein Programm muß ja Zugriff auf die Systemtabellen haben, oder ?
Sonst könnte ich da doch auch keine neue DB anlegen.

Oder habe ich da jetzt einen Denkfehler.

Welche Datenbank muß ich denn im ConnectionString einstellen, damit ich überhaupt ein SELECT absetzten kann ?

Die MASTER ?

Gruß Winni
Winfried
  Mit Zitat antworten Zitat
winnionkel

Registriert seit: 9. Dez 2005
Ort: Roßlau
63 Beiträge
 
Delphi 7 Enterprise
 
#7

Re: Prüfen ob Datenbank auf MSSQL Server vorhanden

  Alt 22. Nov 2006, 17:39
Sorry, Ihr habt ja oben geschrieben, das es die Master ist.
Winfried
  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 01:10 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