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

简介:

这篇文章将建立一列包含CheckBox控件的DataGrid,这个控件允许用户对明细浏览进行多列选择。如果没有恢复对于动态SQL获得该功能的一种方法,那么必须使用IN操作。

在文章的结尾,我们写了一个SQLServer用户自定义函数(UDF),为了将一个字符串分解成带分隔符的子字符串。在这篇文章中,我们能看到这样一个UDF如何派得上用场。我们将建立一个web表单,在此用户可以通过选择checkbox控件而选择一些在DataGrid中的记录。对这些被检查的记录的明细将会出现在表单中的另一个DataGrid中。这个表单像来如图所示。

在下面显示了我们用来建立表单的ASPX。注意:如何使用TemplateColumn和Checkbox控件增加DataGrid列。我们也使用DataGrid的DataKeyField属性来告诉对象,在数据库记录的哪一个字段将会包含第一行的关键字标示符。 

<formid="Form1"method="post"runat="server">
<asp:DataGridid="DataGrid1"runat="server"
 AutoGenerateColumns="False"DataKeyField="EmployeeID">
 <Columns>
<asp:TemplateColumn>
 <ItemTemplate>
<asp:CheckBoxrunat="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:Buttonid="Orders"runat="server"Text="ViewOrders"></asp:Button>
<hr>
<asp:DataGridID="DataGrid2"Runat="server"AutoGenerateColumns="True"/>
</form>

当表单加载初始化时,需要组装顶端的DataGrid。代码使用EnterpriseLibrary来存取SQLSeverNorthwind例子数据库并且执行“SELECTEmployeeID,FirstName,LastNameFROMEmployees”这一语句。加载事件的代码如下:

privatevoidPage_Load(objectsender,System.EventArgse)
{
 if(!Page.IsPostBack)
 {
Databasedb=DatabaseFactory.CreateDatabase();
DBCommandWrapperdbCommandWrapper;

using(dbCommandWrapper=db.GetSqlStringCommandWrapper(SELECT_EMPLOYEES))
{
 using(IDataReaderdataReader=db.ExecuteReader(dbCommandWrapper))
 {
DataGrid1.DataSource=dataReader;
DataGrid1.DataBind();
 }
}
 }
}

当用户单击“Orders”按钮时,我们想显示与数据库中的那些与Employees相配并与Orders数据相关的第二个数据表格。这样做的一种方法是建立动态的SQL并且使用所有EmployeeIDs所需的WHERE语句的OR条件。

第二个方法是使用WHERE语句的IN操作。IN操作将会一列表达式进行比较。例如,下列语句返回employee中IDS7和4之间的信息。

SELECTEmployeeID,FirstName,LastNameFROMEmployeesWHEREEmployeeIDIN(7,4)

在观念上说,我愿意使用一个单一字符串参数来查询所传递的IDs,然而,也许作为一个单字符串,不能对IN操作使用一个单一字符串参数。如果那样,SQL语句会这样“WHEREEmployeeIN(‘7,4’)”,并且数据库因为EmployeeID属于类型int—不属于varchar类型而返回一个错误消息。

不过,我们使用文章中构造的split函数将字符串分离成不同的值。向split函数传递字符串‘7,4’,并且我们会得到与值4和7相对应的两条记录。选择employees并且计算它们的定单总数的SQL查询,将会如下:

SELECTcount(*)ASOrders,E.FirstName,E.LastName

FROMOrdersO

INNERJOINEmployeesEONO.EmployeeID=E.EmployeeID

WHEREE.EmployeeIDIN(SELECTValueFROMfn_Split(@employeeIDs,','))

GROUPBYFirstName,LastName

ORDERBYcount(*)DESC

使用以上查询所需要的是必须建立和传递@employeeIDs参数。这个参数将是用逗号隔开的IDs列表。为了建立该字符串,为了弄明白行是否被用户选择,我们需要使用一个循环,这一循环以行数循环次数,并且检查每一个checkbox控件。如果用户选择了行,通过从表的DataKeys属性中(它被建立在ASPX文件中来指向EmployeeID字段)提取检验人,将关键字保存在employee中。

privatestringGetCheckedEmployeeIDs()
{
 Stringdelimiter=String.Empty;
 StringBuilderemployeeIDs=newStringBuilder();
 for(inti=0;i<DataGrid1.Items.Count;i++)
 {
CheckBoxcheckbox;
checkbox=DataGrid1.Items[i].FindControl("EmployeeCheckBox")asCheckBox;
if(checkbox!=null&&checkbox.Checked==true)
{
 employeeIDs.Append(delimiter+DataGrid1.DataKeys[i].ToString());
 delimiter=",";
}
 }

 returnemployeeIDs.ToString();
}

以上方法返回一个字符串,像“10,7,20”。对Orders按钮单击事件处理器将涉及这样一个方法,将信息传递至SQL以得到employees和orders的列表,并且将其结果绑定在第二个DataGrid对象中。

privatevoidOrders_Click(objectsender,System.EventArgse)
{
 stringemployeeIDs=GetCheckedEmployeeIDs();
 Databasedb=DatabaseFactory.CreateDatabase();
 DBCommandWrapperdbCommandWrapper;

 using(dbCommandWrapper=db.GetSqlStringCommandWrapper(SELECT_ORDERS))
 {
dbCommandWrapper.AddInParameter("@employeeIDs",DbType.String,employeeIDs);
using(IDataReaderdataReader=db.ExecuteReader(dbCommandWrapper))
{
 DataGrid2.DataSource=dataReader;
 DataGrid2.DataBind();
}
 }
}

目录
相关文章
|
1月前
|
SQL 数据库 C#
C# .NET面试系列十一:数据库SQL查询(附建表语句)
#### 第1题 用一条 SQL 语句 查询出每门课都大于80 分的学生姓名 建表语句: ```sql create table tableA ( name varchar(10), kecheng varchar(10), fenshu int(11) ) DEFAULT CHARSET = 'utf8'; ``` 插入数据 ```sql insert into tableA values ('张三', '语文', 81); insert into tableA values ('张三', '数学', 75); insert into tableA values ('李四',
62 2
C# .NET面试系列十一:数据库SQL查询(附建表语句)
|
2月前
|
SQL 数据库 数据安全/隐私保护
【操作宝典】SQL巨擘:掌握SQL Server Management的终极秘籍!
【操作宝典】SQL巨擘:掌握SQL Server Management的终极秘籍!
61 0
|
4月前
|
SQL 分布式计算 数据库
【大数据技术Spark】Spark SQL操作Dataframe、读写MySQL、Hive数据库实战(附源码)
【大数据技术Spark】Spark SQL操作Dataframe、读写MySQL、Hive数据库实战(附源码)
85 0
|
3月前
|
SQL Oracle 关系型数据库
整合Mybatis-Plus高级,Oracle 主键Sequence,Sql 注入器实现自定义全局操作
整合Mybatis-Plus高级,Oracle 主键Sequence,Sql 注入器实现自定义全局操作
87 0
|
3月前
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
38 0
|
30天前
|
SQL 安全 数据库
第三章用sql语句操作数据
第三章用sql语句操作数据
10 0
|
1月前
|
SQL druid Java
【MyBatis】2、MyBatis 的动态 SQL 和增删改操作
【MyBatis】2、MyBatis 的动态 SQL 和增删改操作
29 0
|
2月前
|
SQL 开发框架 .NET
ASP.NET Web——GridView完整增删改查示例(全篇幅包含sql脚本)大二结业考试必备技能
ASP.NET Web——GridView完整增删改查示例(全篇幅包含sql脚本)大二结业考试必备技能
32 0
|
3月前
|
SQL 数据库
SQL-修改表操作
SQL-修改表操作
|
3月前
|
SQL 存储 关系型数据库
SQL语句-表操作
SQL语句-表操作