有没有比较完整的silverlight数据库连接方案,着急啊!
这个问题真是把我给难住了,三个星期了,一直解决不了,下边的工作没法开展,以前有一种程序,数据库连接都正常,但是我找不到他究竞哪个是数据库连接的程序,是不是在vs2008发布以后看不到源代码了,比如在.svc文件里看到的是
<%@ ServiceHost Language="VB" Debug="true" Service="ESA_MER_DB" CodeBehind="~/App_Code/ESA_MER_DB.vb" %>
到ESA_MER_DB.vb中也找不数据库连接的内容,真是急死了?请大侠们给一个完整的数据库连接程序,谢谢了!!!!!
下边是我在网上搜到的,用起来还是有问题,完整贴出来,大家给看一下:
1 创建项目
点击菜单File->New->Project...,打开New Project对话框。在Project types中选择Web,在右侧的Templates中选择ASP.NET Web Application,输入项目名为testDataGrid,点击OK按钮,完成创建。(见图1)
接着,右击Solution Explorer中Solution 'testDataGrid'根文件夹,依次点击菜单选项Add->New Project...。在Project types中选择Silverlight,在右侧的Templates中选择Silverlight Application,输入项目名为SilverlightClient,点击OK按钮,完成创建。
在弹出的对话框中,按下图进行设置,然后点击OK按钮。
2 创建数据库
为了加快实验速度,我们使用SQL Server Express 2008作为后台数据库。
按如下步骤建立数据库及数据表:
1)右击testDataGrid文件夹下的App_Data文件夹,依次点击菜单选项Add->New Item...。在弹出的对话框中,输入数据库名为Employees.mdf,点击Add按钮
双击Employees.mdf,打开Server Explorer窗口。按下两图所示添加新数据表,将该表命名为Employee。
3 创建ADO.NET Entity数据库实体模型
右击testDataGrid文件夹,点击菜单选项Add->New Item...。按下图进行操作,将数据库实体命名为EmployeeModel.edmx,点击Add按钮
在弹出对话框中选Generate from database,点击Next按钮。按下图进行操作,直到Finish为止。
这样数据模型就建立完毕。
4 建立ADO.NET Data Service数据通讯服务
右击testDataGrid文件夹,依次点击Add->New Item...。然后按下图操作,将ADO.NET Data Service服务命名为EmployeeInfoService.svc。
修改EmployeeInfoService.svc.cs代码如下:
using System;
using System.Collections.Generic;
using System.Data.Services;
using System.Linq;
using System.ServiceModel.Web;
using System.Web;
namespace testDataGrid
{
public class EmployeeInfoService : DataService<EmployeesEntities>
{
public static void InitializeService(IDataServiceConfiguration config)
{
config.SetEntitySetAccessRule("*", EntitySetRights.All);
config.SetServiceOperationAccessRule("*", ServiceOperationRights.All);
}
}
}按Ctrl+Shift+B进行整个项目的编译(非常重要,不然数据服务引用会出错!)
右击刚才创建的EmployeeInfoService.svc,选择菜单选项View in Browser(如下图),配置成功的话会出现下图所示的页面。
右击SilverlightClient项目文件夹下的References,选择Add Service References...。接着,在弹出的对话框中点击Discover按钮,Services中出现刚才我们创建的EmployeeInfoService.svc,点击其左边的“+”展开符号,之后出现服务搜寻,结束后将Namespace改为EmployeeServiceReference。
这样,建立ADO.NET Data Service数据通讯服务的过程就此结束。
创建SilverlightClient界面及组件代码
MainPage.xaml代码:
<UserControl
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d" xmlns:data="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Data" x:Class="SilverlightClient.MainPage"
d:DesignWidth="640" d:DesignHeight="480">
<Grid x:Name="LayoutRoot" Background="White" Width="320" Height="220">
<data:DataGrid x:Name="dgEmployee" Height="150" Margin="8,8,0,0" VerticalAlignment="Top" HorizontalAlignment="Left" Width="304"/>
<Button x:Name="btnGetData" Height="28" HorizontalAlignment="Left" Margin="8,171,0,0" VerticalAlignment="Top" Width="98" Content="Get Data"/>
</Grid>
</UserControl>MainPage.xaml.cs代码:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Shapes;
using System.Data.Services.Client;//引入System.Data.Services.Client命名空间
using SilverlightClient.EmployeeServiceReference;//引入数据服务所在命名空间
namespace SilverlightClient
{
public partial class MainPage : UserControl
{
public MainPage()
{
InitializeComponent();
//注册事件触发处理
this.btnGetData.Click += new RoutedEventHandler(btnGetData_Click);
}
void btnGetData_Click(object sender, RoutedEventArgs e)
{
EmployeesEntities proxy = new EmployeesEntities(new Uri("EmployeeInfoService.svc", UriKind.Relative));
var query = from c in proxy.Employee select c;
DataServiceQuery<Employee> userQuery = (DataServiceQuery<Employee>)query;
userQuery.BeginExecute(new AsyncCallback(OnLoadComplete), query);//异步调用
}
void OnLoadComplete(IAsyncResult result)
{
DataServiceQuery<Employee> query = (DataServiceQuery<Employee>)result.AsyncState;
dgEmployee.ItemsSource = query.EndExecute(result).ToList();//将最终结果传给DataGrid
}
}
}
[解决办法]
看过这个专题么?
Silverlight与常用数据库互操作系列
http://silverlightchina.net/html/zhuantixilie/2009/1210/387.html
你的问题在这个系列中都有解释。
[解决办法]
如果你想通过webservice连接数据库的话,可以参考此文,被用于具体项目中。
http://blog.csdn.net/luminji/archive/2009/11/25/4871559.aspx