Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   ADO und MSSQL - Standardschema beeinflussen (https://www.delphipraxis.net/213505-ado-und-mssql-standardschema-beeinflussen.html)

hotrs02 8. Aug 2023 15:32

Datenbank: MSSQL • Version: % • Zugriff über: ADO

ADO und MSSQL - Standardschema beeinflussen
 
Hi *.*,

gegeben ist ein Zugriff auf eine MS SQL Server Datenbank mit verschiedenen Tabellen mittels TADOConnection, TADODataSet und SQL-Befehlen. Es zeigt sich, dass das für den Anwender konfigurierte Standardschema (dbo) nicht mit dem Schema übereinstimmt, zu dem die Tabelle gehört (dba). Damit scheidet eine direkte Verwendung der Tabellennamen ohne weiteren Zusatz in den SQL-Befehlen aus. Stattdessen müssten diese überall um den Prefix "dba." ergänzt werden.

Gibt es eine einfache Möglichkeit, dies direkt über die verwendeten ADO-Komponenten zu erreichen? Eine Durchsicht der Eigenschaften half leider nicht weiter. Und eine Beeinflussung des Standardschemas über den ConnectionString scheint nicht vorgesehen.

Grüße

TigerLilly 8. Aug 2023 18:01

AW: ADO und MSSQL - Standardschema beeinflussen
 
Welches Schema benutzt wird, wird über das dem User zugeordnete Schema festgelegt.
https://learn.microsoft.com/en-us/sq...l-server-ver16

Das Defaultschema ist das erste, das einem USer zugeordnet ist:
https://www.mssqltips.com/sqlservert...in-sql-server/

Es kann aber geändert werden:
https://learn.microsoft.com/en-us/sq...l-server-ver16

Antwort auf deine Frage: Das hängt davon ab, ob dein User ALTER USER Rechte hat. Wenn ja, dann kannst du einfach das ALTER USER Statement absetzen. Wenn nein, dann musst du (einmalig) einen User dafür benutzen, der die Rechte hat.

himitsu 8. Aug 2023 20:24

AW: ADO und MSSQL - Standardschema beeinflussen
 
Bei anderen DBMS lässt sich das Default-Schema auch in der Connection festlegen, bzw. in der Session ändern.

https://stackoverflow.com/questions/...or-a-sql-query
uvm.

Aber im MSSQL scheint das anscheinend nicht zu gehen, so dass du es wohl oder übel in der Datenbank, bzw. beim Nutzer ändern mußt.

hotrs02 9. Aug 2023 10:47

AW: ADO und MSSQL - Standardschema beeinflussen
 
Erstmal danke für eure Antworten.

Es wird jetzt erstmal versucht, das Standardschema des verwendeten Anwenders ändern zu lassen. Das Absetzen eines "ALTER" Befehls dürfte an den notwendigen Berechtigungen scheitern.


Alle Zeitangaben in WEZ +1. Es ist jetzt 07:56 Uhr.

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz