Solved

Populate Dropdownlist with data from database and add blank row

Posted on 2008-10-10
6
794 Views
Last Modified: 2010-04-21
Hello,

I'm new to ASP so I need help to do the following:

I need to populate a Dropdownlist with data from an Access database table. I can bind the control to a DataSource in design mode but I want to fill the dropdownlist with data using code so that I can add on the first row a blank row or some kind of message like "Choose your Color...". So far I've writen the code below, then I got stucked...

Can you please help me do this?

Thanks,

jppinto
Dim strSql As String = ""
strSql = "SELECT [Descricao] FROM [Leis] ORDER BY [Descricao]"
Dim Conn As New OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;" & "Data Source=C:\Programação\AEDemo\db\manpower.mdb")
Dim Cmd As New OleDbCommand(strSql, Conn)
Conn.Open()

Open in new window

0
Comment
Question by:jppinto
6 Comments
 
LVL 4

Accepted Solution

by:
sijishJohn earned 125 total points
ID: 22685604
try this..
Dim strSql As String = ""
        strSql = "SELECT [Descricao] FROM [Leis] ORDER BY [Descricao]"
        Dim Conn As New OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;" & "Data Source=C:\Programação\AEDemo\db\manpower.mdb")
        Dim Cmd As New OleDbCommand(strSql, Conn)
        Conn.Open()
        DropDownList1.DataSource = Cmd.ExecuteNonQuery()
        DropDownList1.DataBind()
        DropDownList1.Items.Add(New ListItem("Choose your Color...", "-1"))
        Conn.Close()

Open in new window

0
 
LVL 20

Expert Comment

by:informaniac
ID: 22685627
Sorry dude have c# code only...
OleDbDataAdapter da = new OleDbDataAdapter();
da.SelectCommand = cmd;
 
DataSet ds = new DataSet();
 
da.Fill(ds);
 
ddl.DataSource = ds.Tables[0];
ddl.DataTextField = "Descricao";
ddl.DataValueField="Descricao";
ddl.DataBind();
 
ListItem li = new ListItem("Select avalue","0");
ddl.Items.Insert(0,li);

Open in new window

0
 
LVL 14

Assisted Solution

by:Binuth
Binuth earned 125 total points
ID: 22685634
try this

        Dim strSql As String = ""
        strSql = "SELECT [Descricao] FROM [Leis] ORDER BY [Descricao]"
        Dim Conn As New Data.OleDb.OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;" & "Data Source=C:\Programação\AEDemo\db\manpower.mdb")
        Dim Cmd As New Data.OleDb.OleDbCommand(strSql, Conn)
        Dim adp As New Data.OleDb.OleDbDataAdapter(Cmd)
 
        Dim dt As New Data.DataTable
        adp.Fill(dt)
 
        DropDownList1.DataSource = dt
        DropDownList1.DataTextField = "Descricao"
        DropDownList1.DataValueField = "Descricao"
        DropDownList1.DataBind()
 
        DropDownList1.Items.Insert(0, "Choose your Color...")

Open in new window

0
Gigs: Get Your Project Delivered by an Expert

Select from freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely and get projects done right.

 
LVL 7

Assisted Solution

by:ajolly
ajolly earned 125 total points
ID: 22685635
You can add this item at design time, Choose your Color...
and specify AppendDataBoundItems property of the dropdownlist as true.


<asp:DropDownList ID="DropDownList1" runat="server" AppendDataBoundItems="true">
    <asp:ListItem Value="" Text="Choose your Color...">
    </asp:ListItem>
</asp:DropDownList>

Open in new window

0
 
LVL 20

Assisted Solution

by:informaniac
informaniac earned 125 total points
ID: 22685638
Here's the entire code
Dim strSql As String = ""
strSql = "SELECT [Descricao] FROM [Leis] ORDER BY [Descricao]"
Dim Conn As New OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;" & "Data Source=C:\Programação\AEDemo\db\manpower.mdb")
Dim Cmd As New OleDbCommand(strSql, Conn)
Conn.Open()
 
Dim da As OleDbDataAdapter =  New OleDbDataAdapter() 
da.SelectCommand = cmd
 
Dim ds As DataSet =  New DataSet() 
 
da.Fill(ds)
 
ddl.DataSource = ds.Tables(0)
ddl.DataTextField = "Descricao"
ddl.DataValueField="Descricao"
ddl.DataBind()
 
Dim li As ListItem =  New ListItem("Select a value","0") 
ddl.Items.Insert(0,li)

Open in new window

0
 
LVL 33

Author Closing Comment

by:jppinto
ID: 31504949
I've chosen to put only a blank row and mantain the control bound to the datasource.
Thanks annyway.

jppinto
0

Featured Post

Gigs: Get Your Project Delivered by an Expert

Select from freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely and get projects done right.

Question has a verified solution.

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

I recently went through the process of creating a Calendar Control of events with the basis of using a database to keep track of the dates that are selectable, one requirement was to have the selected date pop-up in a simple lightbox.  At first this…
User art_snob (http://www.experts-exchange.com/M_6114203.html) encountered strange behavior of Android Web browser on his Mobile Web site. It took a while to find the true cause. It happens so, that the Android Web browser (at least up to OS ver. 2.…
With Secure Portal Encryption, the recipient is sent a link to their email address directing them to the email laundry delivery page. From there, the recipient will be required to enter a user name and password to enter the page. Once the recipient …
A short tutorial showing how to set up an email signature in Outlook on the Web (previously known as OWA). For free email signatures designs, visit https://www.mail-signatures.com/articles/signature-templates/?sts=6651 If you want to manage em…

776 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