Web服务初探:用Demo学Web服务系列(6)——断开模式访问数据库的Web服务-阿里云开发者社区

开发者社区> 文艺小青年> 正文

Web服务初探:用Demo学Web服务系列(6)——断开模式访问数据库的Web服务

简介:
+关注继续查看
  通过上次的《Web服务初探:用Demo学Web服务系列(5)——连接模式访问数据库的Web服务》学习,我们已经知道了,Web Services是如何从数据库中来使用连接模式访问数据库来进行操作。下面我们来看看在上次的讨论中所讲述WebService再次改变,让这个WebService能变成断开模式访问数据库的Web Services。
    这次我们要改变上次的WebService时并不是在原来的方法上做改变,而是在WebService中添加了一个新方法,并且在我们建立的C/S程序工程中也加入了一个新的Windows Form来调用这个新加的方法。
    一、在前面的WebService中加入下面的方法,代码如下:
 1    [WebMethod]
 2    public DataSet SelectUser(string UserName)
 3    {
 4        Configuration WebConfig = WebConfigurationManager.OpenWebConfiguration("~/Web.Config");
 5        DataSet DS = new DataSet("WSDemoDB");
 6        DataTable DT = new DataTable("UserTable");
 7        DS.Namespace = "http://tempuri.org/DataSet";
 8        DS.Tables.Add(DT);
 9        if (WebConfig.ConnectionStrings.ConnectionStrings.Count > 0)
10        {
11            ConnectionStringSettings ConStr = WebConfig.ConnectionStrings.ConnectionStrings["WSConStringSQL"];
12            if (ConStr != null)
13            {
14                SqlConnection SqlCon = new SqlConnection(ConStr.ConnectionString);
15                SqlCommand SqlCom = new SqlCommand("SELECT 用户ID, 用户名称, 用户密码, 用户姓名, 用户性别, 密码提示问题, 问题答案 FROM 用户表 WHERE (用户名称 LIKE '%' + @用户名称 + '%')", SqlCon);
16                SqlCom.Parameters.Add("@用户名称", SqlDbType.NVarChar);
17                SqlCom.Parameters["@用户名称"].Value = UserName;
18                SqlDataAdapter SqlDA = new SqlDataAdapter(SqlCom);
19                try
20                {
21                    SqlCon.Open();
22                    SqlDA.Fill(DT);
23                }

24                finally
25                {
26                    SqlDA.Dispose();
27                    SqlCom.Dispose();
28                    SqlCon.Close();
29                    SqlCon.Dispose();
30                }

31            }

32        }

33        return DS;
34    }
WebService方法说明:添加的方法名为SelecUser,其中需要获得一个参数UserName。此方法返回一个根据传入的UserName查询到的相关用户信息的DataSet。
    二、C/S工程中添加窗体并在“查询”按钮中加入相关代码,窗体和代码如下:
1、窗体中加入一个TextBox、一个Button和一个DataGridView,如下图:

2、在其中的“查询”按钮下代码为:
 1private void Btn_SelectUser_Click(object sender, EventArgs e)
 2        {
 3            MyServ.MyServiceClass MyWebServ = new MyServ.MyServiceClass();
 4            DataSet DS = new DataSet();
 5            DS = MyWebServ.SelectUser(TB_User.Text);
 6            if (DS.Tables.Count > 0)
 7            {
 8                DGV_UserView.DataSource = DS.Tables["UserTable"];//此处也可写成:DGV_UserView.DataSource = DS.Tables[0];
 9            }

10            else
11            {
12                MessageBox.Show("没有查询到所需要的数据!");
13            }

14        }
这样我们完成了此次WebService的调用。

代码说明:跟其他的调用一样我们需要实例化WebService的代理类,然后定义一个DataSet用来接收WebService中SelectUser的返回值,最后将返回的DataSet绑定到DGV_UserView上。




本文转自刚刚博客园博客,原文链接:http://www.cnblogs.com/lijigang/archive/2006/11/18/564853.html,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
微服务消息队列(MQTT For IoT)Android Demo使用介绍
目前阿里云官方对于微消息队列 MQTT提供了很多语言的参考示例,但是在实际的使用中发现很多用户在使用Android Sample的时候总是会遇到问题,无法正常调试使用。本文主要介绍Android Sample的使用。
2484 0
Android手机访问web服务器(post请求)
一:客户端—服务器连接操作类(HttpUtil) package com.example.userdatatoweb; import java.util.ArrayList; import java.util.List; import java.util.Map; import java.util.Map.Entry; import java.util.Set; import
1377 0
使用Nginx反向代理和proxy_cache缓存搭建CDN服务器加快Web访问速度
碰到问题:移动用户访问web服务器www.osyunwei.com很慢解决办法:1、在移动机房放置一台nginx反向代理服务器2、通过域名DNS智能解析,所有移动用户访问www.osyunwei.com时解析到nginx反向代理服务器3、nginx反向代理服务器与web服务器之间采用专线连接系统运维  www.
1580 0
E-MapReduce的Presto组件默认支持访问oss数据
阿里云E-MapReduce从EMR-2.1.0版本镜像开始,Presto组件默认就支持访问oss数据了,不再需要引导操作额外支持。
2280 0
curl向web服务器发送json数据
c++使用libcurl: 1 /* 2 *g++ demo.cpp -g -Wall -lcurl 3 */ 4 5 #include 6 #include 7 #include 8 #include 9 #include ...
1004 0
weblogic连接RAC数据库
对于负载均衡的机器,要连接多个实例的数据库的时候,使用这种策略目前是比较好的一种方案,当然也可以使用weblogic自带的解决方案。 直接使用了RAC的负载均衡策略。   在Oracle中找到tnsnames.ora这个文件。
642 0
[WS]Web服务系列(二) Web服务的结构
我发现写日志可以帮助自己整理思路,有些技术在一段时间不用后,如果以日志的形式写出来,对于巩固记忆是十分有效的。比如这个Web服务系列,为了尽量避免错误,我会重新查阅资料,在这个过程中又能学到新的知识。
971 0
3576
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载