Solved

cannot update gridview with calculated column

Posted on 2009-07-10
3
340 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
ID: 24821481
In your objectdatasource what does your UpdateParameters look like ?

Can we see some code..
0
 
LVL 8

Author Comment

by:arcross
ID: 24821548

<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
ID: 24838389
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

Announcing the Most Valuable Experts of 2016

MVEs are more concerned with the satisfaction of those they help than with the considerable points they can earn. They are the types of people you feel privileged to call colleagues. Join us in honoring this amazing group of Experts.

Question has a verified solution.

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

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 …
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…
This Micro Tutorial will teach you how to censor certain areas of your screen. The example in this video will show a little boy's face being blurred. This will be demonstrated using Adobe Premiere Pro CS6.
Finds all prime numbers in a range requested and places them in a public primes() array. I've demostrated a template size of 30 (2 * 3 * 5) but larger templates can be built such 210  (2 * 3 * 5 * 7) or 2310  (2 * 3 * 5 * 7 * 11). The larger templa…

825 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