多个复选框值

时间:2014-01-07 22:58:35

标签: c# javascript asp.net tsql sqldatasource

我正在修改别人的代码,并且遇到了一个我似乎无法解决的问题。在数据库中,我们有商店位置,并且销售了五种类型的产品。如果某个位置销售产品,则数据库值为“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"/>

3 个答案:

答案 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]