--- title: "Creating, Altering, and Removing Schemas" ms.date: "08/06/2017" ms.prod: sql ms.prod_service: "database-engine" ms.reviewer: "" ms.technology: ms.topic: "reference" helpviewer_keywords: - "schemas [SMO]" ms.assetid: 3e3619de-c6a2-4280-b2be-4ec9924608fb author: "markingmyname" ms.author: "maghan" monikerRange: "=azuresqldb-current||=azure-sqldw-latest||>=sql-server-2016||=sqlallproducts-allversions||>=sql-server-linux-2017||=azuresqldb-mi-current" --- # Creating, Altering, and Removing Schemas [!INCLUDE[appliesto-ss-asdb-asdw-xxx-md](../../../includes/appliesto-ss-asdb-asdw-xxx-md.md)] The object represents an ownership context for database object. The property of the object represents a collection of objects. ## Example To use any code example that is provided, you will have to choose the programming environment, the programming template, and the programming language in which to create your application. For more information, see [Create a Visual C# SMO Project in Visual Studio .NET](../../../relational-databases/server-management-objects-smo/how-to-create-a-visual-csharp-smo-project-in-visual-studio-net.md). ## Creating, Altering, and Removing a Schema in Visual Basic This code example demonstrates how to create a schema and assign it to a database object. The program then grants permission to a user, and then creates a new table in the schema. ```VBNET 'Connect to the local, default instance of SQL Server. Dim srv As Server srv = New Server 'Reference the AdventureWorks2012database. Dim db As Database db = srv.Databases("AdventureWorks2012") 'Define a Schema object variable by supplying the parent database and name arguments in the constructor. Dim sch As Schema sch = New Schema(db, "MySchema1") sch.Owner = "dbo" 'Create the schema on the instance of SQL Server. sch.Create() 'Define an ObjectPermissionSet that contains the Update and Select object permissions. Dim obperset As ObjectPermissionSet obperset = New ObjectPermissionSet() obperset.Add(ObjectPermission.Select) obperset.Add(ObjectPermission.Update) 'Grant the set of permissions on the schema to the guest account. sch.Grant(obperset, "guest") 'Define a Table object variable by supplying the parent database, name and schema arguments in the constructor. Dim tb As Table tb = New Table(db, "MyTable", "MySchema1") Dim mycol As Column mycol = New Column(tb, "Date", DataType.DateTime) tb.Columns.Add(mycol) tb.Create() 'Modify the owner of the schema and run the Alter method to make the change on the instance of SQL Server. sch.Owner = "guest" sch.Alter() 'Run the Drop method for the table and the schema to remove them. tb.Drop() sch.Drop() ``` ## Creating, Altering, and Removing a Schema in Visual C# This code example demonstrates how to create a schema and assign it to a database object. The program then grants permission to a user, and then creates a new table in the schema. ```csharp { //Connect to the local, default instance of SQL Server. Server srv = new Server(); //Reference the AdventureWorks2012 database. Database db = srv.Databases["AdventureWorks2012"]; //Define a Schema object variable by supplying the parent database and name arguments in the constructor. Schema sch = new Schema(db, "MySchema1"); sch.Owner = "dbo"; //Create the schema on the instance of SQL Server. sch.Create(); //Define an ObjectPermissionSet that contains the Update and Select object permissions. ObjectPermissionSet obperset = new ObjectPermissionSet(); obperset.Add(ObjectPermission.Select); obperset.Add(ObjectPermission.Update); //Grant the set of permissions on the schema to the guest account. sch.Grant(obperset, "guest"); //Define a Table object variable by supplying the parent database, name and schema arguments in the constructor. Table tb = new Table(db, "MyTable", "MySchema1"); Column mycol = new Column(tb, "Date", DataType.DateTime); tb.Columns.Add(mycol); tb.Create(); //Modify the owner of the schema and run the Alter method to make the change on the instance of SQL Server. sch.Owner = "guest"; sch.Alter(); //Run the Drop method for the table and the schema to remove them. tb.Drop(); sch.Drop(); } ``` ## Creating, Altering, and Removing a Schema in PowerShell This code example demonstrates how to create a schema and assign it to a database object. The program then grants permission to a user, and then creates a new table in the schema. ```powershell # Set the path context to the local, default instance of SQL Server and get a reference to AdventureWorks2012 CD \sql\localhost\default\databases $db = get-item Adventureworks2012 # Define a schema object variable by supplying the parent database and name arguments in the constructor. $sch = New-Object -TypeName Microsoft.SqlServer.Management.SMO.Schema ` -argumentlist $db, "MySchema1" # Set schema owner $sch.Owner = "dbo" # Create the schema on the instance of SQL Server. $sch.Create() # Define an ObjectPermissionSet that contains the Update and Select object permissions. $obperset = New-Object -TypeName Microsoft.SqlServer.Management.SMO.ObjectPermissionSet $obperset.Add([Microsoft.SqlServer.Management.SMO.ObjectPermission]::Select) $obperset.Add([Microsoft.SqlServer.Management.SMO.ObjectPermission]::Update) # Grant the set of permissions on the schema to the guest account. $sch.Grant($obperset, "guest") #Create a SMO Table with one column and add it to the database $tb = New-Object -TypeName Microsoft.SqlServer.Management.SMO.Table -argumentlist $db, "MyTable", "MySchema1" $Type = [Microsoft.SqlServer.Management.SMO.DataType]::DateTime $mycol = New-Object -TypeName Microsoft.SqlServer.Management.SMO.Column -argumentlist $tb,"Date", $Type $tb.Columns.Add($mycol) $tb.Create() # Modify the owner of the schema and run the Alter method to make the change on the instance of SQL Server. $sch.Owner = "guest" $sch.Alter() # Run the Drop method for the table and the schema to remove them. $tb.Drop() $sch.Drop() ```