我正在修改别人的代码,并且遇到了一个我似乎无法解决的问题。在数据库中,我们有商店位置,并且销售了五种类型的产品。如果某个位置销售产品,则数据库值为“X”。如果没有,则数据库值为null。我正在修改的应用程序有一个搜索框,有一个城市,zip和现在五个产品的复选框(这是刚添加的部分。)理想情况下,你只能输入一个参数,它会显示结果根据你输入/检查了什么,或者你可以输入/检查多个参数。 city / zip位工作正常,但结果只显示销售所有5种产品的位置 - 它无法识别空值。这是我的搜索表单的提交功能:
<script type="text/javascript">
$(function() {
$(".form #searchBtn").click(function() {
var searchParameters = "";
if ($(".form #city").val() != "") {
if (searchParameters != "") {
searchParameters += "&";
}
searchParameters += "city=" + $(".form #city").val();
}
if ($(".form #zip").val() != "") {
if (searchParameters != "") {
searchParameters += "&";
}
searchParameters += "zip=" + $(".form #zip").val();
}
if ($(".form #product1").is(':checked')) {
if (searchParameters != "") {
searchParameters += "&";
}
searchParameters += "product1=" + "X";
}
if ($(".form #product2").is(':checked')) {
if (searchParameters != "") {
searchParameters += "&";
}
searchParameters += "product2=" + "X";
}
if ($(".form #product3").is(':checked')) {
if (searchParameters != "") {
searchParameters += "&";
}
searchParameters += "product3=" + "X";
}
if ($(".form #product4").is(':checked')) {
if (searchParameters != "") {
searchParameters += "&";
}
searchParameters += "product4=" + "X";
}
if ($(".form #product5").is(':checked')) {
if (searchParameters != "") {
searchParameters += "&";
}
searchParameters += "product5=" + "X";
}
searchParameters = searchParameters.replace(" ","%20");
$.fn.colorbox({ href: 'locations.aspx?' + searchParameters });
});
});
</script>
此代码生成的网址包含搜索参数locations.aspx?city = blah&amp; otherParamsHere。任何想法都会非常感激。
修改 的
要回答您的问题,代码全部都在前端。以下是locations.aspx查询的结果,它生成结果。
<asp:SqlDataSource ID="locations" runat="server"
SelectCommand="SELECT * FROM [locations] WHERE (([city] LIKE '%' + @city + '%') AND ([zip] LIKE '%' + @zip + '%') AND ([product1] LIKE '%' + @product1 + '%') AND ([product2] LIKE '%' + @product2 + '%') AND ([product3] LIKE '%' + @product3 + '%') AND ([product4] LIKE '%' + @product4 + '%') AND ([product5] LIKE '%' + @product5 + '%')) ORDER BY [retailer_name]">
<SelectParameters>
<asp:QueryStringParameter DefaultValue="%" Name="city"
QueryStringField="city" Type="String" />
<asp:QueryStringParameter DefaultValue="%" Name="zip"
QueryStringField="zip" Type="String" />
<asp:QueryStringParameter DefaultValue="%" Name="product1"
QueryStringField="product1" Type="String" />
<asp:QueryStringParameter DefaultValue="%" Name="product2"
QueryStringField="product2" Type="String" />
<asp:QueryStringParameter DefaultValue="%" Name="product3"
QueryStringField="product3" Type="String" />
<asp:QueryStringParameter DefaultValue="%" Name="product4"
QueryStringField="product4" Type="String" />
<asp:QueryStringParameter DefaultValue="%" Name="product5"
QueryStringField="product5" Type="String" />
</SelectParameters>
</asp:SqlDataSource>
修改 的
再次修改以包含表格。
<input type="text" id="city" size="20" />
<input type="text" id="zip" maxlength="5" size="5" />
<input type="checkbox" id="product1" value="" />
<input type="checkbox" id="product2" value="" />
<input type="checkbox" id="product3" value="" />
<input type="checkbox" id="product4" value="" />
<input type="checkbox" id="product5" value="" />
<input type="button" value="Search" id="searchBtn"/>
答案 0 :(得分:0)
您应该在select语句where子句中使用产品之间的OR,我认为您可以跳过一些括号。你只需要在你的OR周围使用括号,而不是围绕AND:s试试这个
SELECT * FROM [locations]
WHERE [city] LIKE '%' + @city + '%' AND
[zip] LIKE '%' + @zip + '%' AND
( [product1] LIKE '%' + @product1 + '%' OR
[product2] LIKE '%' + @product2 + '%' OR
[product3] LIKE '%' + @product3 + '%' OR
[product4] LIKE '%' + @product4 + '%' OR
[product5] LIKE '%' + @product5 + '%'
)
ORDER BY [retailer_name]
答案 1 :(得分:0)
我也会尝试同等比较。试试这个:
SELECT * FROM [locations]
WHERE ([city] = @city OR @city = '%') AND
([zip] = @zip OR @zip = '%') AND
(
[product1] = @product1 OR @product1 = '%' OR
[product2] = @product2 OR @product2 = '%' OR
[product3] = @product3 OR @product3 = '%' OR
[product4] = @product4 OR @product4 = '%' OR
[product5] = @product5 OR @product5 = '%'
)
ORDER BY [retailer_name]
答案 2 :(得分:0)
你非常接近!因为你,我能够捅它,直到我弄错了。以下是我最终的SQL语句最终结果,它按照我的意图执行:
SELECT * FROM [locations]
WHERE ([city] = @city OR @city = '%')
AND ([zip] = @zip OR @zip = '%')
AND
(
([product1] = @product1 OR @product1 = '%')
AND ([product2] = @product2 OR @product2 = '%')
AND ([product3] = @product3 OR @product3 = '%')
AND ([product4] = @product4 OR @product4 = '%')
AND ([product5] = @product5 OR @product5 = '%'
))
ORDER BY [retailer_name]