Solved

Issue assigning a session variable to a sqldatasource

Posted on 2007-12-03
5
900 Views
Last Modified: 2008-02-01
I have a sqldatasource that is running an update statement. The update statment calls a sproc that updates the table. I have a 'LastModifiedBy' column in the table. I set a session variable  (userid) to what I want to go into the this column in the page_load event to make sure it's being set. I setup the sqldatasource's parameters to use that session variable to send to the proc to populate the 'LastModifiedBy' column but it never gets sent. If I hardcode the variable in the proc, everything works fine.

Thoughts?
0
Comment
Question by:KBSLPDev
  • 2
5 Comments
 
LVL 40

Expert Comment

by:evilrix
ID: 20399623
Are you sure the session variable exists at the point you use it? Do you check it for null to be use? Posting your code might be useful.
0
 

Author Comment

by:KBSLPDev
ID: 20399992
Pretty sure. However, since it's done declaratively, it's difficult to troubleshoot. Attached is the code. There is more but I think it's irrelavent. There is a 3rd party grid (infragistics) that invokes the update method. I do know the update method is being invoked so it should be out of the grid's hands at that point.
<asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:ConnectionString %>"
        DeleteCommand="k_sp_Rules_D" DeleteCommandType="StoredProcedure" InsertCommand="k_sp_Rules_I"
        InsertCommandType="StoredProcedure" SelectCommand="k_sp_Rules_R" SelectCommandType="StoredProcedure"
        UpdateCommand="k_sp_Rules_U" UpdateCommandType="StoredProcedure" OnDeleted="SqlDataSource1_Deleted" OnUpdated="SqlDataSource1_Updated" OnUpdating="SqlDataSource1_Updating" OnInserted="SqlDataSource1_Inserted" OnInserting="SqlDataSource1_Inserting">
        <DeleteParameters>
            <asp:Parameter Name="product_rules_id" Type="Int32" />
            <asp:Parameter Name="original_product_rules_id" Type="Int32" />
        </DeleteParameters>
        <UpdateParameters>
            <asp:Parameter Direction="ReturnValue" Name="RETURN_VALUE" Type="Int32" />
            <asp:Parameter Name="product_rules_id" Type="Int32" />
            <asp:Parameter Name="original_product_rules_id" Type="Int32" />
            <asp:Parameter Name="supplier_im_id" Type="String" DefaultValue="" />
            <asp:Parameter Name="product_id" Type="String" />
            <asp:Parameter Name="company_id" Type="Int32" />
            <asp:Parameter Name="effective_date" Type="DateTime" />
            <asp:Parameter Name="base_cost" Type="Double" />
            <asp:Parameter Name="capability_support_cost" Type="Double" />
            <asp:Parameter Name="service_cost" Type="Double" />
            <asp:Parameter Name="cc_im" Type="String" />
            <asp:Parameter Name="cc_pct" Type="Double" />
            <asp:Parameter Name="qh_im" Type="String" />
            <asp:Parameter Name="qh_margin" Type="Double" />
            <asp:Parameter Name="qh_pct" Type="Double" />
            <asp:Parameter Name="active" Type="Boolean" />
            <asp:Parameter Name="unit_type" Type="String" />
            <asp:SessionParameter ConvertEmptyStringToNull="False" DefaultValue="" Name="LastModBy"
                SessionField="UserID" Size="15" Type="String" />
        </UpdateParameters>
        <InsertParameters>
            <asp:Parameter Name="supplier_im_id" Type="String" />
            <asp:Parameter Name="product_id" Type="String" />
            <asp:Parameter Name="company_id" Type="Int32" />
            <asp:Parameter Name="effective_date" Type="DateTime" />
            <asp:Parameter Name="base_cost" Type="Double" />
            <asp:Parameter Name="capability_support_cost" Type="Double" />
            <asp:Parameter Name="service_cost" Type="Double" />
            <asp:Parameter Name="cc_im" Type="String" />
            <asp:Parameter Name="cc_pct" Type="Double" />
            <asp:Parameter Name="qh_im" Type="String" />
            <asp:Parameter Name="qh_margin" Type="Double" />
            <asp:Parameter Name="qh_pct" Type="Double" />
            <asp:Parameter Name="active" Type="Boolean" />
            <asp:Parameter Name="unit_type" Type="String" />
            <asp:SessionParameter Name="LastModBy" SessionField="UserID" Type="String" />
        </InsertParameters>
        <SelectParameters>
            <asp:ControlParameter ControlID="txtDate" Name="dtEffectiveDate" PropertyName="Text"
                Type="DateTime" />
        </SelectParameters>
    </asp:SqlDataSource>
 
 
 
In code: 
    string pagename = "frmRule";
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            try
            {
                //fill header, body and footer labels
                GetPageContent(pagename, lblHeader, lblBody, lblFooter);
                txtDate.Text = System.DateTime.Now.ToShortDateString();
                Session["UserID"] = "test userid";
                
            }
            catch (Exception exp)
            {
                HandleError(exp, pagename, lblResult);
            }
        }
}

Open in new window

0
 

Author Comment

by:KBSLPDev
ID: 20404433
Found that if I changed one of the parameter's value in the grid's UpdateRow method to be what I wanted rather than the Update parameter value definition of the sqldatasource, the problem was corrected.

    protected void UltraWebGrid1_UpdateRow(object sender, RowEventArgs e)
    {
        //set the last mod by to be the user id
        e.Row.Cells[15].Value = Session["UserID"].ToString();
    }

Thanks!
0
 
LVL 1

Accepted Solution

by:
Computer101 earned 0 total points
ID: 20592633
PAQed with points refunded (500)

Computer101
EE Admin
0

Featured Post

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
API v SOA 8 40
AJAX ModalPopupExtender will Not Hide in Asp.net 1 36
VB.Net SQL Query 2 Tables Different Databases 3 44
Validation for a field in asp.net 3 12
ASP.Net to Oracle Connectivity Recently I had to develop an ASP.NET application connecting to an Oracle database.As I am doing it first time ,I had to solve several problems. This article will help to such developers  to develop an ASP.NET client…
Performance in games development is paramount: every microsecond counts to be able to do everything in less than 33ms (aiming at 16ms). C# foreach statement is one of the worst performance killers, and here I explain why.
I've attached the XLSM Excel spreadsheet I used in the video and also text files containing the macros used below. https://filedb.experts-exchange.com/incoming/2017/03_w12/1151775/Permutations.txt https://filedb.experts-exchange.com/incoming/201…

749 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