在ASP.NET中使用SQL的IN操作
来源:互联网 发布:杨康的幸福生活 知乎 编辑:程序博客网 时间:2024/05/16 03:36
在文章的结尾,我们写了一个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相对应的两条记录。选择employees并且计算它们的定单总数的SQL查询,将会如下:
SELECT count(*) AS Orders, E.FirstName, E.LastName
FROM Orders O
INNER JOIN Employees E ON O.EmployeeID = E.EmployeeID
WHERE E.EmployeeID IN(SELECT Value FROM fn_Split(@employeeIDs, ','))
GROUP BY FirstName, LastName
ORDER BY count(*) DESC
使用以上查询所需要的是必须建立和传递@employeeIDs参数。这个参数将是用逗号隔开的IDs列表。为了建立该字符串,为了弄明白行是否被用户选择,我们需要使用一个循环,这一循环以行数循环次数,并且检查每一个checkbox控件。如果用户选择了行,通过从表的DataKeys属性中(它被建立在ASPX文件中来指向EmployeeID字段)提取检验人,将关键字保存在employee中。
private strINg GetCheckedEmployeeIDs()
{
StrINg delimiter = StrINg.Empty;
StrINgBuilder employeeIDs = new StrINgBuilder();
for(INt i = 0; i < DataGrid1.Items.Count; i )
{
CheckBox checkbox;
checkbox = DataGrid1.Items[i].FINdControl("EmployeeCheckBox") as CheckBox;
if(checkbox != null && checkbox.Checked == true)
{
employeeIDs.Append(delimiter DataGrid1.DataKeys[i].ToStrINg()) ;
delimiter = ",";
}
}
return employeeIDs.ToStrINg();
}
以上方法返回一个字符串,像“10,7,20”。对Orders按钮单击事件处理器将涉及这样一个方法,将信息传递至SQL以得到employees和orders的列表,并且将其结果绑定在第二个DataGrid对象中。
private void Orders_Click(object sender, System.EventArgs e)
{
strINg employeeIDs = GetCheckedEmployeeIDs();
Database db = DatabaseFactory.CreateDatabase();
DBCommandWrapper dbCommandWrapper;
usINg(dbCommandWrapper = db.GetSQLStrINgCommandWrapper(SELECT_ORDERS))
{
dbCommandWrapper.AddINParameter("@employeeIDs", DbType.StrINg, employeeIDs);
usINg (IDataReader dataReader = db.ExecuteReader(dbCommandWrapper))
{
DataGrid2.DataSource = dataReader;
DataGrid2.DataBINd();
}
}
}
- 在ASP.NET中使用SQL的IN操作
- 在ASP.NET中使用SQL的IN操作
- 在ASP.NET中使用SQL的IN操作
- 在ASP.NET中操作SQL Server的小技巧
- 在PreparedStatement中,sql使用in操作符的问题
- 在asp.net中操作sql-server数据库的一些小技巧
- 在asp.net中操作sql-server数据库的一些小技巧
- 在asp.net中操作sql server数据库的一些小技巧
- [C#.Net]在ASP.NET中操作文件的例子
- 在ASP.NET中使用WINDOWS模式登录SQL数据库
- 在Asp.Net中操作PDF - iTextSharp - 使用字体
- 在Asp.Net中操作PDF – iTextSharp - 使用表格
- 在ASP.NET 2.0中操作数据:使用FormView 的模板
- 在ASP.NET 2.0中操作数据:使用FormView 的模板
- ASP.NET中操作SQL数据库
- 在ASP.NET中操作文件的例子(VB)
- 在ASP.NET中操作文件的例子
- 在Asp.net中操作IIS的虚拟目录(C#)
- Asp.neturl分页的用户控件
- ASP.NET2.0中DataTable小兵变大将
- 对“学号”、“身份证”的数字分析
- 把.NET程序部署到没有安装.NETFramwork的机器上
- 利用ASP.NET的内置功能抵御Web攻击
- 在ASP.NET中使用SQL的IN操作
- 开发ASP.NET下的MP3小偷程序
- ASP.NET设计网络硬盘之删除文件夹
- ASPX保存远程图片到本地的两种方法的函数
- asp.net开发web项目-vss集成环境配置
- datagrid与DataSet结合使用中出现的索引问题
- ASP.NETWeb服务实现软件共享
- ASP.NET设计网络硬盘之文件夹实现
- ASP.NET中为DataGrid添加合计字段