/// <summary>
 /// CodeSmith generated stub method that is called when updating the child <see cref="Budget"/> object.
 /// </summary>
 /// <param name="connection"></param>
 /// <param name="cancel">Value returned from the method indicating whether the object insertion should proceed.</param>
 partial void OnChildUpdating(ApplicationUser applicationUser, BudgetType budgetType, Client client, Home home, SqlConnection connection, ref bool cancel, SqlTransaction trans);
        public void Child_Update(ApplicationUser applicationUser, Client client, Home home, SqlConnection connection, SqlTransaction trans)
        {
            bool cancel = false;

            OnChildUpdating(applicationUser, client, home, connection, ref cancel, trans);
            if (cancel)
            {
                return;
            }

            if (connection.State != ConnectionState.Open)
            {
                connection.Open();
            }
            using (var command = new SqlCommand("[dbo].[spCFM_HomeClient_Update]", connection, trans))
            {
                command.CommandType = CommandType.StoredProcedure;

                command.Parameters.AddWithValue("@p_HomeClientID", this.HomeClientID);
                command.Parameters.AddWithValue("@p_HomeID", home != null ? home.HomeID : this.HomeID);
                command.Parameters.AddWithValue("@p_ClientID", client != null ? client.ClientID : this.ClientID);
                command.Parameters.AddWithValue("@p_EntryDate", this.EntryDate);
                command.Parameters.AddWithValue("@p_ExitDate", ADOHelper.NullCheck(this.ExitDate));
                command.Parameters.AddWithValue("@p_IsActive", this.IsActive);
                command.Parameters.AddWithValue("@p_CreatedBy", applicationUser != null ? applicationUser.ApplicationUserID : this.CreatedBy);
                command.Parameters.AddWithValue("@p_CreatedOn", this.CreatedOn);
                command.Parameters.AddWithValue("@p_UpdatedBy", ADOHelper.NullCheck(applicationUser != null ? applicationUser.ApplicationUserID : this.UpdatedBy));
                command.Parameters.AddWithValue("@p_UpdatedOn", ADOHelper.NullCheck(this.UpdatedOn));

                //result: The number of rows changed, inserted, or deleted. -1 for select statements; 0 if no rows were affected, or the statement failed.
                int result = command.ExecuteNonQuery();
                if (result == 0)
                {
                    throw new DBConcurrencyException("The entity is out of date on the client. Please update the entity and try again. This could also be thrown if the sql statement failed to execute.");
                }

                // Update foreign keys values. This code will update the values passed in from the parent only if no errors occurred after executing the query.
                if (home != null && home.HomeID != this.HomeID)
                {
                    _homeIDProperty = home.HomeID;
                }

                // Update foreign keys values. This code will update the values passed in from the parent only if no errors occurred after executing the query.
                if (client != null && client.ClientID != this.ClientID)
                {
                    _clientIDProperty = client.ClientID;
                }

                // Update foreign keys values. This code will update the values passed in from the parent only if no errors occurred after executing the query.
                if (applicationUser != null && applicationUser.ApplicationUserID != this.CreatedBy)
                {
                    _createdByProperty = applicationUser.ApplicationUserID;
                }

                // Update foreign keys values. This code will update the values passed in from the parent only if no errors occurred after executing the query.
                if (applicationUser != null && applicationUser.ApplicationUserID != this.UpdatedBy)
                {
                    _updatedByProperty = applicationUser.ApplicationUserID;
                }
            }

            // A child relationship exists on this Business Object but its type is not a child type (E.G. EditableChild).
            // TODO: Please override OnChildUpdated() and update this child manually.
            // UpdateChildren(this, null, connection);

            OnChildUpdated();
        }
 public void Child_Update(Home home, SqlConnection connection, SqlTransaction trans)
 {
     Child_Update(null, null, home, connection, trans);
 }
        public void Child_Insert(ApplicationUser applicationUser, Client client, Home home, SqlConnection connection, SqlTransaction trans)
        {
            bool cancel = false;

            OnChildInserting(applicationUser, client, home, connection, ref cancel, trans);
            if (cancel)
            {
                return;
            }

            if (connection.State != ConnectionState.Open)
            {
                connection.Open();
            }
            using (var command = new SqlCommand("[dbo].[spCFM_HomeClient_Insert]", connection, trans))
            {
                command.CommandType = CommandType.StoredProcedure;

                command.Parameters.AddWithValue("@p_HomeClientID", this.HomeClientID);
                command.Parameters["@p_HomeClientID"].Direction = ParameterDirection.Output;
                command.Parameters.AddWithValue("@p_HomeID", home != null ? home.HomeID : this.HomeID);
                command.Parameters.AddWithValue("@p_ClientID", client != null ? client.ClientID : this.ClientID);
                command.Parameters.AddWithValue("@p_EntryDate", this.EntryDate);
                command.Parameters.AddWithValue("@p_ExitDate", ADOHelper.NullCheck(this.ExitDate));
                command.Parameters.AddWithValue("@p_IsActive", this.IsActive);
                command.Parameters.AddWithValue("@p_CreatedBy", applicationUser != null ? applicationUser.ApplicationUserID : this.CreatedBy);
                command.Parameters.AddWithValue("@p_CreatedOn", this.CreatedOn);
                command.Parameters.AddWithValue("@p_UpdatedBy", ADOHelper.NullCheck(applicationUser != null ? applicationUser.ApplicationUserID : this.UpdatedBy));
                command.Parameters.AddWithValue("@p_UpdatedOn", ADOHelper.NullCheck(this.UpdatedOn));

                command.ExecuteNonQuery();

                // Update identity primary key value.
                _homeClientIDProperty = (System.Int32)command.Parameters["@p_HomeClientID"].Value;

                // Update foreign keys values. This code will update the values passed in from the parent only if no errors occurred after executing the query.
                if (home != null && home.HomeID != this.HomeID)
                {
                    _homeIDProperty = home.HomeID;
                }

                // Update foreign keys values. This code will update the values passed in from the parent only if no errors occurred after executing the query.
                if (client != null && client.ClientID != this.ClientID)
                {
                    _clientIDProperty = client.ClientID;
                }

                // Update foreign keys values. This code will update the values passed in from the parent only if no errors occurred after executing the query.
                if (applicationUser != null && applicationUser.ApplicationUserID != this.CreatedBy)
                {
                    _createdByProperty = applicationUser.ApplicationUserID;
                }

                // Update foreign keys values. This code will update the values passed in from the parent only if no errors occurred after executing the query.
                if (applicationUser != null && applicationUser.ApplicationUserID != this.UpdatedBy)
                {
                    _updatedByProperty = applicationUser.ApplicationUserID;
                }
            }

            // A child relationship exists on this Business Object but its type is not a child type (E.G. EditableChild).
            // TODO: Please override OnChildInserted() and insert this child manually.
            // UpdateChildren(this, null, connection);

            OnChildInserted();
        }
 public void Child_Insert(Home home, SqlConnection connection, SqlTransaction trans)
 {
     Child_Insert(null, null, home, connection, trans);
 }
        /// <summary>
        /// Creates a new object of type <see cref="Home"/>.
        /// </summary>
        /// <returns>Returns a newly instantiated collection of type <see cref="Home"/>.</returns>
        public static Home NewHome()
        {
            Home obj = new Home();

            return(obj);
        }