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、在其中的“查询”按钮下代码为:
 1 private   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,如需转载请自行联系原作者

相关文章
|
25天前
|
缓存 NoSQL 关系型数据库
在Python Web开发过程中:数据库与缓存,MySQL和NoSQL数据库的主要差异是什么?
MySQL是关系型DB,依赖预定义的表格结构,适合结构化数据和复杂查询,但扩展性有限。NoSQL提供灵活的非结构化数据存储(如JSON),无统一查询语言,但能横向扩展,适用于大规模、高并发场景。选择取决于应用需求和扩展策略。
114 1
|
30天前
|
网络协议 Java Nacos
nacos常见问题之在web界面 上下线服务时报错 400如何解决
Nacos是阿里云开源的服务发现和配置管理平台,用于构建动态微服务应用架构;本汇总针对Nacos在实际应用中用户常遇到的问题进行了归纳和解答,旨在帮助开发者和运维人员高效解决使用Nacos时的各类疑难杂症。
29 0
|
30天前
|
监控 Serverless 测试技术
Serverless 应用引擎常见问题之做的web服务计费如何解决
Serverless 应用引擎(Serverless Application Engine, SAE)是一种完全托管的应用平台,它允许开发者无需管理服务器即可构建和部署应用。以下是Serverless 应用引擎使用过程中的一些常见问题及其答案的汇总:
402 3
|
1月前
|
JSON API 数据库
解释如何在 Python 中实现 Web 服务(RESTful API)。
解释如何在 Python 中实现 Web 服务(RESTful API)。
25 0
|
1月前
|
负载均衡 Java 中间件
使用Go语言构建高性能Web服务
Go语言作为一种快速、高效的编程语言,其在构建高性能Web服务方面具有独特优势。本文将探讨如何利用Go语言开发和优化Web服务,以实现更高的性能和可伸缩性。
|
2月前
|
Arthas 监控 NoSQL
web服务性能监控方案
web服务性能监控方案
|
21天前
|
数据采集 Java API
python并发编程: Python使用线程池在Web服务中实现加速
python并发编程: Python使用线程池在Web服务中实现加速
18 3
python并发编程: Python使用线程池在Web服务中实现加速
|
29天前
|
关系型数据库 MySQL 数据库
使用Docker搭建MySQL数据库服务
本文介绍了如何使用Docker搭建MySQL数据库服务。首先,通过`docker pull mysql:5.7`命令拉取MySQL 5.7镜像,然后运行`docker run`命令创建并启动容器。接着,使用`docker exec`进入容器并创建MySQL用户及授权。最后,通过MySQL客户端如Navicat测试连接,验证安装成功。Docker简化了MySQL的部署和管理,确保环境一致性。
37 0
|
1月前
|
存储 关系型数据库 分布式数据库
PolarDB常见问题之PolarDB突然有大量服务连不上数据库如何解决
PolarDB是阿里云推出的下一代关系型数据库,具有高性能、高可用性和弹性伸缩能力,适用于大规模数据处理场景。本汇总囊括了PolarDB使用中用户可能遭遇的一系列常见问题及解答,旨在为数据库管理员和开发者提供全面的问题指导,确保数据库平稳运行和优化使用体验。
|
1月前
javaWeb服务详解(含源代码,测试通过,注释) ——web.xml
javaWeb服务详解(含源代码,测试通过,注释) ——web.xml
7 0

热门文章

最新文章