Link to home
Create AccountLog in
Avatar of Robertyue
Robertyue

asked on

DetailsView is not updating the database (Multiple tables)

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

Avatar of naspinski
naspinski
Flag of United States of America image

First thing is first: Open sql management studio and make sure your query is working in there.
Avatar of Robertyue
Robertyue

ASKER

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....
I've done other detailviews and they are perfectly updating the database because they have only one table.
I dont see you declaring any UpdateParameters... all of those need to be declared just like you have your SelectParameters up above.
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>
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

ASKER CERTIFIED SOLUTION
Avatar of naspinski
naspinski
Flag of United States of America image

Link to home
membership
Create a free account to see this answer
Signing up is free and takes 30 seconds. No credit card required.
See answer
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
Is my SQL Update command wrong? It works in Access. The format is wrong in ASP.Net, may be?
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
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.
Hello, you back? Could you please take a look my databse? Thanks