guillermorangel
5/31/2017 - 5:15 PM

sample sql search query join table to compile search results

sample sql search query join table to compile search results

SELECT * FROM ( SELECT DISTINCT q.Id, q.ProjectName, q.QuoteOrderStatusId, qs.Name as 'QuoteOrderStatusName', q.UtcIssueDate , q.UtcCreateDate, q.CustomerServiceRepId, um.FirstName as 'CSRFirstName', um.LastName as 'CSRLastName', q.SalesRepId, q.SoldToAddressId, q.TotalPrice,
            q.QuoteNumber, qc.CustomerNumber, qc.CustomerName, at.*, ct.*, ad.*,
        ROW_NUMBER() OVER ( ORDER BY q.quoteNumber Desc ) as RowNumber
		FROM QuoteOrder q
        LEFT JOIN QuoteOrderCustomer qc ON qc.Id = q.QuoteOrderCustomerId
        LEFT JOIN AccountType at ON at.AccountTypeID = qc.AccountTypeID
        LEFT JOIN CustomerType ct ON ct.CustomerTypeID = qc.CustomerTypeID
        LEFT JOIN Address ad ON ad.AddressID = q.SoldToAddressId
        LEFT JOIN UserMaster um ON um.UserID = q.CustomerServiceRepId
        LEFT JOIN QuoteOrderStatus qs ON qs.Id = q.QuoteOrderStatusId
			WHERE QuoteOrderClassId = 'Q'  AND q.SalesRepId = 2 ) as Quotes1  WHERE RowNumber > 0 and RowNumber <= 30 

        public IPagedListResult<QuoteOrderSummaryEntity> FindMatchingQuotes( QuoteOrderSearchParams args, Page page )
        {
            var parameters = new List<SqlParameter>( );
            var sbSql = new StringBuilder( );

            var where = BuildMachingQuoteWhereClause( args, ref parameters );
            var initialWhereClause = " WHERE QuoteOrderClassId = 'Q' ";

            var totalSql = $" select count( q.Id ) from QuoteOrder q left join QuoteOrderCustomer qc ON qc.Id = q.QuoteOrderCustomerId {initialWhereClause} {where} ";
            var totalParams = parameters.Select( p => new SqlParameter( p.ParameterName, p.Value ) );
            var total = ExecuteScalar<long>( totalSql, totalParams.ToArray( ) );

            // Start with the base SQL. - we're paging, so wrap with ROW_NUMBER select http://www.codeguru.com/csharp/.net/net_data/article.php/c19611/Paging-in-SQL-Server-2005.htm
            sbSql.Append( "SELECT * FROM ( " );

            var sortColumn = SanitizeSortColumn( page.SortField );
            // This join is safe for paging, since there is only a single customer status record per customer
            sbSql.Append( $@"SELECT DISTINCT 
                            q.Id,
                            q.ProjectName,
                            qs.Name as 'QuoteOrderStatusName',
                            q.UtcIssueDate,
                            q.UtcCreateDate,
                            q.CustomerServiceRepId,
                            um.FirstName as 'CSRFirstName',
                            um.LastName as 'CSRLastName',
                            q.SalesRepId,
                            q.SoldToAddressId,
                            q.TotalPrice,
                            q.QuoteNumber,
                            qc.CustomerNumber,
                            qc.CustomerName, at.*, ct.*, ad.*,
                            ROW_NUMBER() OVER ( ORDER BY {sortColumn} {page.Direction} ) as RowNumber
							FROM QuoteOrder q
                            LEFT JOIN QuoteOrderCustomer qc ON qc.Id = q.QuoteOrderCustomerId
                            LEFT JOIN AccountType at ON at.AccountTypeID = qc.AccountTypeID
                            LEFT JOIN CustomerType ct ON ct.CustomerTypeID = qc.CustomerTypeID
                            LEFT JOIN Address ad ON ad.AddressID = q.SoldToAddressId
                            LEFT JOIN UserMaster um ON um.UserID = q.CustomerServiceRepId
                            LEFT JOIN QuoteOrderStatus qs ON qs.Id = q.QuoteOrderStatusId
							" );

            // Add initial where clause.
            sbSql.Append(initialWhereClause);
            sbSql.Append( where );

            // Finish paging wrapper
            sbSql.Append( " ) as Quotes1 " );
            sbSql.Append( " WHERE RowNumber > @PageBegin and RowNumber <= @PageEnd " );
            parameters.Add( new SqlParameter( "PageBegin", page.Skip ) );
            parameters.Add( new SqlParameter( "PageEnd", page.Skip + page.Take ) );

            var pageParams = parameters.Select( p => new SqlParameter( p.ParameterName, p.Value ) );
            var quotes = QueryObjects( sbSql.ToString( ), BuildQuoteOrderSummaryEntity, pageParams.ToArray( ) );

            var result = new PagedListResult<QuoteOrderSummaryEntity>( quotes, total, page );
            return result;
        }

        protected QuoteOrderSummaryEntity BuildQuoteOrderSummaryEntity( SqlDataReader dr )
        {
            var rval = new QuoteOrderSummaryEntity
            {
                Id = dr.GetInt32( "Id" ).Value,
                CustomerName = dr.GetString( "CustomerName" ),
                CustomerNumber = dr.GetString( "CustomerNumber" ),
                ProjectName = dr.GetString( "ProjectName" ),
                CreatedDate = dr.GetDateTime( "utcCreateDate" ),
                QuoteNumber = dr.GetString( "QuoteNumber" ),
                QuoteOrderStatus = new OrderStatus
                {
                    Name = dr.GetString("QuoteOrderStatusName")
                },
            };

            if ( dr.GetByte( "AccountTypeID" ) != null )
            {
                rval.AccountType = new AccountTypeEntity( )
                {
                    AccountTypeID = dr.GetByte( "AccountTypeID" ).Value,
                    AccountTypeDescription = dr.GetString( "AccountTypeDescription" ),
                    IsRequireCustomerNumber = dr.GetBoolean( "IsRequireCustomerNumber" ).Value,
                    Rank = dr.GetByte( "Rank" ).Value
                };
            }

            if( dr.GetString( "CustomerTypeID" ) != null )
            {
                rval.CustomerType = new CustomerTypeEntity
                {
                    CustomerTypeID = dr.GetString( "CustomerTypeID" ),
                    CustomerTypeDescription = dr.GetString( "CustomerTypeDescription" )
                };
            }

            if( dr.GetInt32( "SoldToAddressId" ).HasValue )
            {
                rval.SoldToAddress = new AddressEntity( )
                {
                    AddressID = dr.GetInt32( "AddressID" ).Value,
                    CompanyName = dr.GetString( "CompanyName" ),
                    Address1 = dr.GetString( "Address1" ),
                    Address2 = dr.GetString( "Address2" ),
                    Address3 = dr.GetString( "Address3" ),
                    Address4 = dr.GetString( "Address4" ),
                    City = dr.GetString( "City" ),
                    Region = dr.GetString( "Region" ),
                    PostalCode = dr.GetString( "PostalCode" ),
                    CountryCode = dr.GetString( "CountryCode" ),
                    Phone = dr.GetString( "Phone" ),
                    PhoneExt = dr.GetString( "PhoneExt" ),
                    Fax = dr.GetString( "Fax" ),
                    FaxExt = dr.GetString( "FaxExt" ),
                    Note = dr.GetString( "Note" ),
                    CreateDate = dr.GetDateTime( "CreateDate" ).Value,
                    EditDate =
                        dr.GetDateTime( "EditDate" ).HasValue ? dr.GetDateTime( "EditDate" ).Value : default( DateTime? ),
                    IsShipToAddress = dr.GetBoolean( "IsShipToAddress" ).Value,
                    IsSoldToAddress = dr.GetBoolean( "IsSoldToAddress" ).Value,
                };
            }

            if (dr.GetInt32("CustomerServiceRepId") != null)
            {
                rval.CustomerServiceRep = new UserMaster
                {
                    FirstName = dr.GetString("CSRFirstName"),
                    LastName = dr.GetString("CSRLastName")
                };
            }

            if (dr.GetDateTime("UtcIssueDate") != null)
            {
                rval.QuoteIssuedDate = dr.GetDateTime("UtcIssueDate");
            }

            return rval;
        }