在Visual Studio 2005 中,新增了TableAdapter configuration wizard来很方便地创建数据访问层。首先,我们了解下什么是tableadapter。一个tableadapter连接到
数据库,执行
查询
语句或者
存储过程,并且将返回的结果集填充到datatable中去。Tableadapter configuration 向导允许你以类型化dataset方式创建编辑数据集合,十分方便。
首先用C#语言,创建一个名为NtierExample的WEB项目,如下图:
为了创建数据访问层,首先 鼠标 右键点选工程项目菜单,在弹出的菜单中选择"ADD New Item"。在弹出的"ADD NEW ITEM"对话框中,选择"dataset"类型。然后在文件名中,输入"Authors.xsd",并点击"Add",如下图所示:
当你点"ADD"的按钮时 ,系统会提示是否将该文件放到APP_CODE目录中去,因为VS.NET 2005中,一般会将数据访问层的文件放到该文件夹中去,以方便管理。我们继续选"ok",将xsd文件放到app_code文件夹中去。接下来,就出现"TableAdpater"设置向导的窗口了。首先,我们要指定连接的数据库字符串,并选择将连接字符串保存到web.config文件中去,并选"next"进入下一步。
在该步中,选择命令类型,由于我们刚才建立了存储过程,因此选择"Use existing store procedure",如下图:
再点选"NEXT",进入下一个窗口,会询问采用哪一个存储过程,如下图:
这里,我们选择使用"GetAuthors"这个存储过程,再选"next"进入下一步,如下图:
在这里,我们要指定使用GetAuthors存储过程的哪一个方法用来返回数据集,我们选择"return a datatable"的选现,并指定使用其中的GetAuthors方法,以datatable的形式返回。继续选"next",出现如下窗口,则系统自动会生成数据访问层了。
当你点击"Finish"按钮后,Visual Studio 会自动产生一些类,当这些类产生后,我们将类改名为Authors,这样,最后输出如下图所示:
接下来,我们按上面的步骤,类似地,使用"TableAdapter"向导,选择工具菜单栏的"Data-Add-TableAdapter",再次增加一个tableadapter,这次选择的是"GetTitlesByAuthor"存储过程,而选择返回的方法是"GetTitlesByAuthor",其他步骤和生成"GetAuthos"的一样,最后,将产生的类的名改为"AuthorTitles",如下图所示
从上面的代码中,可以看到,我们刚才通过向导创建的"Authors.xsd"类型化dataset类,现在在 代码 中,可以通过使用AuthorsTableAdapters类来调用,其中authorDB是AuthorsTableAdapters类的实例。
首先用C#语言,创建一个名为NtierExample的WEB项目,如下图:
为了创建数据访问层,首先 鼠标 右键点选工程项目菜单,在弹出的菜单中选择"ADD New Item"。在弹出的"ADD NEW ITEM"对话框中,选择"dataset"类型。然后在文件名中,输入"Authors.xsd",并点击"Add",如下图所示:
当你点"ADD"的按钮时 ,系统会提示是否将该文件放到APP_CODE目录中去,因为VS.NET 2005中,一般会将数据访问层的文件放到该文件夹中去,以方便管理。我们继续选"ok",将xsd文件放到app_code文件夹中去。接下来,就出现"TableAdpater"设置向导的窗口了。首先,我们要指定连接的数据库字符串,并选择将连接字符串保存到web.config文件中去,并选"next"进入下一步。
在该步中,选择命令类型,由于我们刚才建立了存储过程,因此选择"Use existing store procedure",如下图:
再点选"NEXT",进入下一个窗口,会询问采用哪一个存储过程,如下图:
这里,我们选择使用"GetAuthors"这个存储过程,再选"next"进入下一步,如下图:
在这里,我们要指定使用GetAuthors存储过程的哪一个方法用来返回数据集,我们选择"return a datatable"的选现,并指定使用其中的GetAuthors方法,以datatable的形式返回。继续选"next",出现如下窗口,则系统自动会生成数据访问层了。
当你点击"Finish"按钮后,Visual Studio 会自动产生一些类,当这些类产生后,我们将类改名为Authors,这样,最后输出如下图所示:
接下来,我们按上面的步骤,类似地,使用"TableAdapter"向导,选择工具菜单栏的"Data-Add-TableAdapter",再次增加一个tableadapter,这次选择的是"GetTitlesByAuthor"存储过程,而选择返回的方法是"GetTitlesByAuthor",其他步骤和生成"GetAuthos"的一样,最后,将产生的类的名改为"AuthorTitles",如下图所示
创建逻辑层
接下来,我们创建逻辑层,在这个例子中,逻辑层是十分
简单
的,只是起到说明作用。首先,我们新建一个类AuthroBiz类,并将其放在App_code文件夹中,并将类的代码修改如下:
public class AuthorsBiz
{
public AuthorsBiz()
{}
public DataTable GetAuthors()
{
AuthorsTableAdapters.AuthorsTableAdapter authorDB = new AuthorsTableAdapters.AuthorsTableAdapter();
return authorDB.GetAuthors();
}
public DataTable GetAuthorTitles(string authorID)
{
AuthorsTableAdapters.AuthorTitlesTableAdapter authorDB = new AuthorsTableAdapters.AuthorTitlesTableAdapter();
return authorDB.GetTitlesByAuthor(authorID);
}
}
从上面的代码中,可以看到,我们刚才通过向导创建的"Authors.xsd"类型化dataset类,现在在 代码 中,可以通过使用AuthorsTableAdapters类来调用,其中authorDB是AuthorsTableAdapters类的实例。