WCF技巧:教你如何轻松访问数据库 (wcf 如何访问数据库)

WCF(Windows Communication Foundation)是一种用于创建分布式应用程序的框架,它能够帮助开发人员在不同的平台上进行通信。在开发中,我们常常需要访问数据库来存储和读取数据,而WCF也提供了一系列的服务和类,支持对数据库进行数据访问。本篇文章将教你如何使用WCF轻松访问数据库,让你的开发更加高效。

一、设置数据库连接

在WCF中,我们需要先设置数据库连接,让应用程序知道访问哪个数据库,并通过哪个账户进行访问。在配置文件Web.config或App.config中添加以下代码:

“`xml

“`

在这段代码中,我们定义了数据库连接的名称myConnectionString,以及连接字符串和提供程序名称。需要注意的是,Data Source表示数据库服务器的地址,Initial Catalog表示要访问的数据库名称,User Id表示登录账户的用户名,Password表示登录账户的密码,providerName表示提供程序的名称。

二、创建数据访问类

在WCF中,我们可以通过数据访问类访问数据库,以读取或修改数据库中的数据。WCF中提供了许多数据访问类,比如ADO.NET、Entity Framework等,本篇文章以ADO.NET为例来演示如何如何使用数据访问类访问数据库。

我们需要创建一个数据访问类,该类可以实现接口IUserRepository,并实现以下方法:

“`csharp

public class UserRepository : IUserRepository

{

private string connectionString = ConfigurationManager.ConnectionStrings[“myConnectionString”].ConnectionString;

public IEnumerable GetAllUsers()

{

using (SqlConnection connection = new SqlConnection(connectionString))

{

connection.Open();

SqlCommand command = new SqlCommand(“SELECT * FROM Users”, connection);

SqlDataReader reader = command.ExecuteReader();

List users = new List();

while (reader.Read())

{

User user = new User();

user.UserId = Convert.ToInt32(reader[“UserId”]);

user.UserName = reader[“UserName”].ToString();

user.PhoneNumber = reader[“PhoneNumber”].ToString();

users.Add(user);

}

reader.Close();

return users;

}

}

public User GetUserById(int userId)

{

using (SqlConnection connection = new SqlConnection(connectionString))

{

connection.Open();

SqlCommand command = new SqlCommand(“SELECT * FROM Users WHERE UserId=@UserId”, connection);

command.Parameters.AddWithValue(“@UserId”, userId);

SqlDataReader reader = command.ExecuteReader();

if (reader.Read())

{

User user = new User();

user.UserId = Convert.ToInt32(reader[“UserId”]);

user.UserName = reader[“UserName”].ToString();

user.PhoneNumber = reader[“PhoneNumber”].ToString();

reader.Close();

return user;

}

else

{

reader.Close();

return null;

}

}

}

}

“`

在上面的代码中,我们创建了一个UserRepository类,实现了接口IUserRepository,同时定义了数据库连接字符串,和两个方法GetAllUsers和GetUserById。其中,GetAllUsers方法从数据库中获取所有用户信息,并返回一个列表;GetUserById方法从数据库获取指定用户的信息,并返回该用户的User对象。

三、创建服务契约

在WCF中,我们需要创建服务契约,该契约定义了服务提供的方法、数据类型和返回值。在本例中,我们需要创建一个服务契约,它可以提供读取用户信息的方法。代码如下:

“`csharp

[ServiceContract]

public interface IUserService

{

[OperationContract]

IEnumerable GetAllUsers();

[OperationContract]

User GetUserById(int userId);

}

“`

在上面的代码中,我们创建了一个IUserService服务契约,定义了两个服务方法GetAllUsers和GetUserById,分别对应上面的UserRepository类中的两个方法。

四、实现服务

创建完服务契约后,我们需要创建服务并实现服务契约中的方法。代码如下:

“`csharp

public class UserService : IUserService

{

private IUserRepository userRepository = new UserRepository();

public IEnumerable GetAllUsers()

{

return userRepository.GetAllUsers();

}

public User GetUserById(int userId)

{

return userRepository.GetUserById(userId);

}

}

“`

在上面的代码中,我们创建了UserService类,并实现了IUserService中的两个方法GetAllUsers和GetUserById,这两个方法调用了UserRepository类中的方法完成数据读取的操作。

五、配置服务

完成服务的实现后,我们需要进行配置,将服务发布到IIS中,以便其他应用程序可以调用。打开Web.config文件,添加以下配置项:

“`xml

“`

在上面的配置中,我们将服务名称设置为UserService,并且使用basicHttpBinding协议来与客户端进行通信。同时,设置了服务的行为,其中serviceMetadata httpGetEnabled=”true”表示服务可以通过http方式获取元数据信息,serviceDebug includeExceptionDetlInFaults=”false”表示出现异常时,不将详细信息返回给客户端。

我们需要将服务发布到IIS中,以便其他应用程序可以调用。在Visual Studio中选择Build> Publish,设置发布文件夹和发布方式,点击Publish按钮完成发布。

六、调用服务

运行服务后,在浏览器中输入服务地址,可以看到服务的元数据信息。接下来,我们可以使用客户端应用程序来调用服务。在客户端中,需要添加服务引用,并创建客户端代理对象来调用服务。

“`csharp

static void Mn(string[] args)

{

UserServiceClient userServiceClient = new UserServiceClient();

var userList = userServiceClient.GetAllUsers();

foreach (var user in userList)

{

Console.WriteLine(user.UserId + “,” + user.UserName + “,” + user.PhoneNumber);

}

Console.ReadLine();

}

“`

在上面的代码中,我们首先创建了一个UserServiceClient客户端代理对象,通过该对象来访问服务。然后,我们调用了服务中的GetAllUsers方法,获取所有用户信息,并遍历输出。调用Console.ReadLine方法来保持控制台窗口打开。

七、

相关问题拓展阅读:

如何直接访问网站的数据库

1、先创建程序所要访问的数据库,打开控制梁渣面板,建立ODBC数据源:开始→设置→控制面板→管理工具→ODBC数据源→系统DSN。

2、然后编写数据库访问程序:在程序中首先要加载驱动,其次要建立连接,再次创建嫌段用于访问数据库的芹渣誉Statement对象,然后利用Statement对象访问数据库

Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver”);

Stringurl=”jdbc:odbc:book”;

Stringquery=”SELECT*FROMbook1″;

Connectionc=DriverManager.getConnection(Url,user,password);

Connectioncon=DriverManager.getConnection(url);

Statementstmt=con.createStatement();

ResultSetrs=stmt1.executeQuery(query);

建立连接之后,可以访问数据库,对数据库进行操作,如:查询、修改、删除。

连接使用完毕,可以调用close()方法关闭连接.

importjava.sql.*;

classSimpleSelect{

publicstaticvoidmain(Stringargs){

Stringurl=”jdbc:odbc:book”;

Stringquery=”SELECT*FROMbook1″;

try{

Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver”);

}

catch(java.lang.ClassNotFoundExceptione){

System.err.print(“ERROR:”);

System.err.print(e.getMessage());

}

//输出数据库中信息

try{

Connectioncon=DriverManager.getConnection(url);

Statementstmt=con.createStatement();

ResultSetr=stmt.executeQuery(query);

System.out.println(“id:”+””+”name”+””+”price”+””+”author”+””+”publish_name”);

while(r.next()){

Longr1=r.getLong(“id”);

Stringr2=r.getString(“name”);

Doubler3=r.getDouble(“price”);

Stringr4=r.getString(“author”);

Stringr5=r.getString(“publish_name”);

System.out.println(r1+””+r2+””+r3+””+r4+””+r5);

}

r.close();

stmt.close();

con.close();

}catch(SQLExceptionex){

ex.printStackTrace();

}

}

silverlight调用WCF读取数据库,会写填充到datagrid,但是我想用linq查询某一条符合条件的数据到文本框中,

var query =

from order in MemoryData.dsCreditSports.Tables.AsEnumerable()

join gaminginfo in MemoryData.dsCreditSports.Tables.AsEnumerable()

on order.Field(“playid”) equals

gaminginfo.Field(“playid”) into temp1

from play in temp1.DefaultIfEmpty()

join tradingitem in MemoryData.dsCreditSports.Tables.AsEnumerable()

on order.Field(“tradingitemid”) equals

tradingitem.Field(“tradingitemid”) into temp2

from trade in temp2.DefaultIfEmpty()

//where order.Field(“OnlineOrderFlag”) == true

//&& order.Field(“OrderDate”).Month == 8

select new

{//intradingAmt▲totAmt▲processStatus▲playId▲tradingDirection▲processDesc▲matchId▲matchAmt▲tradingItemId▲loginName issuedate

intradingamt =

order.Field(“intradingamt”),

matchAmt =

order.Field(“matchAmt”),

//playid =

// order.Field游辩(“playid”),

tradingitemname =

trade == null ? “” : trade.Field(“tradingitemname”),

playname =

play == null ? “” : play.Field(“playname”),

tradingdirectionname =

order.Field(“tradingdirection”) == “” ? “” :

order.Field(“tradingdirection”) == CommonConst.TradingDirectionEnum.buy.ToString(“d”) ? “买神腔缺” : “卖”,

};

foreach (var item in query)

{

DataRow dRows = MemoryData.dsCreditSports.Tables.Rows;

dRows = string.IsNullOrEmpty(item.playname) ? “不限圆和” : item.playname;

dRows = string.IsNullOrEmpty(item.tradingitemname) ? “不限” : item.tradingitemname;

dRows = string.IsNullOrEmpty(item.tradingdirectionname) ? “不限” : item.tradingdirectionname;

dRows = string.IsNullOrEmpty(item.intradingamt) ? “0” : item.intradingamt;

dRows = string.IsNullOrEmpty(item.matchAmt) ? “0” : item.matchAmt;

}

这是我在项目中用到的,给你参考下吧

不是很清楚你遇到的问题是不知道怎么用wcf还是态明补助到怎么用Linq.

如果是不知道怎么用wcf,这个一时半会是说不清楚的,建议你看看教程;

如果是不清楚怎么用linq 这个就简单了:

你的接口写成:

//假设你的EntityFramework实例名为:

ExampleEntities edm = new ExampleEntities();

public UserInfo GetUserInfo(int id)

{

//可以用linq to sql,不过不清楚你的数据表结构,这里就不介绍了

//因为linq经常配合ORM共同使用,这里以其中一种EntityFramework为例:

var query = edm.UserInfo.FirstOrDefault(s => s.ID == id);

return (UserInfo)query;

}

wcf 如何访问数据库的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于wcf 如何访问数据库,WCF技巧:教你如何轻松访问数据库,如何直接访问网站的数据库,silverlight调用WCF读取数据库,会写填充到datagrid,但是我想用linq查询某一条符合条件的数据到文本框中,的信息别忘了在本站进行查找喔。


数据运维技术 » WCF技巧:教你如何轻松访问数据库 (wcf 如何访问数据库)