Exemplarische Vorgehensweise: Ändern von Datenbankobjekten
Aktualisiert: November 2007
In dieser exemplarischen Vorgehensweise ändern Sie mithilfe des Transact-SQL (T-SQL)-Editors die Definitionen von unterschiedlichen Datenbankobjekten im Datenbankprojekt. Dieser Vorgang umfasst die folgenden Schritte:
Öffnen Sie eine Projektmappe, die ein Datenbankprojekt enthält.
Fügen Sie eine Spalte in einer Tabelle hinzu. Der Kunde möchte verfolgen, in welchem Jahr bestimmte Produkte eingeführt wurden. Sie fügen daher der Tabelle Products die Spalte DateAdded hinzu.
Fügen Sie die Tabelle ShipperRating hinzu, um zu verfolgen, wie die Kunden die Leistungen der Lieferanten beurteilen, die ihre Bestellungen abwickeln. Außerdem fügen Sie Fremdschlüsselbeziehungen und einen Index hinzu.
Vorbereitungsmaßnahmen
In dieser exemplarischen Vorgehensweise wird davon ausgegangen, dass Sie Exemplarische Vorgehensweise: Stellen eines vorhandenen Datenbankschemas unter Versionskontrolle ausgeführt haben. Nach dem Durcharbeiten dieser exemplarischen Vorgehensweise verfügen Sie über die Projektmappe MyNorthwind.
So öffnen Sie die Projektmappe MyNorthwind
Zeigen Sie im Menü Datei auf Öffnen, und klicken Sie dann auf Projekt/Projektmappe.
Das Dialogfeld Projekt öffnen wird angezeigt.
Öffnen Sie den Ordner MyNorthwind, und doppelklicken Sie auf MyNorthwind.sln.
Die Projektmappe MyNorthwind wird geöffnet und im Projektmappen-Explorer angezeigt.
Klicken Sie im Menü Ansicht auf Schemaansicht.
Falls die Schemaansicht noch nicht geöffnet war, wird diese angezeigt. Sie enthält alle Objekte, die in dem Datenbankprojekt definiert sind.
Erweitern Sie den Datenbankprojektknoten in der Schemaansicht, wenn er nicht bereits erweitert ist.
Ändern Sie dann eine Tabellendefinition, um einer Tabelle eine Spalte hinzuzufügen.
So fügen Sie der Tabelle Products die Spalte DateAdded hinzu
Klicken Sie in der Schemaansicht mit der rechten Maustaste auf die Tabelle Products, und klicken Sie auf Öffnen. Sie können auch auf die Tabelle Products doppelklicken.
Der T-SQL-Editor wird geöffnet, und die Definition für die Tabelle Products wird angezeigt.
Ändern Sie im T-SQL-Editor die Definition, um die Spalte DateAdded wie im folgenden Beispiel dargestellt hinzuzufügen:
CREATE TABLE [dbo].[Products] ( [ProductID] [int] NOT NULL IDENTITY(1, 1), [ProductName] [nvarchar] (40) COLLATE SQL_Latin1_General_CP1_CS_AS NOT NULL, [SupplierID] [int] NULL, [CategoryID] [int] NULL, [QuantityPerUnit] [nvarchar] (20) COLLATE SQL_Latin1_General_CP1_CS_AS NULL, [UnitPrice] [money] NULL CONSTRAINT [DF_Products_UnitPrice] DEFAULT (0), [UnitsInStock] [smallint] NULL CONSTRAINT [DF_Products_UnitsInStock] DEFAULT (0), [UnitsOnOrder] [smallint] NULL CONSTRAINT [DF_Products_UnitsOnOrder] DEFAULT (0), [ReorderLevel] [smallint] NULL CONSTRAINT [DF_Products_ReorderLevel] DEFAULT (0), [Discontinued] [bit] NOT NULL CONSTRAINT [DF_Products_Discontinued] DEFAULT (0), [DateAdded] [datetime] NULL ) ON [PRIMARY]
Klicken Sie im Menü Datei auf dbo.Products speichern, um die Änderungen zu speichern.
Standardmäßig wird die Datei automatisch aus der Quellcodeverwaltung ausgecheckt. Wenn Sie die Einstellungen für die Quellcodeverwaltung geändert haben, werden Sie zum Auschecken der Datei aufgefordert.
Danach fügen Sie dem Datenbankprojekt eine Tabelle mit dem Namen ShipperRating hinzu.
So fügen Sie die Tabelle ShipperRating hinzu
Klicken Sie in der Schemaansicht auf den Ordner Tabellen.
Klicken Sie im Menü Projekt auf Neues Element hinzufügen. Sie können auch mit der rechten Maustaste auf den Ordner Tabellen klicken, auf Hinzufügen zeigen und dann auf Tabelle klicken.
Das Dialogfeld Neues Element hinzufügen wird angezeigt.
Klicken Sie in der Vorlagenliste auf Tabelle.
Geben Sie im Feld Name den Namen ShipperRating ein, und klicken Sie dann auf Hinzufügen.
Dem Datenbankprojekt und der Quellcodeverwaltung wird die Tabelle ShipperRating hinzugefügt. Der T-SQL-Editor wird angezeigt, damit Sie die Definition für diese Tabelle bearbeiten können.
Ändern Sie im T-SQL-Editor die Tabellendefinition entsprechend dem folgenden Beispiel:
-- ============================================= -- Create table definition for ShipperRating --Contains a rating of a shipper by --a customer, on a particular date. --Ratings are from 1-100. -- ============================================= CREATE TABLE [dbo].[ShipperRating] ( [ShipperID] [int] NOT NULL, [CustomerID] [nchar] (5) COLLATE SQL_Latin1_General_CP1_CS_AS NOT NULL, [RatingDate] [datetime] NULL, [Rating] [int] NOT NULL ) ON [PRIMARY]
Klicken Sie im Menü Datei auf ShipperRating speichern, um die Änderungen zu speichern.
Danach fügen Sie der Tabelle ShipperRating einen Fremdschlüssel hinzu.
So fügen Sie der Tabelle ShipperRating einen Fremdschlüssel hinzu
Klicken Sie in der Schemaansicht mit der rechten Maustaste auf die Tabelle ShipperRating, zeigen Sie auf Hinzufügen, und klicken Sie dann auf Fremdschlüssel.
Das Dialogfeld Neues Element hinzufügen wird angezeigt, und die Vorlage Fremdschlüssel ist bereits hervorgehoben.
Geben Sie unter Name die Zeichenfolge FK_ShipperRating_Shippers ein, und klicken Sie dann auf Hinzufügen.
Der Fremdschlüssel FK_ShipperRating_Shippers wird der Tabelle ShipperRating im Projekt hinzugefügt. Der T-SQL-Editor wird angezeigt, damit Sie die Definition für die Fremdschlüssel bearbeiten können.
Hinweis: Die Standarddefinition für den Fremdschlüssel verweist auf Spalte_1 in Tabellenname und nicht auf eine tatsächliche Tabelle und Spalte. Das Symbol für FK_ShipperRating_Shippers in der Schemaansicht zeigt daher einen Fehler an (ein roter Kreis mit einem weißen "x"). Außerdem wird ein Fehler im Fehlerlistenfenster angezeigt, um anzugeben, dass eine ungültige Datenbankobjektdefinition vorliegt. Dabei handelt es sich um ein erwartetes Verhalten. Für die Datei im Projektmappen-Explorer, die die Objektdefinition enthält, wird kein Fehlersymbol angezeigt.
Ändern Sie im T-SQL-Editor die Definition des Fremdschlüssels entsprechend dem folgenden Beispiel:
ALTER TABLE [dbo].[ShipperRating] ADD CONSTRAINT [FK_ShipperRating_Shippers] FOREIGN KEY ([ShipperID]) REFERENCES [dbo].[Shippers] ([ShipperID])
Klicken Sie im Menü Datei auf dbo.FK_ShipperRating_Shippers speichern, um die Änderungen zu speichern. Das Fehlersymbol wird durch das normale Symbol für eine Fremdschlüsseleinschränkung ersetzt, da die Definition nun gültig ist.
Im letzten Schritt fügen Sie der Tabelle ShipperRating einen Index hinzu.
So fügen Sie der Tabelle ShipperRating einen Index hinzu
Klicken Sie in der Schemaansicht auf den Ordner Indizes.
Klicken Sie im Menü Projekt auf Neues Element hinzufügen. Sie können auch mit der rechten Maustaste auf den Ordner Indizes klicken, auf Hinzufügen zeigen und dann auf Index klicken.
Klicken Sie in der Liste Vorlagen auf Index, wenn dieser Eintrag nicht bereits hervorgehoben ist.
Geben Sie im Feld Name den Namen ShipperRatingDate ein, und klicken Sie dann auf Hinzufügen.
Der Tabelle ShipperRating im Projekt wird der Index ShipperRatingDate hinzugefügt. Der T-SQL-Editor wird angezeigt, damit Sie die Definition für diesen Index bearbeiten können.
Hinweis: Die Standarddefinition für den Index verweist auf Spalte_1 und nicht auf einen tatsächlichen Spaltennamen. Das Symbol für ShipperRatingDate im Projektmappen-Explorer zeigt daher einen Fehler an (weißes "X" in rotem Kreis). Außerdem wird ein Fehler im Fenster Fehlerliste angezeigt, um anzugeben, dass eine ungültige Datenbankobjektdefinition vorliegt. Dabei handelt es sich um ein erwartetes Verhalten.
Ändern Sie im T-SQL-Editor die Indexdefinition entsprechend dem folgenden Beispiel:
-- ============================================= -- Create index on RatingDate column in --the ShipperRating table. -- ============================================= CREATE INDEX [ShipperRatingDate] ON [dbo].[ShipperRating] (RatingDate)
Klicken Sie im Menü Datei auf ShipperRatingDate speichern, um die Änderungen zu speichern. Das Fehlersymbol wird durch das normale Symbol für einen Index ersetzt, da die Definition nun gültig ist.
So checken Sie die Änderungen in der Versionskontrolle ein
Klicken Sie im Projektmappen-Explorer auf die Datenbank MyNorthwind.
Zeigen Sie im Menü Datei auf Quellcodeverwaltung, und klicken Sie dann auf Einchecken.
Checken Sie die Dateien ein, indem Sie den Schritten für das Quellcodeverwaltungs-Plug-In folgen. Weitere Informationen finden Sie unter Arbeiten mit der Team Foundation-Versionskontrolle.
Die Änderungen am Datenbankprojekt wurden nun eingecheckt sind für andere Teammitglieder verfügbar.
Nächste Schritte
Wenn Sie die Offlinedarstellung dieser Datenbank geändert haben, müssen Sie die Änderungen auf dem Datenbankserver erstellen und bereitstellen. Informationen über das Erstellen und Bereitstellen von Änderungen finden Sie unter Exemplarische Vorgehensweise: Bereitstellen von Änderungen an einer vorhandenen der Versionskontrolle unterliegenden Datenbank.
Siehe auch
Aufgaben
Exemplarische Vorgehensweise: Stellen eines vorhandenen Datenbankschemas unter Versionskontrolle
Konzepte
Übersicht über das Arbeiten mit Datenbankobjekten
Übersicht über die Terminologie der Database Edition