Go Premium for a chance to win a PS4. Enter to Win

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 969
  • Last Modified:

passing variable QueryStringParameter of SelectParameters in SqlDataSource for DataGrid not working

I have a web site done in ASP.NET with VB.NET on MS Visual Web Developer.  I'm tring to pass a variable from the QueryStringParameter of SelectParameters in SqlDataSource for a DataGrid, but it's not working.  It takes me to the correct page with the correct Request.QueryString (http://www.omahavaccine.com/search_product_list.aspx?search=chews) but the page shows nothing in the DataGrid (code snippet below).  I checked the SELECT statement in my MS SQL Server 2005 database and the correct records are returned.  Is there something wrong with the syntax of my SELECT statement (no error mesages are generated)?
<asp:DataGrid ID="DataGrid1" runat="server" AllowPaging="True" AllowSorting="True" PageSize="10" 
            OnPageIndexChanged="DataGrid_PageChanger" BorderColor="Black" BorderWidth="1px" CellPadding="2" 
            DataSourceID="SqlDataSource1" ForeColor="#333333" AutoGenerateColumns="False">
            <FooterStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
            <EditItemStyle BackColor="#999999" />
            <SelectedItemStyle BackColor="Yellow" Font-Bold="False" ForeColor="Maroon" Font-Italic="False" Font-Overline="False" Font-Strikeout="False" Font-Underline="False" />
            <PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" Mode="NumericPages" />
            <AlternatingItemStyle BackColor="White" ForeColor="#284775" />
            <ItemStyle BackColor="#F7F6F3" ForeColor="#333333" />
            <HeaderStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" HorizontalAlign="Center" VerticalAlign="Middle" />
            <Columns>
                <asp:HyperLinkColumn DataNavigateUrlField="sku" DataNavigateUrlFormatString="product_details.aspx?sku={0}" Text="View Product" />
                <asp:BoundColumn DataField="sku" HeaderText="SKU" ReadOnly="True"></asp:BoundColumn>
                <asp:BoundColumn DataField="product" HeaderText="Product" ReadOnly="True"></asp:BoundColumn>
                <asp:BoundColumn DataField="short_descr" HeaderText="Model / Size" ReadOnly="True"></asp:BoundColumn>
                <asp:BoundColumn DataField="price" HeaderText="Price" ReadOnly="True"></asp:BoundColumn>
            </Columns>
        </asp:DataGrid>
        <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:omahavaccineConnectionString %>"
            SelectCommand="SELECT product.sml_img as image, product.sku as sku, product_main.product_name as product, product.product_name as short_descr, product.price as price, Categorization.categoryID AS id FROM product INNER JOIN product_main ON product.associated_master_product_id = product_main.id INNER JOIN Categorization ON product.sku = Categorization.sku WHERE (product.sku NOT LIKE '%-main') AND ((product_main.product_name LIKE '%@strSearch%') OR (product.sku LIKE '@strSearch%')) ORDER BY product.name">
            <SelectParameters>
                <asp:QueryStringParameter Name="strSearch" QueryStringField="search" Type="String" />
            </SelectParameters>
        </asp:SqlDataSource>

Open in new window

0
OVC-it-guy
Asked:
OVC-it-guy
  • 4
  • 4
1 Solution
 
HoggZillaCommented:
Check your variables, they are in quotes. I know you want the results to be in quotes for the SQL stmt but you may have to pull them out of the quotes.
0
 
HoggZillaCommented:
MySQL="Select * from Customers where lname = '" & sLName & "'"
0
 
HoggZillaCommented:
If you are trying to use a Paramatized Query, check your syntax here:
http://aspnet101.com/aspnet101/tutorials.aspx?id=1
 
0
Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
eszaqCommented:
Check if this might be a problem - your WHERE clause reads:
OR (product.sku LIKE '@strSearch%'))
Wild character is missing:
OR (product.sku LIKE '%@strSearch%')


0
 
OVC-it-guyAuthor Commented:
eszaq,

No, I left the wild character out of that where clause because our customers know our id numbers (sku's) from our hardcopy catalog.  WHat they sometime forget is the last letter, if there is one (e.g., the actual shu is 01473A, but all they enter is 01473).  Using like with the trailing wild character will catch that.
0
 
OVC-it-guyAuthor Commented:
HoggZilla,

When I put in the extra quotes (because the entire SQL query is in doubles and like must have the single quotes), I get the error that the variable name "Attribute 'strSearch' is not a valid attribute of element SqlDataSource."  I think your suggestion is going in the right direction because I do need it in quotes as a string in case the customer searches for more than one word.
0
 
OVC-it-guyAuthor Commented:
HoggZilla,

I tried the tutorial, found the bit about quotes with like in the where clause.  So I tried it as follows:
SelectCommand="SELECT product.sml_img as image, product.sku as sku, product_main.product_name as product, product.product_name as short_descr, product.price as price, Categorization.categoryID AS id FROM product INNER JOIN product_main ON product.associated_master_product_id = product_main.id INNER JOIN Categorization ON product.sku = Categorization.sku WHERE (product.sku NOT LIKE '%-main') AND ((product_main.product_name LIKE '%' + @strSearch + '%') OR (product.sku LIKE '%' + @strSearch = '%')) ORDER BY product.name">

Now I get the error System.Data.SqlClient.SqlException: Incorrect syntax near '=' when it hits the DataGrid1.DataBind() upon page_load.  ANybody got any ideas?
0
 
OVC-it-guyAuthor Commented:
Oops, caught my mistake (not holding the shift key when I need a +).  HoggZilla, the tutorial was the answer.
0
 
HoggZillaCommented:
product_main.product_name LIKE '%" & @strSearch & "%') OR
0

Featured Post

What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

  • 4
  • 4
Tackle projects and never again get stuck behind a technical roadblock.
Join Now