Danish Habib

Danish Habib

  • NA
  • 694
  • 245.5k

Relational insertion into the tables

Apr 13 2015 4:32 AM
I have related data (relational database) cascade in nature and i want to save that data the basic structure of the data is like that 
I have district(on first level) , these districts populates Tehsils(second level) , These tehsils populates UCs(third Level) and These Ucs populates villages this has been done now i want to save a record against a user the business rules are like that 
One user can have one or more districts, Many or no Tehsil, Many or no UCs, Many or no villages, the probibility of insertion is that the user can have More villages but uc and tehsil and district count does not go beyond the 20 but villages can have 280 for one user .


I have created four tables 
District(districtId(P),Name)
TEhsil(TehsilID(P),Name,DistrictID(F))
UCS(UCID(P),Name,TEHSILID(F))
Villages(VIllageID(P),Name,UCID(F))
P ---->primary key
F----->Foreign key 

Now i Know that the district can have one to twenty rows so on save function i am simple using the loop and same for tehsil but for ucs and villages i am using table value parameter still it takes 1-2 minutes to save 80 villages ?why it is so and secondly let us an example if I am saving the Villages (for every village ID I pass that ID to a function which fetch the UCID of that Villlage and save(as forign key) may b this method is taking much time or what else .
and mean while I am using four function each one creating its own connection and then close 


below is the code sample ...
Private Sub btnSave_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles btnSave.Click

        If Not Page.IsValid Then Return

        Dim blnIsUpdate As Boolean = False

        Dim hasedBytes As Byte()
        Dim strPassword As String = String.Empty
        Dim md5Hasher As New MD5CryptoServiceProvider()

        If Not litUserId.Text.Trim().Length.Equals(0) Then blnIsUpdate = True

        Dim cnnContact As New SqlConnection(AppSettings("DbSqlPortal"))
        Dim cmdContact As New SqlCommand("spAdminSaveUsers", cnnContact)

        Dim IDs As Integer = Nothing
        Dim trnContact As SqlTransaction = Nothing

        cmdContact.CommandType = CommandType.StoredProcedure

        hasedBytes = md5Hasher.ComputeHash(New UTF8Encoding().GetBytes((txtPassword.Text.Trim() & txtEmail.Text.Trim())))
        GetDistrictID()



        'If GetDistrictId() > 0 Then
        '    DisplayMessage(Me.Master.MessageBox, "A User with same District and Same user role  already exists.", "Record Exists", MessageBoxTypes.Warning)
        'Else


        Try
            With cmdContact.Parameters

                If blnIsUpdate Then

                    .Add("@UserId", SqlDbType.BigInt).Value = CInt(litUserId.Text.Trim())

                Else

                    .Add("@UserId", SqlDbType.BigInt).Value = DBNull.Value

                End If

                .Add("@FullName", SqlDbType.NVarChar).Value = txtFullName.Text.Trim()
                .Add("@Email", SqlDbType.NVarChar).Value = txtEmail.Text.Trim()
                .Add("@Password", SqlDbType.VarChar).Value = base64Encode(txtPassword.Text)

                'txtPassword.Text.Trim()
                'Convert.ToBase64String(hasedBytes)

                .Add("@SecurityQuestion", SqlDbType.VarChar).Value = ddlSecurityQuestions.SelectedItem.Text
                .Add("@SecurityAnswer", SqlDbType.VarChar).Value = txtAnswer.Text.Trim()
                .Add("@UserTypes", SqlDbType.TinyInt).Value = ddlUserTypes.SelectedValue
                .Add("@IsActive", SqlDbType.Bit).Value = chkActive.Checked

                .Add("@DistrictId", SqlDbType.TinyInt).Value = CheckBoxList1.SelectedValue

                .Add("@IsAdmin", SqlDbType.Bit).Value = chkAdmin.Checked

                .Add("@IPAddress", SqlDbType.VarChar).Value = Request.UserHostAddress
                .Add("@Result", SqlDbType.Char, 1).Direction = ParameterDirection.Output
                .Add("@ReturnId", SqlDbType.BigInt).Direction = ParameterDirection.Output



                If ChkIsReportAble.Checked = False Then
                    .Add("@IsReportable", SqlDbType.Bit).Value = False
                Else
                    .Add("@IsReportable", SqlDbType.Bit).Value = ChkIsReportAble.Checked
                End If
                If ChkIsReportAble.Checked Then
                    .Add("@ReporintPerson", SqlDbType.TinyInt).Value = CInt(ddlReporintUser.SelectedValue)

                Else
                    .Add("@ReporintPerson", SqlDbType.TinyInt).Value = DBNull.Value
                End If
            End With

            cnnContact.Open()
            trnContact = cnnContact.BeginTransaction()
            'GetDistrictId()
            'If GetDistrictId() > 0 Then
            '    DisplayMessage(Me.Master.MessageBox, "A User with same District and Same user role  already exists.", "Record Exists", MessageBoxTypes.Warning)
            'Else

            cmdContact.Transaction = trnContact
            cmdContact.ExecuteNonQuery()
            If ddlUserTypes.SelectedValue = "6" Then
                If CChar(cmdContact.Parameters("@Result").Value).Equals("E"c) Or (CChar(cmdContact.Parameters("@Result").Value).Equals("E"c) Or GetDistrictID()) > 0 Then
                    '   Msg.Text = "The Record has been Successfully Submitted !"
                    DisplayMessage(Me.Master.MessageBox, "A User with same District and role  already exists.", "Record Exists", MessageBoxTypes.Warning)
                    'MessageBoxShow(Page, "This Record Exists Try with some other record!")
                    litUserId.Text = String.Empty
                    Return


                End If
            End If
            If CChar(cmdContact.Parameters("@Result").Value).Equals("E"c) Then
                '   Msg.Text = "The Record has been Successfully Submitted !"
                DisplayMessage(Me.Master.MessageBox, "A User with same Email already exists.", "Record Exists", MessageBoxTypes.Warning)
                'MessageBoxShow(Page, "This Record Exists Try with some other record!")
                litUserId.Text = String.Empty
                Return
            End If

            trnContact.Commit()
            litUserId.Text = (cmdContact.Parameters("@ReturnId").Value)
            cnnContact.Close()
            ' SearchUsers()

            If blnIsUpdate Then
                '  spAdminDeleletUserAssociationNews()
                'Dim cmdsDistrict As New SqlCommand("spAdminDeleletUserAssociation", cnnContact)
                Dim cmdsDistrict As New SqlCommand("spAdminDeleletUserAssociationNews", cnnContact)
                cmdsDistrict.CommandType = CommandType.StoredProcedure
                Try
                    With cmdsDistrict.Parameters
                        .Add("@UserId", SqlDbType.TinyInt).Value = litUserId.Text
                        .Add("@Result", SqlDbType.Char, 1).Direction = ParameterDirection.Output

                    End With

                    cnnContact.Open()
                    trnContact = cnnContact.BeginTransaction()
                    cmdsDistrict.Transaction = trnContact
                    'GetDistrictId()

                    cmdsDistrict.ExecuteNonQuery()
                    trnContact.Commit()


                    cnnContact.Close()
                Catch ex As Exception

                End Try
                'Dim cmd3 As New SqlCommand("Delete from UserAndDistricts Where UserId=@Userid,Delete from UserDistricts Where UserID=@Userid", cnnContact)
                'cmd3.CommandType = CommandType.Text
                'cmd3.Parameters.AddWithValue("@UserId", litUserId.Text)
                'cnnContact.Open()
                'cmd3.ExecuteNonQuery()
                'cnnContact.Close()
                'Dim cmd2 As New SqlCommand("shiftDistrictsAndSUsers", cnnContact)
                'cmd2.CommandType = CommandType.StoredProcedure
                'cmd2.Parameters.AddWithValue("@UserId", litUserId.Text)
                'cnnContact.Open()
                'cmd2.ExecuteNonQuery()


                'cnnContact.Close()
            End If
            'GetListBoxSelStringInComma(CheckBoxList1)
            Bulkinsert()
            'Dim i As Integer = 0
            'Do While (i < CheckBoxList1.Items.Count)
            '    If CheckBoxList1.Items(i).Selected Then

            '        Dim cmdDistrict As New SqlCommand("UserDistrictsss", cnnContact)
            '        cmdDistrict.CommandType = CommandType.StoredProcedure


            '        With cmdDistrict.Parameters

            '            .Add("@DistrictId", SqlDbType.BigInt).Value = CInt(CheckBoxList1.Items(i).Value)
            '            ' .Add("@DistrictId", SqlDbType.NVarChar).Value = GetListBoxSelStringInComma(CheckBoxList1).ToString()
            '            'If CheckBoxList2.Items(i).Selected = False Then
            '            '    .Add("@TehsilId", SqlDbType.BigInt).Value = 0
            '            'End If
            '            ' .Add("@TehsilId", SqlDbType.BigInt).Value = CInt(CheckBoxList2.Items(i).Value)
            '            .Add("UserId", SqlDbType.TinyInt).Value = litUserId.Text
            '            .Add("@DistrictName", SqlDbType.NVarChar).Value = CheckBoxList1.Items(i).Text
            '            .Add("@Result", SqlDbType.Char, 1).Direction = ParameterDirection.Output
            '            .Add("@ReturnId", SqlDbType.BigInt).Direction = ParameterDirection.Output
            '        End With
            '        cnnContact.Open()
            '        trnContact = cnnContact.BeginTransaction()
            '        cmdDistrict.Transaction = trnContact
            '        cmdDistrict.ExecuteNonQuery()
            '        If CChar(cmdContact.Parameters("@Result").Value).Equals("E"c) Then
            '            '   Msg.Text = "The Record has been Successfully Submitted !"
            '            DisplayMessage(Me.Master.MessageBox, "A User with same District already exists.", "Record Exists", MessageBoxTypes.Warning)
            '            'MessageBoxShow(Page, "This Record Exists Try with some other record!")
            '            litUserId.Text = String.Empty
            '            Return
            '        End If
            '        trnContact.Commit()
            '        cnnContact.Close()

            '    End If

            '    i = (i + 1)
            'Loop


            Dim j As Integer = 0


            Do While (j < CheckBoxList2.Items.Count)
                If CheckBoxList2.Items(j).Selected Then



                    Dim cmdsDistrict As New SqlCommand("UserTehsilss", cnnContact)
                    cmdsDistrict.CommandType = CommandType.StoredProcedure




                    With cmdsDistrict.Parameters



                        .Add("@TehsilId", SqlDbType.BigInt).Value = CInt(CheckBoxList2.Items(j).Value)
                        hdnThil = CInt(CheckBoxList2.Items(j).Value)
                        'GetDistrictIds(CheckBoxList2.Items(j).Value)
                        ' .Add("@DistrictID", SqlDbType.Int).Value = GetDistrictIds(CheckBoxList2.Items(j).Value)
                        .Add("@DistrictID", SqlDbType.Int).Value = 1
                        'GetListBoxSelStringInCommaTehsil(CheckBoxList2)
                        'CInt(CheckBoxList2.Items(j).Value)
                        .Add("UserId", SqlDbType.TinyInt).Value = litUserId.Text

                        .Add("@tehsilName", SqlDbType.NVarChar).Value = CheckBoxList2.Items(j).Text
                        .Add("@Result", SqlDbType.Char, 1).Direction = ParameterDirection.Output
                        .Add("@ReturnId", SqlDbType.BigInt).Direction = ParameterDirection.Output
                        '.Add("@DistrictID", SqlDbType.BigInt).Value = CInt(CheckBoxList1.Items(i).Value)
                    End With
                    cnnContact.Open()
                    trnContact = cnnContact.BeginTransaction()
                    cmdsDistrict.Transaction = trnContact
                    'GetDistrictId()

                    cmdsDistrict.ExecuteNonQuery()
                    If CChar(cmdContact.Parameters("@Result").Value).Equals("E"c) Then
                        '   Msg.Text = "The Record has been Successfully Submitted !"
                        DisplayMessage(Me.Master.MessageBox, "A User with same Tehsil already exists.", "Record Exists", MessageBoxTypes.Warning)
                        'MessageBoxShow(Page, "This Record Exists Try with some other record!")
                        litUserId.Text = String.Empty
                        Return
                    End If
                    trnContact.Commit()


                    cnnContact.Close()
                End If
                j = (j + 1)
            Loop









            Dim k As Integer = 0


            Do While (k < CheckBoxList3.Items.Count)
                If CheckBoxList3.Items(k).Selected Then

                    Dim cmdsDistrictd As New SqlCommand("UserUCss", cnnContact)
                    cmdsDistrictd.CommandType = CommandType.StoredProcedure
                    Try

                        With cmdsDistrictd.Parameters


                            .Add("@UcId", SqlDbType.BigInt).Value = CInt(CheckBoxList3.Items(k).Value)
                            hdnUC = CInt(CheckBoxList3.Items(k).Value)
                            '  .Add("@TehsilId", SqlDbType.BigInt).Value = GetTehsilIDIds(CheckBoxList3.Items(k).Value)
                            .Add("@TehsilId", SqlDbType.BigInt).Value = 13
                            .Add("@UserId", SqlDbType.BigInt).Value = litUserId.Text
                            .Add("@UCName", SqlDbType.NVarChar).Value = CheckBoxList3.Items(k).Text
                            .Add("@Result", SqlDbType.Char, 1).Direction = ParameterDirection.Output
                            .Add("@ReturnId", SqlDbType.BigInt).Direction = ParameterDirection.Output
                            '.Add("@DistrictID", SqlDbType.BigInt).Value = CInt(CheckBoxList1.Items(i).Value)
                        End With
                        cnnContact.Open()
                        trnContact = cnnContact.BeginTransaction()
                        cmdsDistrictd.Transaction = trnContact
                        cmdsDistrictd.ExecuteNonQuery()
                        trnContact.Commit()


                        cnnContact.Close()


                    Catch ex As Exception



                    End Try



                End If
                k = k + 1
            Loop
            BulkinsertVillages()
            'Dim L As Integer = 0
            'Do While (L < CheckBoxList4.Items.Count)
            '    If CheckBoxList4.Items(L).Selected Then

            '        Dim cmdsDistrict As New SqlCommand("UserVillagess", cnnContact)
            '        cmdsDistrict.CommandType = CommandType.StoredProcedure
            '        Try

            '            With cmdsDistrict.Parameters


            '                .Add("@villageId", SqlDbType.BigInt).Value = CInt(CheckBoxList4.Items(L).Value)
            '                hdnVillage = CInt(CheckBoxList4.Items(L).Value)
            '                .Add("@UcUD", SqlDbType.BigInt).Value = GetUCIDIds(CheckBoxList4.Items(L).Value)


            '                .Add("UserId", SqlDbType.TinyInt).Value = litUserId.Text
            '                .Add("@VillageName", SqlDbType.NVarChar).Value = CheckBoxList4.Items(L).Text
            '                .Add("@Result", SqlDbType.Char, 1).Direction = ParameterDirection.Output
            '                .Add("@ReturnId", SqlDbType.BigInt).Direction = ParameterDirection.Output
            '                '.Add("@DistrictID", SqlDbType.BigInt).Value = CInt(CheckBoxList1.Items(i).Value)
            '            End With
            '            cnnContact.Open()
            '            trnContact = cnnContact.BeginTransaction()
            '            cmdsDistrict.Transaction = trnContact
            '            cmdsDistrict.ExecuteNonQuery()
            '            trnContact.Commit()


            '            cnnContact.Close()


            '        Catch ex As Exception



            '        End Try



            '    End If

            '    L = (L + 1)
            'Loop





            '    Catch ex As Exception

            'End Try






            cnnContact.Close()
            Dim strMessage As String = "A new User has successfully been created and saved."
            If blnIsUpdate Then strMessage = "The selected User has successfully been updated and saved."
            'lblMesssages.InnerText = "Welcome"
            DisplayMessage(Me.Master.MessageBox, strMessage, "User Saved Successfully", MessageBoxTypes.Success)
            SendMAilMessage()

            MVSearch.ActiveViewIndex = 0
            SearchUsers()
            'DisplayInitialPage()
        Catch ex As Exception

            If trnContact IsNot Nothing Then trnContact.Rollback()

            DisplayMessage(Me.Master.MessageBox, "An unexpected error occurred while saving the Record. Please retry.", "Record Not Saved", MessageBoxTypes.Error)

        Finally
            DisposeDataObjects(, , cmdContact, cnnContact)

        End Try

        ' End If

    End Sub