Solved

DetailsView is not updating the database (Multiple tables)

Posted on 2008-06-15
12
894 Views
Last Modified: 2012-06-27
Hi Guys,
The DetailsView is not updating the databse. There is no error message, but after I clicked update, it retures to detailsview with all old data. Anyone please help me. Thanks
<asp:DetailsView ID="DetailsView3" runat="server" AutoGenerateRows="False" BackColor="White"
        BorderColor="White" BorderStyle="Ridge" BorderWidth="2px" CellPadding="3" CellSpacing="1"
        DataSourceID="AccessDataSourceStudentContact" GridLines="None" Height="50px"
        Width="288px" DataKeyNames="Username">
        <FooterStyle BackColor="#C6C3C6" ForeColor="Black" />
        <EditRowStyle BackColor="#9471DE" Font-Bold="True" ForeColor="White" />
        <RowStyle BackColor="#DEDFDE" ForeColor="Black" />
        <PagerStyle BackColor="#C6C3C6" ForeColor="Black" HorizontalAlign="Right" />
        <Fields>
            <asp:BoundField DataField="Username" HeaderText="Username" ReadOnly="True" SortExpression="Username" />
            <asp:BoundField DataField="Email" HeaderText="Email" SortExpression="Email" />
            <asp:BoundField DataField="LocalPhone" HeaderText="LocalPhone" SortExpression="LocalPhone" />
            <asp:BoundField DataField="LocalWorkPhone" HeaderText="LocalWorkPhone" SortExpression="LocalWorkPhone" />
            <asp:BoundField DataField="PerStreet" HeaderText="PerStreet" SortExpression="PerStreet" />
            <asp:BoundField DataField="PerCity" HeaderText="PerCity" SortExpression="PerCity" />
            <asp:BoundField DataField="PerState" HeaderText="PerState" SortExpression="PerState" />
            <asp:BoundField DataField="PerZip" HeaderText="PerZip" SortExpression="PerZip" />
            <asp:BoundField DataField="PerCountry" HeaderText="PerCountry" SortExpression="PerCountry" />
            <asp:BoundField DataField="LocalStreet" HeaderText="LocalStreet" SortExpression="LocalStreet" />
            <asp:BoundField DataField="LocalCity" HeaderText="LocalCity" SortExpression="LocalCity" />
            <asp:BoundField DataField="LocalState" HeaderText="LocalState" SortExpression="LocalState" />
            <asp:BoundField DataField="LocalZip" HeaderText="LocalZip" SortExpression="LocalZip" />
            <asp:BoundField DataField="AddressUntil" HeaderText="AddressUntil" SortExpression="AddressUntil" />
            <asp:BoundField DataField="CountryName" HeaderText="CountryName" SortExpression="CountryName" />
            <asp:BoundField DataField="CountryCode" HeaderText="CountryCode" SortExpression="CountryCode" />
            <asp:CommandField ShowEditButton="True" />
        </Fields>
        <HeaderStyle BackColor="#4A3C8C" Font-Bold="True" ForeColor="#E7E7FF" />
        <HeaderTemplate>
            Contact Information
        </HeaderTemplate>
    </asp:DetailsView>
    <asp:AccessDataSource ID="AccessDataSourceStudentContact" runat="server" DataFile="~/App_Data/GLC.mdb"
        SelectCommand="SELECT Students.Username, Students.Email, Students.LocalPhone, Students.LocalWorkPhone, Address.PerStreet, Address.PerCity, Address.PerState, Address.PerZip, Address.PerCountry, Address.LocalStreet, Address.LocalCity, Address.LocalState, Address.LocalZip, Address.AddressUntil, Countries.CountryName, Countries.CountryCode FROM ((Students INNER JOIN Address ON Students.Username = Address.UserName) INNER JOIN Countries ON Address.PerCountry = Countries.ID) WHERE (Students.Username = @Username)" 
        UpdateCommand="UPDATE Students, Address SET Students.Email = [@Email], Students.LocalPhone = [@LocalPhone], Students.LocalWorkPhone = [@LocalWorkPhone], Address.PerStreet = [@PerStreet], Address.PerCity = [@PerCity], Address.PerState = [@PerState], Address.PerZip = [@PerZip], Address.PerCountry = [@PerCountry], Address.LocalStreet = [@LocalStreet], Address.LocalCity = [@LocalCity], Address.LocalState = [@LocalState], Address.LocalZip = [@LocalZip], Address.AddressUntil = [@AddressUntil]
WHERE ((([Student].[Username])=[@Username]))">
 
     
    <SelectParameters>
       <asp:QUERYSTRINGPARAMETER DefaultValue="0" Name="Students.Username" QueryStringField="ID" />
    </SelectParameters>

Open in new window

0
Comment
Question by:Robertyue
  • 8
  • 4
12 Comments
 
LVL 21

Expert Comment

by:naspinski
ID: 21790548
First thing is first: Open sql management studio and make sure your query is working in there.
0
 

Author Comment

by:Robertyue
ID: 21792861
Thank you. I'm using access database. I changed the SQL update command to
"UPDATE Address INNER JOIN Students ON Address.UserName = Students.Username SET Students.Email = @Email, Students.LocalPhone = @LocalPhone, Students.LocalWorkPhone = @LocalWorkPhone, Address.PerStreet = @PerStreet, Address.PerCity = @PerCity, Address.PerState = @PerState, Address.PerZip = @PerZip, Address.PerCountry = @PerCountry, Address.LocalStreet = @LocalStreet, Address.LocalCity = @LocalCity, Address.LocalState = @LocalState, Address.LocalZip = @LocalZip, Address.AddressUntil = @AddressUntil WHERE Student.Username=@Username"
It works fine in Access, but not in DetailsView....
0
 

Author Comment

by:Robertyue
ID: 21792880
I've done other detailviews and they are perfectly updating the database because they have only one table.
0
Best Practices: Disaster Recovery Testing

Besides backup, any IT division should have a disaster recovery plan. You will find a few tips below relating to the development of such a plan and to what issues one should pay special attention in the course of backup planning.

 
LVL 21

Expert Comment

by:naspinski
ID: 21792897
I dont see you declaring any UpdateParameters... all of those need to be declared just like you have your SelectParameters up above.
0
 

Author Comment

by:Robertyue
ID: 21793044
Sorry, I forgot the post the rest...I did declare them..Sorry again


    <UpdateParameters>
     <asp:Parameter Name="Email" Type="String" />
     <asp:Parameter Name="LocalPhone" Type="String" />
     <asp:Parameter Name="LocalWorkPhone" Type="String" />
     <asp:Parameter Name="PerStreet" Type="String" />
     <asp:Parameter Name="PerCity" Type="String" />
     <asp:Parameter Name="PerState" Type="String" />
     <asp:Parameter Name="PerZip" Type="String" />
     <asp:Parameter Name="PerCountry" Type="Int32" />
     <asp:Parameter Name="LocalStreet" Type="String" />
     <asp:Parameter Name="LocalCity" Type="String" />
     <asp:Parameter Name="LocalState" Type="String" />
     <asp:Parameter Name="LocalZip" Type="String" />
     <asp:Parameter Name="AddressUntil" Type="DateTime" />
     
     
     
    </UpdateParameters>
0
 

Author Comment

by:Robertyue
ID: 21793074
Here is the complete version
<asp:DetailsView ID="DetailsView3" runat="server" AutoGenerateRows="False" BackColor="White"
        BorderColor="White" BorderStyle="Ridge" BorderWidth="2px" CellPadding="3" CellSpacing="1"
        DataSourceID="AccessDataSourceStudentContact" GridLines="None" Height="50px"
        Width="288px" DataKeyNames="Username">
        <FooterStyle BackColor="#C6C3C6" ForeColor="Black" />
        <EditRowStyle BackColor="#9471DE" Font-Bold="True" ForeColor="White" />
        <RowStyle BackColor="#DEDFDE" ForeColor="Black" />
        <PagerStyle BackColor="#C6C3C6" ForeColor="Black" HorizontalAlign="Right" />
        <Fields>
            <asp:BoundField DataField="Username" HeaderText="Username" ReadOnly="True" SortExpression="Username" />
            <asp:BoundField DataField="Email" HeaderText="Email" SortExpression="Email" />
            <asp:BoundField DataField="LocalPhone" HeaderText="LocalPhone" SortExpression="LocalPhone" />
            <asp:BoundField DataField="LocalWorkPhone" HeaderText="LocalWorkPhone" SortExpression="LocalWorkPhone" />
            <asp:BoundField DataField="PerStreet" HeaderText="PerStreet" SortExpression="PerStreet" />
            <asp:BoundField DataField="PerCity" HeaderText="PerCity" SortExpression="PerCity" />
            <asp:BoundField DataField="PerState" HeaderText="PerState" SortExpression="PerState" />
            <asp:BoundField DataField="PerZip" HeaderText="PerZip" SortExpression="PerZip" />
            <asp:BoundField DataField="PerCountry" HeaderText="PerCountry" SortExpression="PerCountry" />
            <asp:BoundField DataField="LocalStreet" HeaderText="LocalStreet" SortExpression="LocalStreet" />
            <asp:BoundField DataField="LocalCity" HeaderText="LocalCity" SortExpression="LocalCity" />
            <asp:BoundField DataField="LocalState" HeaderText="LocalState" SortExpression="LocalState" />
            <asp:BoundField DataField="LocalZip" HeaderText="LocalZip" SortExpression="LocalZip" />
            <asp:BoundField DataField="AddressUntil" HeaderText="AddressUntil" SortExpression="AddressUntil" />
            <asp:BoundField DataField="CountryName" HeaderText="CountryName" SortExpression="CountryName" />
            <asp:BoundField DataField="CountryCode" HeaderText="CountryCode" SortExpression="CountryCode" />
            <asp:CommandField ShowEditButton="True" />
        </Fields>
        <HeaderStyle BackColor="#4A3C8C" Font-Bold="True" ForeColor="#E7E7FF" />
        <HeaderTemplate>
            Contact Information
        </HeaderTemplate>
    </asp:DetailsView>
    <asp:AccessDataSource ID="AccessDataSourceStudentContact" runat="server" DataFile="~/App_Data/GLC.mdb"
        SelectCommand="SELECT Students.Username, Students.Email, Students.LocalPhone, Students.LocalWorkPhone, Address.PerStreet, Address.PerCity, Address.PerState, Address.PerZip, Address.PerCountry, Address.LocalStreet, Address.LocalCity, Address.LocalState, Address.LocalZip, Address.AddressUntil, Countries.CountryName, Countries.CountryCode FROM ((Students INNER JOIN Address ON Students.Username = Address.UserName) INNER JOIN Countries ON Address.PerCountry = Countries.ID) WHERE (Students.Username = @Username)" 
        UpdateCommand="UPDATE (Address INNER JOIN Students ON Address.UserName = Students.Username) SET Students.Email = @Email, Students.LocalPhone = @LocalPhone, Students.LocalWorkPhone = @LocalWorkPhone, Address.PerStreet = @PerStreet, Address.PerCity = @PerCity, Address.PerState = @PerState, Address.PerZip = @PerZip, Address.PerCountry = @PerCountry, Address.LocalStreet = @LocalStreet, Address.LocalCity = @LocalCity, Address.LocalState = @LocalState, Address.LocalZip = @LocalZip, Address.AddressUntil = @AddressUntil WHERE (Student.Username=@Username)">
 
     
    <SelectParameters>
       <asp:QUERYSTRINGPARAMETER DefaultValue="0" Name="Students.Username" QueryStringField="ID" />
    </SelectParameters>
    
    <UpdateParameters>
     <asp:Parameter Name="Email" Type="String" />
     <asp:Parameter Name="LocalPhone" Type="String" />
     <asp:Parameter Name="LocalWorkPhone" Type="String" />
     <asp:Parameter Name="PerStreet" Type="String" />
     <asp:Parameter Name="PerCity" Type="String" />
     <asp:Parameter Name="PerState" Type="String" />
     <asp:Parameter Name="PerZip" Type="String" />
     <asp:Parameter Name="PerCountry" Type="Int32" />
     <asp:Parameter Name="LocalStreet" Type="String" />
     <asp:Parameter Name="LocalCity" Type="String" />
     <asp:Parameter Name="LocalState" Type="String" />
     <asp:Parameter Name="LocalZip" Type="String" />
     <asp:Parameter Name="AddressUntil" Type="DateTime" />
     
    </UpdateParameters>
    
    </asp:AccessDataSource>

Open in new window

0
 
LVL 21

Accepted Solution

by:
naspinski earned 500 total points
ID: 21793094
I dont see username in there.  I know it is a readonly, but it still needs to be declared.

Try adding that in.
0
 

Author Comment

by:Robertyue
ID: 21793220
I did add it in but it's still not working. I didn't declare Username for my another single table detailsview and it works.  Thanks
0
 

Author Comment

by:Robertyue
ID: 21793234
Is my SQL Update command wrong? It works in Access. The format is wrong in ASP.Net, may be?
0
 

Author Comment

by:Robertyue
ID: 21793284
Please see attachment. This is my database and there is only one query (update). Please enter "hao" as the Uername. Why it's asking me to enter the username for both "Students.Username" and "@Username"? Should it ask me to only enter "@Username", then the database compares the entry with records to find out the data? Thanks
GLC.mdb
0
 
LVL 21

Expert Comment

by:naspinski
ID: 21793298
Sorry, I have to get going today, but I can take a look at it in about 12 hours if someone doesn't beat me to it.
0
 

Author Comment

by:Robertyue
ID: 21809504
Hello, you back? Could you please take a look my databse? Thanks
0

Featured Post

Problems using Powershell and Active Directory?

Managing Active Directory does not always have to be complicated.  If you are spending more time trying instead of doing, then it's time to look at something else. For nearly 20 years, AD admins around the world have used one tool for day-to-day AD management: Hyena. Discover why

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
Calling web service and its methods dynamically 2 59
Adware on IIS hosted asp.net website 1 27
asp day pilot 3 19
Regex validation 2 24
Today is the age of broadband.  More and more people are going this route determined to experience the web and it’s multitude of services as quickly and painlessly as possible. Coupled with the move to broadband, people are experiencing the web via …
In .NET 2.0, Microsoft introduced the Web Site.  This was the default way to create a web Project in Visual Studio 2005.  In Visual Studio 2008, the Web Application has been restored as the default web Project in Visual Studio/.NET 3.x The Web Si…
Along with being a a promotional video for my three-day Annielytics Dashboard Seminor, this Micro Tutorial is an intro to Google Analytics API data.
Email security requires an ever evolving service that stays up to date with counter-evolving threats. The Email Laundry perform Research and Development to ensure their email security service evolves faster than cyber criminals. We apply our Threat…

773 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