网站导航免费论文 原创论文 论文搜索 原创论文 网学软件 学术大家 资料中心 会员中心 问题解答 原创论文 大学论文导航 设计下载 最新论文 下载排行 原创论文 论文源代码
返回网学首页
网学联系
最新论文 推荐专题 热门论文 素材专题
当前位置: 网学 > 编程文档 > ASP.net > 正文

在ASP.NET中使用SQL的IN操作

来源:http://myeducs.cn 联系QQ:点击这里给我发消息 作者: 用户投稿 来源: 网络 发布时间: 12/10/12

  这篇文章将建立一列包含CheckBox控件的DataGrid,这个控件允许用户对明细浏览进行多列选择。如果没有恢复对于动态SQL获得该功能的一种方法,那么必须使用IN操作。
  
  在文章的结尾,我们写了一个SQL Server用户自定义函数(UDF),为了将一个字符串分解成带分隔符的子字符串。在这篇文章中,我们能看到这样一个UDF如何派得上用场。我们将建立一个web表单,在此用户可以通过选择checkbox控件而选择一些在DataGrid中的记录。对这些被检查的记录的明细将会出现在表单中的另一个DataGrid中。这个表单像来如图所示。
  
  在下面显示了我们用来建立表单的ASPX。注意:如何使用TemplateColumn和Checkbox控件增加DataGrid列。我们也使用DataGrid的DataKeyField属性来告诉对象,在数据库记录的哪一个字段将会包含第一行的关键字标示符。
  
  <form id="Form1" method="post" runat="server">
  <asp:DataGrid id="DataGrid1" runat="server"
  AutoGenerateColumns="False" DataKeyField="EmployeeID">
  <Columns>
  <asp:TemplateColumn>
  <ItemTemplate>
  <asp:CheckBox runat="server" ID="EmployeeCheckBox" />
  </ItemTemplate>
  </asp:TemplateColumn>
  <asp:TemplateColumn>
  <ItemTemplate>
  <%# DataBinder.Eval(Container.DataItem, "LastName") %>,
  <%# DataBinder.Eval(Container.DataItem, "FirstName") %>
  </ItemTemplate>
  </asp:TemplateColumn>
  </Columns>
  </asp:DataGrid>
  
  <hr>
  
  <asp:Button id="Orders" runat="server" Text="View Orders"></asp:Button>
  <hr>
  <asp:DataGrid ID="DataGrid2" Runat="server" AutoGenerateColumns="True" />
  </form>
  
  当表单加载初始化时,需要组装顶端的DataGrid。代码使用Enterprise Library来存取SQL Sever Northwind例子数据库并且执行“SELECT EmployeeID,FirstName,LastName FROM Employees”这一语句。加载事件的代码如下:
  
  private void Page_Load(object sender, System.EventArgs e)
  {
  if(!Page.IsPostBack)
  {
  Database db = DatabaseFactory.CreateDatabase();
  DBCommandWrapper dbCommandWrapper;
  
  using(dbCommandWrapper = db.GetSqlStringCommandWrapper(SELECT_EMPLOYEES))
  {
  using (IDataReader dataReader = db.ExecuteReader(dbCommandWrapper))
  {
  DataGrid1.DataSource = dataReader;
  DataGrid1.DataBind();
  }
  }
  }
  }
  
  当用户单击“Orders”按钮时,我们想显示与数据库中的那些与Employees相配并与Orders数据相关的第二个数据表格。这样做的一种方法是建立动态的SQL并且使用所有EmployeeIDs所需的WHERE语句的OR条件。
  
  第二个方法是使用WHERE语句的IN操作。IN操作将会一列表达式进行比较。例如,下列语句返回employee中IDS 7和4之间的信息。
  
  SELECT EmployeeID, FirstName, LastName FROM Employees WHERE EmployeeID IN (7, 4)
  
  在观念上说,我愿意使用一个单一字符串参数来查询所传递的IDs,然而,也许作为一个单字符串,不能对IN操作使用一个单一字符串参数。如果那样,SQL语句会这样“WHERE Employee IN (‘7,4’)”,并且数据库因为EmployeeID属于类型int—不属于varchar类型而返回一个错误消息。
  
  不过,我们使用文章中构造的split函数将字符串分离成不同的值。向split函数传递字符串‘7,4’,并且我们会得到与值4和7相对应

网学推荐

免费论文

原创论文

设为首页 | 加入收藏 | 论文首页 | 论文专题 | 设计下载 | 网学软件 | 论文模板 | 论文资源 | 程序设计 | 关于网学 | 站内搜索 | 网学留言 | 友情链接 | 资料中心
版权所有 QQ:3710167 邮箱:3710167@qq.com 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
Copyright 2008-2015 myeducs.Cn www.myeducs.Cn All Rights Reserved 湘ICP备09003080号