?
Solved

Read database but dont get all answers only first one

Posted on 2009-05-03
2
Medium Priority
?
175 Views
Last Modified: 2012-05-06
Why do I only get the first answer in my sql statment from the database?

I know there are at least four CustomerID
public void ReadOrder(String customerid)
    {
        String myConnectionString = "PROVIDER=Microsoft.Jet.OLEDB.4.0;Data Source= C:\\Documents and Settings\\MFL\\Dokumenter\\Visual Studio 2005\\WebSites\\WebSite\\WebSite\\Tenta1\\Nwind.mdb";
        OleDbConnection myConnection = new OleDbConnection(myConnectionString);
        string myInsertQuery = "SELECT * FROM Orders WHERE (CustomerID) ='" +customerid +"'";
        OleDbCommand myCommand = new OleDbCommand(myInsertQuery);
        myCommand.Connection = myConnection;
        myConnection.Open();
        OleDbDataReader rdr = myCommand.ExecuteReader();
        rdr.Read();
 
        if (rdr.HasRows)
        {
            Order temp = new Order();
            temp.OrderId = rdr[0].ToString();
            temp.Customer = rdr[1].ToString();
            temp.Employee = rdr[2].ToString();
            temp.OrderDate = rdr[3].ToString();
            temp.RequriedDate = rdr[4].ToString();
            temp.ShippingDate = rdr[5].ToString();
            temp.ShipVia = rdr[6].ToString();
            temp.Freight = rdr[7].ToString();
            temp.ShipName = rdr[8].ToString();
            temp.ShipAdress = rdr[9].ToString();
            temp.ShipCity = rdr[10].ToString();
            temp.ShipRegion = rdr[11].ToString();
            temp.ShipPostalCode = rdr[12].ToString();
            temp.ShipCountry = rdr[13].ToString();
            order.Add(temp);
 
 
            Response.Redirect("Uppgift3cc.aspx");
        }
 
        myConnection.Close();
    }
}

Open in new window

0
Comment
Question by:Mickeys
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
2 Comments
 
LVL 4

Accepted Solution

by:
cauos earned 1200 total points
ID: 24290043
because you should add rdr.Read() to loop through all the result that come from the query

public void ReadOrder(String customerid)
    {
        String myConnectionString = "PROVIDER=Microsoft.Jet.OLEDB.4.0;Data Source= C:\\Documents and Settings\\MFL\\Dokumenter\\Visual Studio 2005\\WebSites\\WebSite\\WebSite\\Tenta1\\Nwind.mdb";
        OleDbConnection myConnection = new OleDbConnection(myConnectionString);
        string myInsertQuery = "SELECT * FROM Orders WHERE (CustomerID) ='" +customerid +"'";
        OleDbCommand myCommand = new OleDbCommand(myInsertQuery);
        myCommand.Connection = myConnection;
        myConnection.Open();
        OleDbDataReader rdr = myCommand.ExecuteReader();
        while(rdr.Read())
        {
        if (rdr.HasRows)
        {
            Order temp = new Order();
            temp.OrderId = rdr[0].ToString();
            temp.Customer = rdr[1].ToString();
            temp.Employee = rdr[2].ToString();
            temp.OrderDate = rdr[3].ToString();
            temp.RequriedDate = rdr[4].ToString();
            temp.ShippingDate = rdr[5].ToString();
            temp.ShipVia = rdr[6].ToString();
            temp.Freight = rdr[7].ToString();
            temp.ShipName = rdr[8].ToString();
            temp.ShipAdress = rdr[9].ToString();
            temp.ShipCity = rdr[10].ToString();
            temp.ShipRegion = rdr[11].ToString();
            temp.ShipPostalCode = rdr[12].ToString();
            temp.ShipCountry = rdr[13].ToString();
            order.Add(temp);
 
 
            Response.Redirect("Uppgift3cc.aspx");
        }
        }
        myConnection.Close();
    }
}

Open in new window

0
 
LVL 9

Assisted Solution

by:tillgeffken
tillgeffken earned 800 total points
ID: 24290051
Cause you're not looping through the DataReader.

public void ReadOrder(String customerid)
    {
        String myConnectionString = "PROVIDER=Microsoft.Jet.OLEDB.4.0;Data Source= C:\\Documents and Settings\\MFL\\Dokumenter\\Visual Studio 2005\\WebSites\\WebSite\\WebSite\\Tenta1\\Nwind.mdb";
        OleDbConnection myConnection = new OleDbConnection(myConnectionString);
        string myInsertQuery = "SELECT * FROM Orders WHERE (CustomerID) ='" +customerid +"'";
        OleDbCommand myCommand = new OleDbCommand(myInsertQuery);
        myCommand.Connection = myConnection;
        myConnection.Open();
        OleDbDataReader rdr = myCommand.ExecuteReader();
 
        if (rdr.HasRows)
        {
           while (dr.Read())
           {
            Order temp = new Order();
            temp.OrderId = rdr[0].ToString();
            temp.Customer = rdr[1].ToString();
            temp.Employee = rdr[2].ToString();
            temp.OrderDate = rdr[3].ToString();
            temp.RequriedDate = rdr[4].ToString();
            temp.ShippingDate = rdr[5].ToString();
            temp.ShipVia = rdr[6].ToString();
            temp.Freight = rdr[7].ToString();
            temp.ShipName = rdr[8].ToString();
            temp.ShipAdress = rdr[9].ToString();
            temp.ShipCity = rdr[10].ToString();
            temp.ShipRegion = rdr[11].ToString();
            temp.ShipPostalCode = rdr[12].ToString();
            temp.ShipCountry = rdr[13].ToString();
            order.Add(temp);
           }
 
            Response.Redirect("Uppgift3cc.aspx");
        }
 
        myConnection.Close();
    }
}

Open in new window

0

Featured Post

Get your Conversational Ransomware Defense e‑book

This e-book gives you an insight into the ransomware threat and reviews the fundamentals of top-notch ransomware preparedness and recovery. To help you protect yourself and your organization. The initial infection may be inevitable, so the best protection is to be fully prepared.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Confronted with some SQL you don't know can be a daunting task. It can be even more daunting if that SQL carries some of the old secret codes used in the Ye Olde query syntax, such as: (+)     as used in Oracle;     *=     =*    as used in Sybase …
This article aims to explain the working of CircularLogArchiver. This tool was designed to solve the buildup of log file in cases where systems do not support circular logging or where circular logging is not enabled
Monitoring a network: how to monitor network services and why? Michael Kulchisky, MCSE, MCSA, MCP, VTSP, VSP, CCSP outlines the philosophy behind service monitoring and why a handshake validation is critical in network monitoring. Software utilized …
In this video you will find out how to export Office 365 mailboxes using the built in eDiscovery tool. Bear in mind that although this method might be useful in some cases, using PST files as Office 365 backup is troublesome in a long run (more on t…
Suggested Courses

752 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question