最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

[原创]Silverlight与Access数据库的互操作(CURD完全解析)

来源:懂视网 责编:小采 时间:2020-11-09 07:43:50
文档

[原创]Silverlight与Access数据库的互操作(CURD完全解析)

[原创]Silverlight与Access数据库的互操作(CURD完全解析):Silverlight 与 SQL Server 或 SQL Server Express 的互操作,已成为我们常见的开发 Siverlight 应用程序的一种模式。可是在开发一些小型应用程序时,我们就需要使用一些小巧的轻量级的数据库,比如 Access 数据库。由于 Visual Studio
推荐度:
导读[原创]Silverlight与Access数据库的互操作(CURD完全解析):Silverlight 与 SQL Server 或 SQL Server Express 的互操作,已成为我们常见的开发 Siverlight 应用程序的一种模式。可是在开发一些小型应用程序时,我们就需要使用一些小巧的轻量级的数据库,比如 Access 数据库。由于 Visual Studio

Silverlight 与 SQL Server 或 SQL Server Express 的互操作,已成为我们常见的开发 Siverlight 应用程序的一种模式。可是在开发一些小型应用程序时,我们就需要使用一些小巧的轻量级的数据库,比如 Access 数据库。由于 Visual Studio 中并没有直接提供 Sil

SilverlightSQL ServerSQL Server Express的互操作,已成为我们常见的开发Siverlight应用程序的一种模式。可是在开发一些小型应用程序时,我们就需要使用一些小巧的轻量级的数据库,比如Access数据库。由于Visual Studio中并没有直接提供SilverlightAccess互操作的系列方法。于是本文就将为大家介绍如何让Silverlight使用Access作为后台数据库。

准备工作

1)建立起测试项目

细节详情请见强大的DataGrid组件[2]_数据交互之ADO.NET Entity Framework——Silverlight学习笔记[10]。

2)创建测试用数据库

如下图所示,创建一个名为Employees.mdbAccess数据库,建立数据表名称为Employee。将该数据库置于作为服务端的项目文件夹下的App_Data文件夹中,便于操作管理。

建立数据模型

EmployeeModel.cs文件(放置在服务端项目文件夹下)

using System;

using System.Collections.Generic;

using System.Linq;

namespace datagridnaccessdb

{

public class EmployeeModel

{

public int EmployeeID { get; set; }

public string EmployeeName { get; set; }

public int EmployeeAge { get; set; }

}

}

建立服务端Web Service★

右击服务端项目文件夹,选择Add->New Item....,按下图所示建立一个名为EmployeesInfoWebService.asmxWeb Service,作为SilverlightAccess数据库互操作的桥梁。

创建完毕后,双击EmployeesInfoWebService.asmx打开该文件。将里面的内容修改如下:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

using System.Web.Services;

using System.Data.OleDb;//引入该命名空间为了操作Access数据库

using System.Data;

namespace datagridnaccessdb

{

///

/// Summary description for EmployeesInfoWebService

///

[WebService(Namespace = "http://tempuri.org/")]

[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]

[System.ComponentModel.ToolboxItem(false)]

// To allow this Web Service to be called from script, using ASP.NET AJAX, uncomment the following line.

// [System.Web.Script.Services.ScriptService]

public class EmployeesInfoWebService : System.Web.Services.WebService

{

[WebMethod]//获取雇员信息

public List GetEmployeesInfo()

{

List returnedValue = new List();

OleDbCommand Cmd = new OleDbCommand();

SQLExcute("SELECT * FROM Employee", Cmd);

OleDbDataAdapter EmployeeAdapter = new OleDbDataAdapter();

EmployeeAdapter.SelectCommand = Cmd;

DataSet EmployeeDataSet = new DataSet();

EmployeeAdapter.Fill(EmployeeDataSet);

foreach (DataRow dr in EmployeeDataSet.Tables[0].Rows)

{

EmployeeModel tmp = new EmployeeModel();

tmp.EmployeeID = Convert.ToInt32(dr[0]);

tmp.EmployeeName = Convert.ToString(dr[1]);

tmp.EmployeeAge = Convert.ToInt32(dr[2]);

returnedValue.Add(tmp);

}

return returnedValue;

}

[WebMethod] //添加雇员信息

public void Insert(List employee)

{

employee.ForEach( x =>

{

string CmdText = "INSERT INTO Employee(EmployeeName,EmployeeAge) VALUES('"+x.EmployeeName+"',"+x.EmployeeAge.ToString()+")";

SQLExcute(CmdText);

});

}

[WebMethod] //更新雇员信息

public void Update(List employee)

{

employee.ForEach(x =>

{

string CmdText = "UPDATE Employee SET EmployeeName='"+x.EmployeeName+"',EmployeeAge="+x.EmployeeAge.ToString();

CmdText += " WHERE EmployeeID="+x.EmployeeID.ToString();

SQLExcute(CmdText);

});

}

[WebMethod] //删除雇员信息

public void Delete(List employee)

{

employee.ForEach(x =>

{

string CmdText = "DELETE FROM Employee WHERE EmployeeID="+x.EmployeeID.ToString();

SQLExcute(CmdText);

});

}

//执行SQL命令文本,重载1

private void SQLExcute(string SQLCmd)

{

string ConnectionString = "PROVIDER=Microsoft.Jet.OLEDB.4.0;DATA SOURCE=" + Server.MapPath(@"App_Data\Employees.mdb;");

OleDbConnection Conn = new OleDbConnection(ConnectionString);

Conn.Open();

OleDbCommand Cmd = new OleDbCommand();

Cmd.Connection = Conn;

Cmd.CommandTimeout = 15;

Cmd.CommandType = CommandType.Text;

Cmd.CommandText = SQLCmd;

Cmd.ExecuteNonQuery();

Conn.Close();

}

//执行SQL命令文本,重载2

private void SQLExcute(string SQLCmd,OleDbCommand Cmd)

{

string ConnectionString = "PROVIDER=Microsoft.Jet.OLEDB.4.0;DATA SOURCE=" + Server.MapPath(@"App_Data\Employees.mdb;");

OleDbConnection Conn = new OleDbConnection(ConnectionString);

Conn.Open();

Cmd.Connection = Conn;

Cmd.CommandTimeout = 15;

Cmd.CommandType = CommandType.Text;

Cmd.CommandText = SQLCmd;

Cmd.ExecuteNonQuery();

}

}

}

之后,在Silverlight客户端应用程序文件夹下,右击References文件夹,选择菜单选项Add Service Reference...。如下图所示,引入刚才我们创建的Web Service(别忘了按Discover按钮进行查找)。

创建Silverlight客户端应用程序

MainPage.xaml文件

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" xmlns:dataFormToolkit="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Data.DataForm.Toolkit" x:Class="SilverlightClient.MainPage"

d:DesignWidth="320" d:DesignHeight="240">

文档

[原创]Silverlight与Access数据库的互操作(CURD完全解析)

[原创]Silverlight与Access数据库的互操作(CURD完全解析):Silverlight 与 SQL Server 或 SQL Server Express 的互操作,已成为我们常见的开发 Siverlight 应用程序的一种模式。可是在开发一些小型应用程序时,我们就需要使用一些小巧的轻量级的数据库,比如 Access 数据库。由于 Visual Studio
推荐度:
标签: 操作 数据库 原创
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top