SQL Server2005中的SMO编程

SMO是SQL Mangagement Objects的简称.与之相对应的是ADO.Net,不过不同的地方是ADO.Net是用于数据访问的,而SMO是用于设计的,虽然SMO能够再服务器上执行任意的SQL语句.另外一个不同的地方是ADO.Net可以访问计算机中任意数据源,而SMO对象是专门针对SQL Server而设计的.
在SMO中最重要的一个类就是Server.其他大多数对象都是Server对象的后代.比如Database,Table,View等等对象都是通过Server属性不断向下检索到的.
要在VS2005中使用必须引用SMO的程序集.我们建立好一个控制台应用程序,添加引用:Microsoft.SqlServer.ConnectionInfo和Microsoft.SqlServer.Smo.我们可以输入如下代码使用Server对象给出某服务器中的数据库数目:
using System;
using Microsoft.SqlServer.Management.Smo;
namespace SMOTest
{
class Class1
{
public static void Main()
{
Microsoft.SqlServer.Management.Common.ServerConnection conn = new Microsoft.SqlServer.Management.Common.ServerConnection("tcp:157.60.15.215,12345", "sa", "123456");
Server s = new Server(conn);
Console.WriteLine("DatabaseCount:" + s.Databases.Count);
}
}
}

运行以上代码就可以得到服务器上数据库的数目.下面我们再来看看在SMO中对数据库常见的操作:
1,创建删除数据库.
Database db2 = new Database(s, "NewDatabaseName");
db2.Create();
以上是创建数据库的代码,那么删除数据库的代码就是:
Database db2 = s.Databases["NewDatabaseName"];
db2.Drop();
2,创建表.
Database db = s.Databases["AdventureWorks"];
Table tb = new Table(db, "NewTableName");
Column c = new Column(tb, "CustomerID");
c.Identity = true;
c.IdentitySeed = 1;
c.DataType = DataType.Int;
c.Nullable = false;
tb.Columns.Add(c);
c = new Column(tb, "CustomerName");
c.DataType = DataType.VarChar(20);
c.Nullable = true;
tb.Columns.Add(c);
tb.Create();

以上语句是在数据库AdventureWorks中创建了一个表NewTableName,其中我们定义了两个字段,一个是CustomerID,一个是CustomerName.需要注意的是在创建表的时候必须要指定其中的列,如果没有指定列,那么创建表就会失败.
3,创建存储过程.
StoredProcedure sp = new StoredProcedure(db, "NewStoredProcedure");
StoredProcedureParameter spp1 = new StoredProcedureParameter(sp, "@addrID", DataType.Int);
sp.TextMode = false;
sp.Parameters.Add(spp1);
sp.TextBody = "select * from Person.Address where AddressID=@addrID";
sp.Create();

这儿需要说明的是如果不写sp.TextMode = false;那么可能创建存储过程要失败,所以最好把这句加上.
整个语句比较简单,而且也比较好理解,就不用多作解释了.
4,删除对象.
删除对象比较简单,只要将需要删除的对象引用过来,然后执行Drop操作就可以了.比如:
删除表:

Table tb=db.Tables["TableName"]; tb.Drop();

删除存储过程:

StoredProcedure sp = db.StoredProcedures["NewStoredProcedure123"]; sp.Drop();

5,执行存储过程.
执行存储过程不需要在StoredProcedure对象下寻找方法,要SMO直接执行存储过程可以使用Database对象下的ExecuteNonQuery方法.
6,更新对象属性.
若想要修改数据库的属性,修改存储过程内容等,在进行修改后必须要执行Alter方法才能真正更新.
比如修改数据库属性可以使用修改db.DatabaseOptions下的属性,新属性修改好后执行一句db.Alter();便可.
若要修改存储过程,代码如下:
StoredProcedure sp = db.StoredProcedures["NewStoredProcedure123"];
StoredProcedureParameter spp1 = new StoredProcedureParameter(sp, "@spID", DataType.Int);
sp.TextMode = false;
sp.Parameters.Add(spp1);
sp.TextBody = "select * from Person.Address where StateProvinceID=@spID";
sp.Alter();

其他的一下对象如表,视图等等原理相同.

时间: 2024-09-26 15:53:28

SQL Server2005中的SMO编程的相关文章

体验SQL Server2005中T-SQL特性

错误处理一直是T-SQL开发的一个棘手部分.你曾经需要在基于逐个场景的基础上运行每一个语句和处理他们之后手动检查错误.事务管理也很烦琐,因为你得指出你的事务的状态,并恰当的回滚或提交.在SQL Server2005中,微软通过增加Try...Catch块到T-SQL中,提供了一个更新.更强大的错误处理能力. 异常处理很简单;在执行你的代码过程中有意外发生时,例如一个异常,你需要有一个例行方式去处理这个异常.要怎么处理这个异常是由作为开发者的你来决定的.为了增加一个异常处理到你的T-SQL代码中,

[转]在SQL Server2005中进行错误捕捉

原文:http://www.cnblogs.com/nokiaguy/archive/2008/05/09/1190551.html    任何程序都可能出现错误,在SQL Server中执行Transact-SQL也不例外.如果在Transact-SQL中发生了错误,一般有两种捕捉错误的方法,一种是在客户端代码(如 c#.delphi等)中使用类似try...catch的语句进行捕捉:另外一种就是在Transact-SQL中利用Transact-SQL本身提供的错误捕捉机制进行捕捉.如果是因为

完美解决SQL server2005中插入汉字变成问号的问题_MsSql

关于SQL server2005中插入汉字变成问号的解决办法 1.右击你所建的数据库,点击"属性",选择"选项"并点击.将其中的排序规则设置为:Chinese_PRC_CI_AS(选择下拉列表框即可设置),然后"确定". 2.在表中将你的汉字字段的数据类型设置为nvarchar型或ntext型,设置前最好先将表中的数据全部删除.(不要使用varchar或text型,因为它们只会继续使你的数据乱码). 3.设置好后,关闭服务器,再重新启动,就可生效

完美解决SQL server2005中插入汉字变成问号的问题

关于SQL server2005中插入汉字变成问号的解决办法 1.右击你所建的数据库,点击"属性",选择"选项"并点击.将其中的排序规则设置为:Chinese_PRC_CI_AS(选择下拉列表框即可设置),然后"确定". 2.在表中将你的汉字字段的数据类型设置为nvarchar型或ntext型,设置前最好先将表中的数据全部删除.(不要使用varchar或text型,因为它们只会继续使你的数据乱码). 3.设置好后,关闭服务器,再重新启动,就可生效

SQL Server2005杂谈(4):在SQL Server2005中按列连接字符串的三种方法

本文为原创,如需转载,请注明作者和出处,谢谢! 上一篇:SQL Server2005杂谈(3):四个排名函数(row_number.rank.dense_rank和ntile)的比较 最近做一个项目,遇到一个在分组的情况下,将某一列的字段值(varchar类型)连接起来的问题,类似于sum函数对int型字段值求和. 如有一个表t_table,结构和数据如图1                                           图1     其中要按着xh字段分组,并且将每一组na

在SQL Server2005中进行错误捕捉

任何程序都可能出现错误,在SQL Server中执行Transact-SQL也不例外.如果在Transact-SQL中发生了错误,一般有两种捕捉错误的方法,一种是在客户端代码(如C#.Delphi等)中使用类似try...catch的语句进行捕捉:另外一种就是在Transact-SQL中利用Transact-SQL本身提供的错误捕捉机制进行捕捉.如果是因为Transact-SQL语句的执行而产生的错误,如键值冲突,使用第一种和第二种方法都可以捕捉,但是如果是逻辑错误,使用客户端代码进行捕捉就不太

SQL Server2005 中的数据类型总结

 SQL Server 2005 中的数据类型归纳为下列类别:精确数字 bigint decimal int numeric smallint money tinyint smallmoney bit   近似数字 float real 日期和时间 datetime smalldatetime 字符串 char text varchar   Unicode字符串 nchar ntext nvarchar   二进制字符串 binary image varbinary   其他数据类型 curso

SQL Server2005中触发器的运用

编写过存储过程的人,再编写触发器时会发现:他们的语法.格式是非常类似的.其实触发器就是一种特殊类型的存储过程.他们都是预编译的,在程序正式编译前就由编译器进行编译,存储在服务器端. 不过,触发器与一般的存储过程也有些区别.触发器主要是通过对数据库的增删改的操作,或者是一个触发动作的触发作用等事件触发而被执行:而存储过程则是通过像传递SQL语句一样,传递存储过程的名字来被程序调用,实现功能. 触发器一共分为五种类型:Update触发器,Insert触发器.Delete触发器.Instead of触

在SQL Server2005中使用 .NET程序集

昨天完成了一个最简单的在数据库中创建标量值函数,今天主要完成表值函数,存储过程和用户定义类型在和.NET结合下的使用方法. 1,表值函数 所谓表值函数就是说这个函数返回的结果是一个Table,而不是单个的值. 在.NET 中创建这样的函数,返回的结果是一个IEnumerable接口.这个接口非常灵活,所有.NET数组集合等都是实现了该接口的.下面我们举一个简单的例子来说明. 在VS2005中创建一个类Student,这个就是我们要返回的表的内容,类下面有属性int Age,string sNam