Silverlight实用窍门系列:30.Silverlight中创建一个最简单的WCF RIA Services访问数据库实例【实例源码+数据库下载】

简介:

本文将建立一个最简单的WCF RIA Services访问数据库的实例,附带有数据库文件,可以在Sql Server中附加数据库,在本文中并没有采用ADO.NET实体数据模型绑定数据库,而是单独写一个类来连接数据库查询数据表并返回值,下面我们看详细步骤。

        第一步:首先我们打开VS2010,新建一个Silverlight应用程序项目SLGetDataFromWCFRIA。2011032617094444.jpg

        第二步:点击确定之后,在弹出的“新建Silverlight应用程序”窗口中,选中“启用 WCF RIA 服务”复选框然后确定。2011032617125449.jpg

        第三步:在创建好的项目中,鼠标右键点击“SLGetDataFromWCFRIA.Web”项目,然后“添加”-->“新建项”-->“WCF服务”,命名为SLWCFRIA.svc。2011032617152044.jpg

        第四步:在上一步生成的ISLWCFRIA.cs文件中,我们可以定义相关的通信的契约,在本实例中我们定义一个string GetData()契约。2011032617212086.jpg

        第五步:在SLWCFRIA.svc.cs文件中我们实现这个契约函数,代码如下:

复制代码
 
 
using System;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.Serialization;
using System.ServiceModel;
using System.Text;
using System.Data;
using System.Data.SqlClient;

namespace SLGetDataFromWCFRIA.Web
{
// 注意: 使用“重构”菜单上的“重命名”命令,可以同时更改代码、svc 和配置文件中的类名“SLWCFRIA”。
public class SLWCFRIA : ISLWCFRIA
{
public void DoWork()
{
}
public string GetData()
{
DataSet ds
= DB.Getdata( " select * from userinfo " );
return ds.GetXml();
}
}
}
复制代码

        第七步:我们在SQL SERVER2008中创建一个示例数据库名为SLRiaTest。在这个数据库里面新增一个UserInfo表,在里面添加字段如下:2011032617310182.jpg

        第八步:编写一个类,来连接SLRiaTest数据库,获取DataSet数据集。

ContractedBlock.gif DB.cs数据库访问类

        第九步:鼠标右键点击SLGetDataFromWCFRIA项目“添加服务引用”即引用刚才我们编写的WCF服务。2011032617410945.jpg

        第十步:添加一个UserInfo的实体类集合。代码如下:

复制代码
 
 
/// <summary>
/// 用户实体类
/// </summary>
public class UserInfo
{
private string _ID;
private string _UserName;
private string _UserAddr;
private string _UserTel;

public string ID
{
get { return _ID; }
set { _ID = value; }
}

public string UserName
{
get { return _UserName; }
set { _UserName = value; }
}

public string UserAddr
{
get { return _UserAddr; }
set { _UserAddr = value; }
}

public string UserTel
{
get { return _UserTel; }
set { _UserTel = value; }
}
}
复制代码

        第十一步:点击MainPage.xaml文件,添加一个DataGird控件命名为grShow,在MainPage.xaml.cs文件中编写以下代码获取WCF RIA services读取到的数据库数据:

复制代码
 
 
public partial class MainPage : UserControl
{
public MainPage()
{
InitializeComponent();
// 创建一个代理类的实例
SLWCFRIAClient client = new SLWCFRIAClient();
// 调用GetData方法并加载事件
client.GetDataAsync();
client.GetDataCompleted
+= new EventHandler < GetDataCompletedEventArgs > (client_GetDataCompleted);
}
public List < UserInfo > userList = new List < UserInfo > ();
void client_GetDataCompleted( object sender, GetDataCompletedEventArgs e)
{
using (XmlReader xReader = XmlReader.Create( new StringReader(e.Result)))
{
// XmlReader读取XML数据
while (xReader.ReadToFollowing( " Table " ))
{
xReader.ReadToDescendant(
" ID " );
string id = xReader.ReadElementContentAsString();
xReader.ReadToNextSibling(
" UserName " );
string username = xReader.ReadElementContentAsString();

xReader.ReadToNextSibling(
" UserAddr " );
string useraddr = xReader.ReadElementContentAsString();

xReader.ReadToNextSibling(
" UserTel " );
string usertel = xReader.ReadElementContentAsString();
// 实例化类并添加进实体类List<>
UserInfo uinfo = new UserInfo(){ID = id, UserName = username,UserAddr = useraddr,UserTel = usertel};
userList.Add(uinfo);
}
this .grShow.ItemsSource = userList;
}

}
}
复制代码

        最后我们看最后的效果图,本实例采用VS2010+Silverlight 4.0+MS SQL SERVER 2008,点击 SLGetDataFromWCFRIA.rar 下载本实例源码和示例数据库。

2011032617450024.jpg

本文转自程兴亮博客园博客,原文链接:http://www.cnblogs.com/chengxingliang/archive/2011/03/28/1996434.html,如需转载请自行联系原作者


相关文章
|
6月前
|
Oracle 关系型数据库 API
C# LIS检验系统源码,接口技术:RESTful API + Http+WCF
LIS检验系统一种专门用于医院化验室的计算机系统,它致力于提高医院化验室的工作效率和检测准确率。LIS系统由多个子系统组成,包括样本管理系统、质控系统、检验结果管理系统、报告管理系统等。体系结构:Client/Server架构 SaaS模式 客户端:WPF+Windows Forms 服务端:C# +.Net 数据库:Oracle 接口技术:RESTful API + Http+WCF
|
9月前
|
API 数据库
如何使用WCF框架和EF框架实现对数据库的操作
如何使用WCF框架和EF框架实现对数据库的操作
|
.NET 开发框架 数据安全/隐私保护
|
数据库 存储
使用Entity Framework和WCF Ria Services开发SilverLight之7:多个Domain Service间共享Poco实体
在前两篇中,我们讲了在SL端通过Entity Framework和WCF Ria Services实现联表查询,其中最关键的是为实体类中的相关属性设定为Include特性,如下: 遗憾的是,这样的实体Include只能在单个域服务间共享实体。
758 0