Solved

cannot update gridview with calculated column

Posted on 2009-07-10
3
338 Views
Last Modified: 2012-05-07
Hi,
ive got a table with these columns
ID,jobid,description,StartTIme and EndTime.

Then I created a stored procedure to return these fields + a calculated column to display the difference in hours from the StartTime and EndTime columns. This column is called TotalHrs.

In my objectdatasource, in the select list, i ve choosen this stored procedure. And in the UPDATE list i selected a stored procedure, that i created, to update those fields ( In the update procedure doesnt appear the column TotalHrs)

Now, the grid it is showing me the correct data with the difference in hours but when i try to update the record it says.( In this grid I added a template field to show the total hours bound to the stored procedure field TotalHrs)

"ObjectDataSource 'ods_timesheet' could not find a non-generic method 'spUpdateTimeSheet' that has parameters: JobID, Description, StartTime, EndTime, original_ID, totalhrs"

If i remove the template field 'TotalHrs' it updates fine.

any thoughts?

0
Comment
Question by:arcross
  • 2
3 Comments
 
LVL 13

Expert Comment

by:crazyman
Comment Utility
In your objectdatasource what does your UpdateParameters look like ?

Can we see some code..
0
 
LVL 8

Author Comment

by:arcross
Comment Utility

<asp:ObjectDataSource ID="ods_TimeSheet" runat="server" 

                OldValuesParameterFormatString="original_{0}" SelectMethod="GetTimeSheetByDate" 

                TypeName="lstcTableAdapters.TimesheetTableAdapter" 

                InsertMethod="spInsertTimeSheet" UpdateMethod="spUpdateTimeSheet"

                >

                <UpdateParameters>

                    <asp:Parameter Name="JobID" Type="Int32" />

                    <asp:Parameter Name="Description" Type="String" />

                    <asp:Parameter Name="StartTime" Type="DateTime" />

                    <asp:Parameter Name="EndTime" Type="DateTime" />

                    <asp:Parameter Name="original_ID" Type="Int32" />

                </UpdateParameters>

                <SelectParameters>

                  

                     <asp:ControlParameter ControlID="txt_date" PropertyName="Text" Name="mytime" 

                         Type="DateTime" />
 

                </SelectParameters>

                <InsertParameters>

                    <asp:Parameter Name="JobID" Type="Int32" />

                    <asp:Parameter Name="Description" Type="String" />

                    <asp:Parameter Name="StartTime" Type="DateTime" />

                    <asp:Parameter Name="EndTime" Type="DateTime" />

                </InsertParameters>

                </asp:ObjectDataSource>

Open in new window

0
 
LVL 8

Accepted Solution

by:
arcross earned 0 total points
Comment Utility
i found the answer.

I went back to the XSD file I added an extra column, in this case TOTALHRS.
Then i refreshed my objectdatasource to make the field 'TotalHrs' appear in the bound field list. SO after this, i made it Readonly = true and that worked.
0

Featured Post

How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

Join & Write a Comment

In an ASP.NET application, I faced some technical problems. In this article, I list them out and show the solutions that I found.  I hope it will be useful. Problem: After closing a pop-up window, the parent page should be refreshed automaticall…
A quick way to get a menu to work on our website, is using the Menu control and assign it to a web.sitemap using SiteMapDataSource. Example of web.sitemap file: (CODE) Sample code to add to the page menu: (CODE) Running the application, we wi…
It is a freely distributed piece of software for such tasks as photo retouching, image composition and image authoring. It works on many operating systems, in many languages.
This video shows how to remove a single email address from the Outlook 2010 Auto Suggestion memory. NOTE: For Outlook 2016 and 2013 perform the exact same steps. Open a new email: Click the New email button in Outlook. Start typing the address: …

771 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

Need Help in Real-Time?

Connect with top rated Experts

8 Experts available now in Live!

Get 1:1 Help Now