Reviews of the best new books, and previews of dozens of books publishing soon

What's New

Publishing Soon

  • The Pirate Queen
    Ariel Lawhon
    Published 9/8/26

    From the New York Times bestselling author of The Frozen River and I Was Anastasia, a thrilling historical adventure inspired by the life of Grace O'Malley, an infamous Irish ...
  • Robert B. Parker's Booked (Sunny Randall)
    Alison Gaylin
    Published 12/23/26

    Boston PI Sunny Randall investigates a popular book critic on a mean streak ... only for her to wind up dead, in the latest thriller in Robert B. Parker's bestselling series.

First Impressions: Readers Recommend

Latest "Beyond the Book" Articles

  • Saint Thomas Christians
    Beyond the book article for The Covenant of Water
    One of the overarching themes in Abraham Verghese's The Covenant of Water is faith, in all its various guises. For the character Big Ammachi and her family, it is their proud history as Saint Thomas Christians that sustains them in their bleakest hours.

    The novel refers to the legend of Saint ...
  • The Sociological Work of Pierre Bourdieu
    Beyond the book article for Change
    In addition to being a novelist, Édouard Louis, author of Change, is a scholar of the French sociologist Pierre Bourdieu. Louis's scholarly work has explicitly informed his novels, which are about the violence and indignity of poverty, the racism and homophobia of his working-class childhood, ...
  • Chernozem: The National Soil of Ukraine
    Beyond the book article for Endling
    In Endling, Maria Reva centers Ukrainian identity, whether her focus is on romance tours or the snail conservation efforts of one of the central 'brides' named Yeva. Through Yeva's work, we learn about the topography and life forms that shape Ukraine. One detail that stuck with me was the discussion...

New in Hardcover

New in Paperback

  • A Gentleman and a Thief
    Dean Jobb
    Published 5/1/26

    In this captivating Jazz Age true crime about "the greatest jewel thief who ever lived" (Life Magazine), Arthur Barry, who charmed celebrities and millionaires while ...

Your guide toexceptional          books

BookBrowse seeks out and recommends the best in contemporary fiction and nonfiction—books that not only engage and entertain but also deepen our understanding of ourselves and the world around us.

 


Debugging Information
ColdFusion Server Developer 2021,0,13,330286
Template /current_books/index.cfm
Time Stamp 31-May-26 06:31 PM
Locale en
User Agent Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)
Remote IP 127.0.0.1
Host Name 127.0.0.1


Execution Time

Total Time Avg Time Count Template
1780252302024 ms 1.78025230202E+012 ms 1 /root/website/app_server.cfm
330 ms 330 ms 1 /root/website/current_books/index.cfm
260 ms 260 ms 1 /root/website/current_books/dsp_main.cfm
52 ms 52 ms 1 /root/website/app_globals.cfm
21 ms 21 ms 1 /root/website/queries/qry_get_books_publishing_this_week.cfm
19 ms 19 ms 1 /root/website/queries/qry_get_active_obc.cfm
17 ms 17 ms 1 /root/website/app_layout.cfm
13 ms 13 ms 1 /root/website/site/blocks/layout/dsp_footer.cfm
11 ms 11 ms 1 /root/website/adsystem/adsystem_mod.cfm
11 ms 11 ms 1 /root/website/adzones/showcase_track.cfm
9 ms 9 ms 1 /root/website/queries/qry_get_current_competition.cfm
4 ms 4 ms 1 /root/website/actions/adstatus.cfm
4 ms 4 ms 1 /root/website/queries/qry_get_current_wordplay.cfm
4 ms 4 ms 1 CFC[ /root/website/cfcs/homepage.cfc | books(maxrows = 10, category_number = 61) ] from /root/website/cfcs/homepage.cfc
3 ms 3 ms 1 /root/website/act_check_login.cfm
3 ms 2 ms 2 /root/website/actions/act_spider_tracker.cfm
3 ms 2 ms 2 /root/website/queries/qry_get_member_info.cfm
3 ms 3 ms 1 CFC[ /root/website/cfcs/homepage.cfc | books(maxrows = 10, category_number = 60) ] from /root/website/cfcs/homepage.cfc
2 ms 2 ms 1 /root/website/queries/qry_get_books_by_special_category_new_in_paperback.cfm
1 ms 1 ms 1 /root/website/act_libraryIPLogin.cfm
1 ms 1 ms 1 /root/website/queries/qry_get_books_by_special_category_new_in_hardcover.cfm
1 ms 1 ms 1 /root/website/queries/qry_get_forthcoming_books.cfm
1 ms 1 ms 1 /root/website/queries/qry_get_previous_arcs_for_ad.cfm
1 ms 1 ms 1 /root/website/site/blocks/layout/dsp_header.cfm
1 ms 1 ms 1 /root/website/site/blocks/layout/head.cfm
0 ms 0 ms 1 /root/website/Application.cfm
0 ms 0 ms 1 /root/website/actions/udfs.cfm
0 ms 0 ms 1 /root/website/articles/btb_udfs.cfm
0 ms 0 ms 1 /root/website/banners/ad_594.cfm
0 ms 0 ms 1 /root/website/formurl2attributes.cfm
0 ms 0 ms 1 /root/website/js/fbjavascriptsdk.cfm
0 ms 0 ms 1 /root/website/queries/qry_get_current_ezine.cfm
0 ms 0 ms 1 /root/website/queries/qry_get_free_newsletters.cfm
0 ms 0 ms 1 /root/website/queries/qry_get_news_for_rss_feed.cfm
0 ms 0 ms 1 /root/website/queries/qry_get_previous_arcs.cfm
0 ms 0 ms 1 /root/website/queries/qry_get_recent_btb.cfm
0 ms 0 ms 1 /root/website/site/blocks/dsp_header_newsletter.cfm
0 ms 0 ms 1 /root/website/site/blocks/email_modal.cfm
0 ms 0 ms 1 /root/website/site/blocks/layout/dsp_bottom_block.cfm
0 ms 0 ms 1 /root/website/site/blocks/layout/google_tags.cfm
0 ms 0 ms 1 /root/website/site/blocks/layout/header_announcement.cfm
0 ms 0 ms 1 /root/website/site/blocks/layout/main_menu.cfm
0 ms 0 ms 1 /root/website/site/blocks/layout/main_search.cfm
1 ms  STARTUP, PARSING, COMPILING, LOADING, & SHUTDOWN
331 ms  TOTAL EXECUTION TIME
red = over 250 ms average execution time


SQL Queries

spidercheck (Datasource=bookbrowse_com_new, Time=1ms, Records=1) in /root/website/actions/act_spider_tracker.cfm @ 18:31:42.042
SELECT	a.bot_number
        FROM	bots a
        WHERE	charindex(a.bot_name, ?) > 0
		OR a.bot_ip = ?
Query Parameter Value(s) -
Parameter #1(cf_sql_varchar) = Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)
Parameter #2(cf_sql_varchar) = 127.0.0.1

get_member_info (Datasource=bookbrowse_com_new, Time=2ms, Records=0) in /root/website/queries/qry_get_member_info.cfm @ 18:31:42.042
select 	a.*, 
    		b.member_account_type_name, b.member_account_type_charge, b.member_account_type_charge_frequency,  b.member_account_type_months, 
            c.member_chargetype_name, c.member_chargetype_number, a.member_classification_number, a.member_book_format
	
    from members a, member_account_types b, member_chargetype c
	
    where a.member_account_type_number = b.member_account_type_number
	and a.payment_method_id = c.member_chargetype_number
	and a.member_number = ?
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 0

adactive (Datasource=bookbrowse_com_new, Time=4ms, Records=2) in /root/website/actions/adstatus.cfm @ 18:31:42.042
SELECT	viewby, section
    FROM	adsystem 
    WHERE	active  = 1 
    AND		start_date <= GETDATE()
    AND 	(viewby = ? OR viewby = 'all')
Query Parameter Value(s) -
Parameter #1(CF_SQL_VARCHAR) = non

get_current_ezine (Datasource=bookbrowse_com_new, Time=0ms, Records=1, Cached Query) in /root/website/queries/qry_get_current_ezine.cfm @ 18:31:42.042
select		top 1 ezine_number, ezine_dt, ezine_image, ezine_brief_description, ezine_introduction
from		ezines
where		ezine_active_flag = 1
and 		ezine_type_number = 4
and			ezine_dt < getdate()
order by 	ezine_dt DESC
get_current_wordplay (Datasource=bookbrowse_com_new, Time=3ms, Records=1) in /root/website/queries/qry_get_current_wordplay.cfm @ 18:31:42.042
SELECT		a.wordplay_number, a.wordplay_dt, a.wordplay_name, a.wordplay_intro_text, b.wordplay_puzzle_number, b.wordplay_puzzle_question
    FROM		wordplays a 
	INNER JOIN	wordplay_puzzle_mapping c on c.wordplay_number = a.wordplay_number
	INNER JOIN	wordplay_puzzles b on b.wordplay_puzzle_number = c.wordplay_puzzle_number
	WHERE		a.wordplay_number = (	select top 1 a.wordplay_number
                                from wordplays a, wordplay_puzzles b, wordplay_puzzle_mapping c
                                where a.wordplay_number = c.wordplay_number
                                and b.wordplay_puzzle_number = c.wordplay_puzzle_number
                                and a.wordplay_dt < getdate()
                                and a.wordplay_expiration_dt > dateadd(day, -1, getdate())
                                order by a.wordplay_dt asc
                                )
get_ComNo (Datasource=bookbrowse_com_new, Time=3ms, Records=0) in /root/website/queries/qry_get_current_competition.cfm @ 18:31:42.042
SELECT 	TOP 1 	x.competition_number, x.bb_briefs_flag
	from			competitions x
	
		WHERE	x.competition_dt <= getdate()
		AND		x.competition_expiration_dt > dateadd(d,-1,getdate())
get_current_competition (Datasource=bookbrowse_com_new, Time=4ms, Records=0) in /root/website/queries/qry_get_current_competition.cfm @ 18:31:42.042
SELECT 	x.competition_number, x.book_number, x.competition_teaser_title, x.competition_teaser_description, x.competition_intro_text, x.competition_expiration_dt, x.bb_briefs_flag, x.competition_full_info_flag, x.competition_type, x.competition_optin,x.competition_optin_text, 
				a.book_title as "title",
				(b.author_first_name + ' ' +  b.author_middle_initial + ' ' + b.author_last_name) as "author",
	            f.edition_publish_dt AS "hardcover_publish_dt", f.edition_jacket_image as "hardcover_jacket_image",
				g.edition_publish_dt AS "paperback_publish_dt", g.edition_jacket_image as "paperback_jacket_image"
	
		FROM 		competitions x
		INNER JOIN	books a on a.book_number = x.book_number
		INNER JOIN	book_author_mapping c on c.book_number = x.book_number
		INNER JOIN	authors b on c.author_number = b.author_number
		LEFT JOIN	editions f on a.book_number = f.book_number and f.edition_paperback_flag = 0
		LEFT JOIN	editions g on a.book_number = g.book_number and g.edition_paperback_flag = 1

		WHERE		x.competition_number = ?
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 0

get_previous_arcs_for_ad (Datasource=bookbrowse_com_new, Time=0ms, Records=0, Cached Query) in /root/website/queries/qry_get_previous_arcs_for_ad.cfm @ 18:31:42.042
SELECT 	a.arc_number,a.arc_client_url,a.arc_active_dt, a.arc_off_ad_dt,
		b.ezine_preview_number, b.ezine_preview_title, b.ezine_preview_subtitle, b.ezine_preview_jacket_image, b.ezine_preview_author, b.ezine_preview_publisher, 
		b.ezine_preview_publish_dt, b.ezine_preview_jacket_desc, b.ezine_preview_number_of_pages, b.ezine_preview_bb_comments, b.ezine_preview_isbn13,
		c.ezine_preview_category_name AS "ezine_preview_category",
		(select count(*) from arc_allocator d where d.arc_number = a.arc_number and arc_allocator_review_approved_flag = 1) as "reviews",
		(select (CAST(AVG(CAST(arc_allocator_review_rating AS numeric(12,0))) AS numeric(12,0)))+
				(CASE WHEN right(CAST(AVG(CAST(arc_allocator_review_rating AS numeric(12,2))) AS numeric(12,2)),2) > 25 AND right(CAST(AVG(CAST(arc_allocator_review_rating AS numeric(12,2))) AS numeric(12,2)),2) < 50 THEN 0.5
				 WHEN right(CAST(AVG(CAST(arc_allocator_review_rating AS numeric(12,2))) AS numeric(12,2)),2) > 50 AND right(CAST(AVG(CAST(arc_allocator_review_rating AS numeric(12,2))) AS numeric(12,2)),2) < 75 THEN -0.5
				 ELSE 0
				 END)
 			from arc_allocator	where arc_number = a.arc_number and arc_allocator_review_approved_flag = 1) AS arcrating,
 			(select (CAST(AVG(CAST(arc_allocator_review_rating AS numeric(12,1))) AS numeric(12,1)))from arc_allocator where arc_number = a.arc_number and arc_allocator_review_approved_flag = 1) AS "decrating"

FROM arcs a
INNER JOIN ezine_previews b ON b.ezine_preview_number = a.ezine_preview_number
INNER JOIN ezine_preview_categories c ON b.ezine_preview_category_number = c.ezine_preview_category_number

WHERE arc_closed_flag = 1
AND arc_obc_flag = 0
AND getdate() >= arc_on_ad_dt
AND getdate() < arc_off_ad_dt

ORDER BY a.arc_on_ad_dt DESC
get_future_obc (Datasource=bookbrowse_com_new, Time=4ms, Records=0) in /root/website/queries/qry_get_active_obc.cfm @ 18:31:42.042
SELECT 		a.arc_forumidfk, a.discourse_flag, a.arc_promo_text, arc_on_ad_dt,
				b.ezine_preview_number, b.ezine_preview_title, b.ezine_preview_subtitle, b.ezine_preview_jacket_image, b.ezine_preview_author, b.ezine_preview_jacket_desc, b.ezine_preview_publisher, ezine_preview_publish_dt, ezine_preview_number_of_pages, ezine_preview_isbn, ezine_preview_short_summary,
	            b.ezine_preview_bb_author_link, ezine_preview_bb_link
	
	FROM 		arcs a
	INNER JOIN 	ezine_previews b ON b.ezine_preview_number = a.ezine_preview_number
	
	WHERE 		arc_obc_flag = 1

	AND 		getdate() < arc_on_ad_dt
	
		ORDER BY  	NEWID()
get_active_obc (Datasource=bookbrowse_com_new, Time=6ms, Records=1) in /root/website/queries/qry_get_active_obc.cfm @ 18:31:42.042
SELECT 		a.arc_forumidfk, a.discourse_flag, a.arc_promo_text,
				b.ezine_preview_number, b.ezine_preview_title, b.ezine_preview_subtitle, b.ezine_preview_jacket_image, b.ezine_preview_author, b.ezine_preview_jacket_desc, b.ezine_preview_publisher, ezine_preview_publish_dt, ezine_preview_number_of_pages,  ezine_preview_isbn, ezine_preview_short_summary,
	            b.ezine_preview_bb_author_link, ezine_preview_bb_link,
	            c.book_reading_guide
	
	FROM 		arcs a
	INNER JOIN 	ezine_previews b ON b.ezine_preview_number = a.ezine_preview_number
	LEFT JOIN  	books c on c.book_number = b.ezine_preview_bb_link
	
	WHERE 		a.arc_obc_flag = 1
	AND			a.arc_active_flag = 0
	AND 		arc_closed_flag = 1
	AND 		getdate() >= arc_on_ad_dt
	AND 		getdate() < arc_off_ad_dt
	ORDER BY  	NEWID()
get_recent_obc (Datasource=bookbrowse_com_new, Time=7ms, Records=4) in /root/website/queries/qry_get_active_obc.cfm @ 18:31:42.042
SELECT 		a.arc_forumidfk, a.discourse_flag, a.arc_promo_text,
				b.ezine_preview_number, b.ezine_preview_title, b.ezine_preview_subtitle, b.ezine_preview_jacket_image, b.ezine_preview_author, b.ezine_preview_jacket_desc, b.ezine_preview_publisher, ezine_preview_publish_dt, ezine_preview_number_of_pages,  ezine_preview_isbn, ezine_preview_short_summary,
	            b.ezine_preview_bb_author_link, ezine_preview_bb_link,
	            c.book_reading_guide
	
	FROM 		arcs a
	INNER JOIN 	ezine_previews b ON b.ezine_preview_number = a.ezine_preview_number
	LEFT JOIN  	books c on c.book_number = b.ezine_preview_bb_link
	
	WHERE a.arc_number IN (select top 4 arc_number
							from		arcs
							WHERE 		arc_obc_flag = 1
							AND			arc_active_flag = 0
							AND 		arc_closed_flag = 1
							AND 		getdate() > arc_off_ad_dt
							ORDER BY	arc_on_ad_dt DESC)
	ORDER BY  	NEWID()
get_news_for_rss_feed (Datasource=bookbrowse_com_new, Time=0ms, Records=10, Cached Query) in /root/website/queries/qry_get_news_for_rss_feed.cfm @ 18:31:42.042
SELECT TOP 10 *
    FROM news
	where news_item_dt <= getdate()
    ORDER BY news_item_dt DESC, news_item_number DESC
get_member_info (Datasource=bookbrowse_com_new, Time=1ms, Records=0) in /root/website/queries/qry_get_member_info.cfm @ 18:31:42.042
select 	a.*, 
    		b.member_account_type_name, b.member_account_type_charge, b.member_account_type_charge_frequency,  b.member_account_type_months, 
            c.member_chargetype_name, c.member_chargetype_number, a.member_classification_number, a.member_book_format
	
    from members a, member_account_types b, member_chargetype c
	
    where a.member_account_type_number = b.member_account_type_number
	and a.payment_method_id = c.member_chargetype_number
	and a.member_number = ?
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 0

get_books_publishing_this_week (Datasource=bookbrowse_com_new, Time=8ms, Records=0) in /root/website/queries/qry_get_books_publishing_this_week.cfm @ 18:31:42.042
SELECT 	
		a.ezine_preview_number, a.ezine_preview_title, a.ezine_preview_subtitle, a.ezine_preview_author, a.ezine_preview_short_summary, a.ezine_preview_jacket_image, a.ezine_preview_bb_link, a.ezine_preview_bb_author_link, a.ezine_preview_publish_dt, a.ezine_preview_rating,
		DATEADD(wk, 0, DATEADD(DAY, 1-DATEPART(WEEKDAY, GETDATE()), DATEDIFF(dd, 0, GETDATE()))) AS "thisweek",
		CASE when (SELECT count(arc_number) FROM arcs WHERE arcs.ezine_preview_number = a.ezine_preview_number) = 0
			 then 0
			 else 1
		end AS "fi"
		
FROM 		ezine_previews a
INNER JOIN 	ezine_preview_categories b on b.ezine_preview_category_number = a.ezine_preview_category_number 


WHERE		DATEPART(wk, a.ezine_preview_publish_dt) = DATEPART(wk, GETDATE())
AND 		DATEPART(yy, a.ezine_preview_publish_dt) = DATEPART(yy, GETDATE())
AND			(select count(*) from editions e where e.book_number = a.ezine_preview_bb_link) < 2

 order by fi DESC, b.ezine_preview_category_sortorder asc, a.ezine_preview_publish_dt ASC, a.ezine_preview_title, a.ezine_preview_number ASC
total_books_this_week (Datasource=bookbrowse_com_new, Time=9ms, Records=1) in /root/website/queries/qry_get_books_publishing_this_week.cfm @ 18:31:42.042
select 	count(*) as "count"
	from 	ezine_previews a
	inner join ezine_preview_categories b  on b.ezine_preview_category_number = a.ezine_preview_category_number

	where 	DATEPART(wk, a.ezine_preview_publish_dt) = DATEPART(wk, GETDATE())
	AND 	DATEPART(yy, a.ezine_preview_publish_dt) = DATEPART(yy, GETDATE())
	AND		(select count(*) from editions e where e.book_number = a.ezine_preview_bb_link) < 2
get_forthcoming_books (Datasource=bookbrowse_com_new, Time=1ms, Records=2, Cached Query) in /root/website/queries/qry_get_forthcoming_books.cfm @ 18:31:42.042
select 	top 12 ezine_preview_number, ezine_number, ezine_preview_category_number, ezine_preview_title, ezine_preview_subtitle, ezine_preview_jacket_image, ezine_preview_author, 
    		ezine_preview_publisher, ezine_preview_publish_dt, ezine_preview_jacket_desc, ezine_preview_bb_comments, ezine_preview_reviews, ezine_preview_short_summary,
            ezine_preview_rating, ezine_preview_number_of_pages, ezine_preview_isbn, ezine_preview_isbn13, ezine_preview_bb_link, ezine_preview_bb_author_link, book_awards_number,
            right(ezine_preview_author, charindex(' ',reverse(ezine_preview_author))) as "author_sortorder",
            (select count(*) from ezine_previews where 	ezine_preview_publish_dt >= ? and datalength(ezine_preview_jacket_image) > 0)as "total"
         
    from 	ezine_previews
        
    where 	ezine_preview_publish_dt >= ?
    and 	datalength(ezine_preview_jacket_image) > 0
            
	
        order by ezine_preview_publish_dt ASC, ezine_preview_rating
Query Parameter Value(s) -
Parameter #1(CF_SQL_DATE) = 2026-06-09
Parameter #2(CF_SQL_DATE) = 2026-06-09

get_previous_arcs (Datasource=bookbrowse_com_new, Time=188ms, Records=895) in /root/website/queries/qry_get_previous_arcs.cfm @ 18:31:42.042
SELECT 	a.arc_number,a.arc_client_url,a.arc_active_dt,a.arc_off_ad_dt,
                b.ezine_preview_number, b.ezine_preview_title, b.ezine_preview_subtitle, b.ezine_preview_jacket_image, b.ezine_preview_author, b.ezine_preview_publisher, 
                b.ezine_preview_publish_dt, b.ezine_preview_jacket_desc, b.ezine_preview_number_of_pages, b.ezine_preview_bb_comments, b.ezine_preview_short_summary,
                b.ezine_preview_bb_author_link,b.ezine_preview_rating,b.ezine_preview_firsts_flag,ezine_preview_bb_link,
                c.ezine_preview_category_name AS "ezine_preview_category",
                (select count(*) from arc_allocator d where d.arc_number = a.arc_number and arc_allocator_review_approved_flag = 1) as "reviews",
                CASE WHEN getdate() < arc_off_ad_dt THEN 1
                ELSE 0
                END "Current",
                (select (CAST(AVG(CAST(arc_allocator_review_rating AS numeric(12,0))) AS numeric(12,0)))+
                        (CASE WHEN right(CAST(AVG(CAST(arc_allocator_review_rating AS numeric(12,2))) AS numeric(12,2)),2) > 25 AND right(CAST(AVG(CAST(arc_allocator_review_rating AS numeric(12,2))) AS numeric(12,2)),2) < 50 THEN 0.5
                         WHEN right(CAST(AVG(CAST(arc_allocator_review_rating AS numeric(12,2))) AS numeric(12,2)),2) > 50 AND right(CAST(AVG(CAST(arc_allocator_review_rating AS numeric(12,2))) AS numeric(12,2)),2) < 75 THEN -0.5
                         ELSE 0
                         END)
                    from arc_allocator	where arc_number = a.arc_number and arc_allocator_review_approved_flag = 1) AS "arcrating",
                (select (CAST(AVG(CAST(arc_allocator_review_rating AS numeric(12,1))) AS numeric(12,1)))from arc_allocator where arc_number = a.arc_number and arc_allocator_review_approved_flag = 1) AS "decrating",
                (select top 1 arc_allocator_notification_dt from arc_allocator where arc_number = a.arc_number and arc_allocator_review_approved_flag = 1) AS "arcdate",
                (select top 1 year(arc_allocator_notification_dt) from arc_allocator where arc_number = a.arc_number and arc_allocator_review_approved_flag = 1) AS "arcyear",
                year(ezine_preview_publish_dt) AS "pubyear"
        
        FROM arcs a
        INNER JOIN ezine_previews b ON b.ezine_preview_number = a.ezine_preview_number
        INNER JOIN ezine_preview_categories c ON b.ezine_preview_category_number = c.ezine_preview_category_number
        
        WHERE 	arc_closed_flag = 1
        AND		a.arc_obc_flag = ?
		AND		year(ezine_preview_publish_dt) > 2005

        
       ORDER BY arc_on_ad_dt
	   			
					ASC
Query Parameter Value(s) -
Parameter #1(cf_sql_tinyint) = 0

data (Datasource=, Time=3ms, Records=0) in /root/website/current_books/dsp_main.cfm @ 18:31:42.042
select 	* 
    from 	arclist
    where 	reviews > 1
    and ? < arc_off_ad_dt
Query Parameter Value(s) -
Parameter #1(cf_sql_date) = 2026-05-31

get_recent_btb (Datasource=bookbrowse_com_new, Time=0ms, Records=30, Cached Query) in /root/website/queries/qry_get_recent_btb.cfm @ 18:31:42.042
SELECT		a.ezine_dt, 
				b.ezine_sort_order, b.ezine_boxed_content_title, b.ezine_boxed_content, 
				d.book_number, d.book_title
                
	FROM		ezines a
	INNER JOIN  ezine_edition_mapping b on a.ezine_number = b.ezine_number
	INNER JOIN 	editions c on  c.edition_number = b.edition_number
	INNER JOIN	books d on d.book_number = c.book_number
	WHERE		a.ezine_number IN
				(select top 2 ezine_number
				from ezines
				where ezine_active_flag = 1
				order by ezine_dt DESC)
    ORDER BY	ezine_sort_order
check_editors_choice (Datasource=bookbrowse_com_new, Time=7ms, Records=1) in /root/website/articles/btb_udfs.cfm @ 18:31:42.042
SELECT 	count(*) as "count"
	    FROM 	books
	    WHERE 	book_number = ?
	    AND		book_number IN (SELECT		top 4 a.book_number
	                            FROM		editors_choice a 
	                            WHERE		editors_choice_dt < getdate()
	                            ORDER BY	editors_choice_dt DESC)
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 4614

check_free_ezine (Datasource=bookbrowse_com_new, Time=3ms, Records=1) in /root/website/articles/btb_udfs.cfm @ 18:31:42.042
SELECT 		count(*) as "count"
	    FROM    	ezine_edition_mapping AS a
	    INNER JOIN 	ezines b ON b.ezine_number = a.ezine_number
	    INNER JOIN	editions c ON c.edition_number = a.edition_number
	    WHERE 		c.book_number = ?
		AND			ezine_edition_free_review_flag = 1
		AND			dateadd(ww,4,b.ezine_dt) > getdate()
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 4614

check_cat_73 (Datasource=bookbrowse_com_new, Time=1ms, Records=1) in /root/website/articles/btb_udfs.cfm @ 18:31:42.042
SELECT 		count(*) as "count"
	    FROM    	books AS b
	    INNER JOIN 	category_book_mapping AS c ON c.book_number = b.book_number
	    WHERE 		b.book_number = ?
		AND			c.category_number = 73
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 4614

check_old_ezine (Datasource=bookbrowse_com_new, Time=1ms, Records=1) in /root/website/articles/btb_udfs.cfm @ 18:31:42.042
SELECT 		count(*) as "count"
	    FROM    	ezine_edition_mapping AS a
	    INNER JOIN 	ezines b ON b.ezine_number = a.ezine_number
	    INNER JOIN	editions c ON c.edition_number = a.edition_number
	    WHERE 		c.book_number = ?
		AND			datediff(mm,b.ezine_dt,getdate()) > 12
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 4614

check_editors_choice (Datasource=bookbrowse_com_new, Time=0ms, Records=1) in /root/website/articles/btb_udfs.cfm @ 18:31:42.042
SELECT 	count(*) as "count"
	    FROM 	books
	    WHERE 	book_number = ?
	    AND		book_number IN (SELECT		top 4 a.book_number
	                            FROM		editors_choice a 
	                            WHERE		editors_choice_dt < getdate()
	                            ORDER BY	editors_choice_dt DESC)
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 4792

check_free_ezine (Datasource=bookbrowse_com_new, Time=1ms, Records=1) in /root/website/articles/btb_udfs.cfm @ 18:31:42.042
SELECT 		count(*) as "count"
	    FROM    	ezine_edition_mapping AS a
	    INNER JOIN 	ezines b ON b.ezine_number = a.ezine_number
	    INNER JOIN	editions c ON c.edition_number = a.edition_number
	    WHERE 		c.book_number = ?
		AND			ezine_edition_free_review_flag = 1
		AND			dateadd(ww,4,b.ezine_dt) > getdate()
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 4792

check_cat_73 (Datasource=bookbrowse_com_new, Time=0ms, Records=1) in /root/website/articles/btb_udfs.cfm @ 18:31:42.042
SELECT 		count(*) as "count"
	    FROM    	books AS b
	    INNER JOIN 	category_book_mapping AS c ON c.book_number = b.book_number
	    WHERE 		b.book_number = ?
		AND			c.category_number = 73
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 4792

check_old_ezine (Datasource=bookbrowse_com_new, Time=0ms, Records=1) in /root/website/articles/btb_udfs.cfm @ 18:31:42.042
SELECT 		count(*) as "count"
	    FROM    	ezine_edition_mapping AS a
	    INNER JOIN 	ezines b ON b.ezine_number = a.ezine_number
	    INNER JOIN	editions c ON c.edition_number = a.edition_number
	    WHERE 		c.book_number = ?
		AND			datediff(mm,b.ezine_dt,getdate()) > 12
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 4792

check_editors_choice (Datasource=bookbrowse_com_new, Time=1ms, Records=1) in /root/website/articles/btb_udfs.cfm @ 18:31:42.042
SELECT 	count(*) as "count"
	    FROM 	books
	    WHERE 	book_number = ?
	    AND		book_number IN (SELECT		top 4 a.book_number
	                            FROM		editors_choice a 
	                            WHERE		editors_choice_dt < getdate()
	                            ORDER BY	editors_choice_dt DESC)
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 5028

check_free_ezine (Datasource=bookbrowse_com_new, Time=1ms, Records=1) in /root/website/articles/btb_udfs.cfm @ 18:31:42.042
SELECT 		count(*) as "count"
	    FROM    	ezine_edition_mapping AS a
	    INNER JOIN 	ezines b ON b.ezine_number = a.ezine_number
	    INNER JOIN	editions c ON c.edition_number = a.edition_number
	    WHERE 		c.book_number = ?
		AND			ezine_edition_free_review_flag = 1
		AND			dateadd(ww,4,b.ezine_dt) > getdate()
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 5028

check_cat_73 (Datasource=bookbrowse_com_new, Time=0ms, Records=1) in /root/website/articles/btb_udfs.cfm @ 18:31:42.042
SELECT 		count(*) as "count"
	    FROM    	books AS b
	    INNER JOIN 	category_book_mapping AS c ON c.book_number = b.book_number
	    WHERE 		b.book_number = ?
		AND			c.category_number = 73
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 5028

check_old_ezine (Datasource=bookbrowse_com_new, Time=0ms, Records=1) in /root/website/articles/btb_udfs.cfm @ 18:31:42.042
SELECT 		count(*) as "count"
	    FROM    	ezine_edition_mapping AS a
	    INNER JOIN 	ezines b ON b.ezine_number = a.ezine_number
	    INNER JOIN	editions c ON c.edition_number = a.edition_number
	    WHERE 		c.book_number = ?
		AND			datediff(mm,b.ezine_dt,getdate()) > 12
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 5028

get_category_information (Datasource=bookbrowse_com_new, Time=0ms, Records=1, Cached Query) in /root/website/cfcs/homepage.cfc @ 18:31:42.042
select a.category_qry_template
                from categories a
                    where a.category_number = ?
                        and a.category_qry_template IS NOT NULL
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 60

get_books_by_category_id (Datasource=bookbrowse_com_new, Time=1ms, Records=0) in /root/website/queries/qry_get_books_by_special_category_new_in_hardcover.cfm @ 18:31:42.042
select	a.book_number, a.book_title, a.book_sub_title, a.book_short_summary, 
    		CAST(a.book_jacket_info AS VARCHAR(10)) as "book_jacket_info", 
            CAST(a.book_excerpt AS VARCHAR(10)) as "book_excerpt", 
            CAST(a.book_reading_guide AS VARCHAR(10)) as "book_reading_guide", 
            UPPER(CASE WHEN UPPER(LEFT(a.book_title, 2)) = 'A ' THEN SUBSTRING(a.book_title, 3, 1) WHEN UPPER(LEFT(a.book_title, 3)) = 'AN ' THEN SUBSTRING(a.book_title, 4, 1) WHEN UPPER(LEFT(a.book_title, 4)) = 'THE ' THEN SUBSTRING(a.book_title, 5, 1) ELSE LEFT(a.book_title, 1) END) "sortorder",
			b.category_name, b.category_description, b.category_member_only_flag,
            d.*, 
            f.edition_publish_dt "hardcover_publish_dt", f.edition_number_of_pages "hardcover_number_of_pages", f.edition_isbn "hardcover_isbn", f.edition_isbn13 "hardcover_isbn13", f.edition_jacket_image "hardcover_jacket_image", f.edition_publisher "hardcover_publisher", 
            g.edition_publish_dt "paperback_publish_dt", g.edition_number_of_pages "paperback_number_of_pages", g.edition_isbn "paperback_isbn", g.edition_isbn13 "paperback_isbn13", g.edition_jacket_image "paperback_jacket_image", g.edition_publisher "paperback_publisher", 
            i.*, 
            (select top 1 edition_publish_dt from editions where book_number = a.book_number and edition_publish_dt < getdate() order by edition_publish_dt desc) "sort_publish_dt",
            (select AVG(CAST(media_review_rating AS numeric(12,2))) from media_reviews  where book_number = a.book_number and media_review_type_number <> 7 and media_review_rating > 0) "critrating",
            (select AVG(CAST(reader_review_rating AS numeric(12,2))) from reader_reviews where book_number = a.book_number and reader_review_rating > 0) "avrating",			
            round((select AVG(CAST(media_review_rating AS numeric(12,2))) from media_reviews  where book_number = a.book_number and media_review_type_number <> 7 and media_review_rating > 0),0) "scritrating",
            round((select AVG(CAST(reader_review_rating AS numeric(12,2))) from reader_reviews where book_number = a.book_number and reader_review_rating > 0),0) "savrating",	
			CASE	WHEN datalength(d.author_middle_initial) > 0 
		            THEN d.author_first_name + ' ' + d.author_middle_initial + ' ' + d.author_last_name
		            ELSE d.author_first_name + ' ' + d.author_last_name
	    	END AS "author_full_name"
			
	from 	books a
	inner join book_author_mapping e on a.book_number = e.book_number
	inner join authors d on e.author_number = d.author_number
	inner join author_info i on i.author_number = d.author_number
	left outer join editions f on a.book_number = f.book_number and f.edition_paperback_flag = 0 
	left outer join editions g on a.book_number = g.book_number and g.edition_paperback_flag = 1 
	left outer join categories b on b.category_active_flag = 1 and b.category_number = ?
	
	where f.edition_publish_dt > DATEADD(month, -3, getdate()) 
	and f.edition_publish_dt < getdate()

        
		

	ORDER BY f.edition_publish_dt desc, a.book_entry_dt desc
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 60

get_category_information (Datasource=bookbrowse_com_new, Time=0ms, Records=1, Cached Query) in /root/website/cfcs/homepage.cfc @ 18:31:42.042
select a.category_qry_template
                from categories a
                    where a.category_number = ?
                        and a.category_qry_template IS NOT NULL
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 61

get_books_by_category_id (Datasource=bookbrowse_com_new, Time=2ms, Records=1) in /root/website/queries/qry_get_books_by_special_category_new_in_paperback.cfm @ 18:31:42.042
select 	a.book_number, a.book_title, a.book_sub_title, a.book_short_summary, 
	        CAST(a.book_jacket_info AS VARCHAR(10)) as "book_jacket_info", 
	        CAST(a.book_excerpt AS VARCHAR(10)) as "book_excerpt", 
	        CAST(a.book_reading_guide AS VARCHAR(10)) as "book_reading_guide", 
	        UPPER(CASE WHEN UPPER(LEFT(a.book_title, 2)) = 'A ' THEN SUBSTRING(a.book_title, 3, 1) WHEN UPPER(LEFT(a.book_title, 3)) = 'AN ' THEN SUBSTRING(a.book_title, 4, 1) WHEN UPPER(LEFT(a.book_title, 4)) = 'THE ' THEN SUBSTRING(a.book_title, 5, 1) ELSE LEFT(a.book_title, 1) END) "sortorder",
			b.category_name, b.category_description, b.category_member_only_flag, 
	        d.*, 
	        '' "hardcover_publish_dt", '' "hardcover_number_of_pages", '' "hardcover_isbn", '' "hardcover_isbn13", '' "hardcover_jacket_image", '' "hardcover_publisher",
			g.edition_publish_dt "paperback_publish_dt", g.edition_number_of_pages "paperback_number_of_pages", g.edition_isbn "paperback_isbn", g.edition_isbn13 "paperback_isbn13", g.edition_jacket_image "paperback_jacket_image", g.edition_publisher "paperback_publisher", 
			i.*, 
			(select top 1 edition_publish_dt from editions where book_number = a.book_number and edition_publish_dt < getdate() order by edition_publish_dt desc) "sort_publish_dt",
			(select AVG(CAST(media_review_rating AS numeric(12,2))) from media_reviews  where book_number = a.book_number and media_review_type_number <> 7 and media_review_rating > 0) "critrating",
			(select AVG(CAST(reader_review_rating AS numeric(12,2))) from reader_reviews where book_number = a.book_number and reader_review_rating > 0) "avrating",			
			round((select AVG(CAST(media_review_rating AS numeric(12,2))) from media_reviews  where book_number = a.book_number and media_review_type_number <> 7 and media_review_rating > 0),0) "scritrating",
			round((select AVG(CAST(reader_review_rating AS numeric(12,2))) from reader_reviews where book_number = a.book_number and reader_review_rating > 0),0) "savrating",	
			CASE	WHEN datalength(d.author_middle_initial) > 0 
		            THEN d.author_first_name + ' ' + d.author_middle_initial + ' ' + d.author_last_name
		            ELSE d.author_first_name + ' ' + d.author_last_name
	    	END AS "author_full_name"
	
	from 	books a
	inner join book_author_mapping e on a.book_number = e.book_number
	inner join authors d on e.author_number = d.author_number
	inner join author_info i on i.author_number = d.author_number
	left outer join editions f on a.book_number = f.book_number and f.edition_paperback_flag = 0 
	left outer join editions g on a.book_number = g.book_number and g.edition_paperback_flag = 1 
	left outer join categories b on b.category_active_flag = 1 and b.category_number = ?
	
	where g.edition_publish_dt > DATEADD(month, -3, getdate()) 
	and g.edition_publish_dt < getdate()
	

	ORDER BY g.edition_publish_dt desc, a.book_entry_dt desc
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 61

get_book_image (Datasource=bookbrowse_com_new, Time=1ms, Records=1) in /root/website/actions/udfs.cfm @ 18:31:42.042
select 	f.edition_publish_dt "hardcover_publish_dt", f.edition_jacket_image "hardcover_jacket_image", 
            g.edition_publish_dt "paperback_publish_dt", g.edition_jacket_image "paperback_jacket_image"
    
    from   	books a
	left join editions f on a.book_number = f.book_number and f.edition_paperback_flag = 0
	left join editions g on a.book_number = g.book_number and g.edition_paperback_flag = 1
                    
    where 	a.book_number = ?
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 4841

get_coauthor (Datasource=bookbrowse_com_new, Time=1ms, Records=1) in /root/website/actions/udfs.cfm @ 18:31:42.042
select 		book_number, 
            			CASE	WHEN datalength(d.author_middle_initial) > 1 
				                THEN d.author_first_name + ' ' + d.author_middle_initial + ' ' + d.author_last_name
				                ELSE d.author_first_name + ' ' + d.author_last_name
                        END "author",
                        d.author_number
            from		book_author_mapping e
            inner join	authors d ON e.author_number = d.author_number
            where		e.book_number = ?
			order by	book_author_mapping_number ASC
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 4841

get_free_newsletters (Datasource=bookbrowse_com_new, Time=0ms, Records=4, Cached Query) in /root/website/queries/qry_get_free_newsletters.cfm @ 18:31:42.042
SELECT 	*
    FROM 	free_newsletters
get_ads (Datasource=bookbrowse_com_new, Time=4ms, Records=0) in /root/website/adsystem/adsystem_mod.cfm @ 18:31:42.042
SELECT		a.adid,	adweight
	FROM		adsystem a
	INNER JOIN 	ad_category_mapping b ON b.adid = a.adid
	WHERE		a.section = ?
	AND			a.active  = 1
	AND 		a.start_date <= GETDATE()
	
	AND (a.viewby LIKE '%n%' OR a.viewby = 'all')
            

	AND     (b.category_number IN (	SELECT	category_number
									FROM	category_book_mapping
									WHERE	book_number = ?)
      		OR 	b.category_number = ?)
Query Parameter Value(s) -
Parameter #1(CF_SQL_VARCHAR) = showcase_track
Parameter #2(CF_SQL_VARCHAR) = 0
Parameter #3(CF_SQL_VARCHAR) = 0

get_ads (Datasource=bookbrowse_com_new, Time=3ms, Records=1) in /root/website/adsystem/adsystem_mod.cfm @ 18:31:42.042
SELECT	a.adid,	adweight
        FROM	adsystem a
        WHERE	a.section = ? 
        AND 	a.active  = 1 
        AND		a.start_date <= GETDATE()	
        
        AND (a.viewby LIKE '%n%' OR a.viewby = 'all')
        AND (select count(*) from ad_category_mapping where datalength(category_number) >= 1 and adid = a.adid) = 0
Query Parameter Value(s) -
Parameter #1(CF_SQL_VARCHAR) = showcase_track

get_type (Datasource=bookbrowse_com_new, Time=0ms, Records=1) in /root/website/adsystem/adsystem_mod.cfm @ 18:31:42.042
SELECT	a.start_date, a.adid, a.end_date, a.camp_views, a.image_name, a.alt_text, a.views, a.code, a.adsize
        FROM	adsystem a
        WHERE	a.adid = ?
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 594


Scope Variables

CGI Variables:
AUTH_PASSWORD=
AUTH_TYPE=
AUTH_USER=
CERT_COOKIE=
CERT_FLAGS=
CERT_ISSUER=
CERT_KEYSIZE=
CERT_SECRETKEYSIZE=
CERT_SERIALNUMBER=
CERT_SERVER_ISSUER=
CERT_SERVER_SUBJECT=
CERT_SUBJECT=
CF_TEMPLATE_PATH=/root/website/current_books/index.cfm
CONTENT_LENGTH=
CONTENT_TYPE=
CONTEXT_PATH=
GATEWAY_INTERFACE=
HTTPS=
HTTPS_KEYSIZE=
HTTPS_SECRETKEYSIZE=
HTTPS_SERVER_ISSUER=
HTTPS_SERVER_SUBJECT=
HTTP_ACCEPT=*/*
HTTP_ACCEPT_ENCODING=gzip, br, zstd, deflate
HTTP_ACCEPT_LANGUAGE=
HTTP_CONNECTION=upgrade
HTTP_COOKIE=CFGLOBALS=urltoken%3DCFID%23%3D4071353%26CFTOKEN%23%3D5e48458f69d6d934%2DF90F70E1%2DB621%2DC7B7%2D90E3D53AC4FBD459%23lastvisit%3D%7Bts%20%272026%2D05%2D31%2018%3A31%3A41%27%7D%23hitcount%3D3%23timecreated%3D%7Bts%20%272026%2D05%2D31%2018%3A31%3A41%27%7D%23cftoken%3D5e48458f69d6d934%2DF90F70E1%2DB621%2DC7B7%2D90E3D53AC4FBD459%23cfid%3D4071353%23; CFTOKEN=5e48458f69d6d934-F90F70E1-B621-C7B7-90E3D53AC4FBD459; CFCLIENT_BOOKBROWSE=order%3Dp%23member%5Fnumber%3D0%23member%5Factive%5Fflag%3D0%23member%5Flogged%5Fin%5Fflag%3D0%23library%5Fuser%5Fflag%3D0%23view%3Dbooks%23; CFID=4071353
HTTP_HOST=dev.bookbrowse.com
HTTP_REFERER=http://dev.bookbrowse.com/current_books/
HTTP_URL=
HTTP_USER_AGENT=Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)
LOCAL_ADDR=127.0.0.1
PATH_INFO=
PATH_TRANSLATED=/root/website/current_books/index.cfm
QUERY_STRING=
REMOTE_ADDR=127.0.0.1
REMOTE_HOST=127.0.0.1
REMOTE_USER=
REQUEST_METHOD=GET
SCRIPT_NAME=/current_books/index.cfm
SERVER_NAME=dev.bookbrowse.com
SERVER_PORT=8500
SERVER_PORT_SECURE=0
SERVER_PROTOCOL=HTTP/1.1
SERVER_SOFTWARE=
WEB_SERVER_API=
Client Variables:
cfid=4071353
cftoken=5e48458f69d6d934-F90F70E1-B621-C7B7-90E3D53AC4FBD459
hitcount=3
lastvisit={ts '2026-05-31 18:31:41'}
library_user_flag=0
member_active_flag=0
member_logged_in_flag=0
member_number=0
order=p
timecreated={ts '2026-05-31 18:31:41'}
urltoken=CFID=4071353&CFTOKEN=5e48458f69d6d934-F90F70E1-B621-C7B7-90E3D53AC4FBD459
view=books
Cookie Variables:
CFCLIENT_BOOKBROWSE=order=p#member_number=0#member_active_flag=0#member_logged_in_flag=0#library_user_flag=0#view=books#
CFGLOBALS=urltoken=CFID#=4071353&CFTOKEN#=5e48458f69d6d934-F90F70E1-B621-C7B7-90E3D53AC4FBD459#lastvisit={ts '2026-05-31 18:31:41'}#hitcount=3#timecreated={ts '2026-05-31 18:31:41'}#cftoken=5e48458f69d6d934-F90F70E1-B621-C7B7-90E3D53AC4FBD459#cfid=4071353#
CFID=4071353
CFTOKEN=5e48458f69d6d934-F90F70E1-B621-C7B7-90E3D53AC4FBD459
Session Variables:
cfid=4071353
cftoken=5e48458f69d6d934-F90F70E1-B621-C7B7-90E3D53AC4FBD459
sessionid=BOOKBROWSE_4071353_5e48458f69d6d934-F90F70E1-B621-C7B7-90E3D53AC4FBD459
urltoken=CFID=4071353&CFTOKEN=5e48458f69d6d934-F90F70E1-B621-C7B7-90E3D53AC4FBD459
Debug Rendering Time: 7 ms