Shannon Hale Interview, plus links to author biography, book summaries, excerpts and reviews

Shannon Hale

Shannon Hale

How to pronounce Shannon Hale: shan-non hale (rhymes with rail)

An interview with Shannon Hale

An interview with Shannon Hale, author of Princess Academy, The Goose Girl, and other books for young readers.

This is a transcription from TheAuthorHour radio show. For additional questions not asked during the live show, visit TheAuthorHour

Matthew: My guest today is Shannon Hale, New York Times bestselling author of Princess Academy, which received the Newbery Honor. She's also written the Bayern series, starting with The Goose Girl, which received the Josette Frank Award and made the American Library Association Top Ten Books for Young Adults list. Thanks for being on the show today, Shannon.

Shannon: Well, thank you.

Matthew: Let's first talk about Princess Academy. Congratulations on getting the Newbery Honor award, by the way.

Shannon: Thanks, that just never gets old. No matter who I explain it too. It's the gift that keeps on giving, that's for sure.

Matthew: I know! I'm sure it's just one of those things you are just ecstatic about.

Shannon: Yeah, it still doesn't feel real, honestly, three and a half years later.

Matthew: Well, tell us a little bit about Princess Academy.

Shannon: Princess Academy is a story about a girl who lives in a very small village on top of a mountain. It's a fantasy book, so it's a sort of a long ago, far away, type of setting. They get word that one of the girls from the village will be the bride to the next prince, and he'll choose one of them, but first they all have to attend a school to learn what they need to know in case they're chosen. They're very resistant to this idea, but they attend this academy to learn those things. So, the suspense, of course is who's going to be chosen and do they actually, any of them, will they want to be chosen and leave their home and all that that implies.

Matthew: 'Cause they don't even really know the person that they'd be marrying, do they?

Shannon: That's right, in part, I think my fascination with that story was reading fairy tales as a child, it was always a good thing to become a princess and marry a prince and you know, go off to the castle.

Matthew: Yeah.

Shannon: But the reality of it, you know, would you really want to? Would that always be the best thing? What if you didn't like the prince? What if he wasn't a great guy? What if you'd rather stay with your family? So, these girls have very many conflicting feelings about it and questions, as they're attending this school and learning these things. Of course, there's a fantasy element and danger and romance mixed into it all because those are things that I love.

Matthew: Yeah. And the age group for that book is middle grade?

Shannon: Yeah, they said 10 and up. I've had 8 year old readers and well, I've had 80 year old readers, so anywhere in between there.

Matthew: Well, that's good. You have another series that you've written. Actually The Goose Girl, was the first one in this series, the Bayern series, back in 2003, that was your first book wasn't it?

Shannon: It was my first book, yeah. It was my first baby.

Matthew: Your baby. And it did really well. It received the Josette Frank Award and made the ALA Top Ten list for teens.

Shannon: You know, that was a long ride. I started to write when I was ten. So, it felt like a long time to me. It took twenty years to get published. I have many, many dozens of rejections on my stories and on my books before The Goose Girl was selected to be published. And it's interesting, I actually just posted on my blog about this. The Goose Girl was rejected by the Who's Who of Publishers, before it was published by Bloomsberry. And of course it's gone on to be one of my most successful books and hundreds of thousands of books in print and readers and, you know, 15 languages.

Matthew: Yeah.

Shannon: And such, so I think, for me, it's an example of how rejection isn't always a bad thing. It isn't a condemnation of you or your book. It's just saying you haven't found the right home yet, and keep trying until you find the right place.

Matthew: Yeah. I totally agree with you. Rejection ... I mean it happens, you're going to get it and a lot of people don't realize how much rejection authors, the typical author, gets. Even well established authors can sometimes get rejected and not get their next book out, or another series.

Shannon: I was talking to several New York Times best-selling, award winning authors, recently. And they were talking about how they didn't feel like they'd made it yet. And they're still waiting to feel like they've "made it." And it sort of dawned on me that you don't ever really feel secure. It's such a crazy business. And I think from the outside, people sometimes think that we must be like sudo-celebrities, or wealthy or totally secure in what we do. Of course, we're not, we're just working people, writing each story, the best story that we can and just trying to stay afloat in this crazy economy.

Matthew: Yeah, well one of the best things is to get a book published, but then after the book is published, "your baby", you know, of course, there's the reviews. And I've learned, 'cause I have a book out, I've learned that you really kind of take the reviews with a grain of salt because you know, you might get a hundred great ones, and it's just that one bad review, that just ... for me at least, it sticks with me. And I'm like, "Wow, that person really hated my book!"

Shannon: It is incredible how, and I think we do it in life, just generally as well. You can hear, you know, ten wonderful things and one negative thing, and it's the negative thing that you mull over and over and over again. And reviews are hard, you know, it's hard in this age because of the Internet. Everybody can review. It's so easy to stumble across those reviews. It's so easy for people to say, you know, what they think and how much they hate you and your book and your hair style and everything about you.

Matthew: [laughs]

Shannon: And it doesn't feel personal, they don't think they're actually saying it to me. But reading it feels like they're saying it to my face.

Matthew: Yeah, exactly. I know ... exactly. It seems like it's like an invitation to be a little meaner than you normally would be.

Shannon: It's something that's sort of shocking to me and it's something that I talk to young people about. I think we need to retrain ourselves. I think the progression of the internet happened too fast and we haven't had time to evolve to it. But kindness always ... there's no reason to be rude and unkind, to only ever say in print what you would say to a person's face. And always question what you're willing to say to a person's face.

Matthew: Yeah. Don't just have an ax to grind, too. Yeah, have a good reason for what you say. I totally agree with you. But The Goose Girl has gotten some awards and the next one was Enna Burning, River Secrets. Tell us just a little bit about the series, and then we'll talk about the newest one that just came out, Forest Born.

Shannon: The Goose Girl was based on a fairy tale. And the magic system in these books is that everything has a language, animals, plants, people, and also the elements of nature, like fire, wind, and water, have languages and there are certain people born with the ability to speak those languages, to understand them. And as they progress in that knowledge, they actually come to the point where they control them. So, each of my books of Bayern deals with a person learning one of these powers and the adventures and the challenges that come with that. So, Goose Girl's the story of a princess who is sent off, again the theme is a little different than Princess Academy, but a similar theme. She's sent off to marry a prince that she's never met and her lady in waiting, who wants to take her place is jealous of her and tries to kill her, and there's a massacre in the forest before she escapes, she manages to escape, but she has to hide as a goose girl or a girl who takes care of geese, while she tries to re-claim her throne and her name. And then Enna Burning and River Secrets followed because I'd found these characters in The Goose Girl, who I just loved so much, I wanted to hear their own stories. And the fourth book in the series, Forest Born is another new character. I think my favorite thing about these books is, it's silly to say, but they've become like friends of mine, you know.

Matthew: [laughs]

Shannon: I love hearing what they say, and returning to that land and seeing where they are now and what new adventures they can have.

Matthew: Forest Born, that's the one that just came out. Tell us a little bit more about that one.

Shannon: Forest Born, the main character is Rin. And she is a Forest Born, she was born in the forest, rather than in the city. So, her folk are scavengers basically, they live off of the land. She's from a very large family, she's got six big brothers and then there's her. She feels lost in this family, she feels like she doesn't quite belong. And she has this dark secret that's inside, she feels wrong and bad, like she needs to get away from them. And she doesn't completely understand this at the beginning of the book, what's causing these feelings, and is she really inherently just a bad person because of some bad things that she'd done? And she leaves the forest, to go to the city and meets the queen and becomes one of her waiting women. And through this, when there's a threat to the kingdom and she comes along to help with the queen, she begins to learn about what it is that she has inside her, what these powers mean. And the choice whether she can use them for good reasons or whether she will go completely corrupt.

It's a little bit darker, I think, than some of my other books have been, than Goose Girl. But I think that there's also a lot more danger and adventure to it than some of them as well. They're all a little bit different. You can read them all alone, or you can read them in a series, starting with Goose Girl. But it's so fun. It was a three year project, Forest Born, and it's so magical to see it on the shelves and people reading it and the response so far has just been amazing.

Matthew: Do you plan on having more in the series?

Shannon: I never plan on having more. [laughs]

Matthew: [laughs] Goose Girl was it!

Shannon: I never think that way. I think of one book at a time. And so what just happens is there's a character that comes along in the story, is one that I can't resist, that I'm willing to spend however many years it's going to take to write it. If another one comes along that just begs to be written then, yeah, I will, but currently I'm not writing another one in that series. I'm working on a completely different book.

Matthew: You do have a couple books for adults. Your first one, Austenland, came out 2007, made the BookSense pick list, and your second one, The Actor and the Housewife just came out this year. Do you find it easier to write for adults than for children?

Shannon: Yes! I do actually. Most people assume the opposite, but you are wise. It is easier to write for adults than children. And I think that surprises some people. At least it is for me. And I think it's easier for me, partly because ... [they're set in a contemporary setting].

Matthew: You are an adult, for one.

Shannon: Right. You know, I really don't have a hard time channeling my younger self. I think that's one of the key aspects of any children's writer, is that we tend to be quite immature inside and have very good recollections of what it's like to be young.

Matthew: Well, one novel I didn't mention was the Book of a Thousand Days, which I understand is based on a classic fairy tale from the Brothers Grimm? You really like these fairy tales, and you have some graphic novels that are kind of a real twist on the fairy tales: Rapunzel's Revenge and Calamity Jack's coming out.

Shannon: I often get asked why I retell fairy tales. I mean I've done four. And I think part of it is just those were the stories of my childhood. And I think those stories of your childhood just resonate so powerfully.

Matthew: Well, last question. What are you working on now?

Shannon: I'm working on which might be a trilogy, I'm not sure yet. I'm writing it all in one piece because I'm not good about thinking about the future. I have to write the story that's in front of me. It's called Daisy Danger Brown. It's my first book for young readers. It's in a contemporary setting and it's also first person, which is also unusual for me. And it is so much fun. I'm just having a great ... it is just a kick-butt, crazy super hero-type of adventure.

Matthew: I'm so grateful to speak with you today. I've been speaking with Shannon Hale, New York Times bestselling author of award-winning Princess Academy and the Bayern series. Thank you for being on the show today, Shannon.

Shannon: Well, thank you so much. It's my pleasure.

For additional questions not asked during the live show, visit TheAuthorHour

This interview was originally aired on 10/22/2009

Unless otherwise stated, this interview was conducted at the time the book was first published, and is reproduced with permission of the publisher. This interview may not be reproduced or reprinted without permission in writing from the copyright holder.

Membership Advantages
  • Reviews
  • "Beyond the Book" articles
  • Free books to read and review (US only)
  • Find books by time period, setting & theme
  • Read-alike suggestions by book and author
  • Book club discussions
  • and much more!
  • Just $60 for 12 months or $20 for 3 months.
  • More about membership!

Books by this Author

Books by Shannon Hale at BookBrowse
Dangerous jacket Palace of Stone jacket Book of a Thousand Days jacket
Membership Advantages
  • Reviews
  • "Beyond the Book" articles
  • Free books to read and review (US only)
  • Find books by time period, setting & theme
  • Read-alike suggestions by book and author
  • Book club discussions
  • and much more!
  • Just $60 for 12 months or $20 for 3 months.
  • More about membership!

BookBrowse Book Club

Book Jacket
The Cover Girl
by Amy Rossi
Find them early enough, and they will always be her girls.

Members Recommend

  • Book Jacket
    The Sister's Curse
    by Nicola Solvinic
  • Book Jacket
    The Lost Story of Eva Fuentes
    by Chanel Cleeton
    A mysterious book links three women across generations in this novel by New York Times bestselling author Chanel Cleeton.
  • Book Jacket
    The Vanishing Place
    by Zoë Rankin
Who Said...

Second hand books are wild books...

Click Here to find out who said this, as well as discovering other famous literary quotes!

Book
Trivia
  • Book Trivia

    Can you name the title?

    Test your book knowledge with our daily trivia challenge!

Wordplay

Solve this clue:

W the C A the M W P

and be entered to win..

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 /author_interviews/full/index.cfm
Time Stamp 01-Jun-26 12:56 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
1780318563286 ms 1.78031856329E+012 ms 1 /root/website/app_server.cfm
312 ms 312 ms 1 /root/website/author_interviews/full/index.cfm
135 ms 135 ms 1 /root/website/app_globals.cfm
112 ms 112 ms 1 /root/website/app_layout.cfm
77 ms 77 ms 1 /root/website/site/blocks/layout/dsp_right_column.cfm
74 ms 25 ms 3 /root/website/adsystem/adsystem_mod.cfm
70 ms 70 ms 1 /root/website/queries/qry_get_active_obc.cfm
45 ms 45 ms 1 /root/website/author_interviews/full/dsp_main.cfm
39 ms 39 ms 1 /root/website/site/blocks/dsp_border_first_impressions.cfm
38 ms 38 ms 1 /root/website/queries/qry_get_arcs_for_ad.cfm
29 ms 29 ms 1 /root/website/site/blocks/layout/dsp_footer.cfm
27 ms 27 ms 1 /root/website/adzones/showcase_track.cfm
26 ms 26 ms 1 /root/website/adzones/AdZone6.cfm
23 ms 23 ms 1 /root/website/adzones/AdZone2.cfm
18 ms 9 ms 2 /root/website/site/blocks/membership_advantages.cfm
17 ms 9 ms 2 /root/website/queries/qry_get_member_account_types.cfm
14 ms 14 ms 1 /root/website/act_check_login.cfm
14 ms 14 ms 1 /root/website/queries/qry_get_current_competition.cfm
13 ms 13 ms 1 /root/website/queries/qry_get_member_info.cfm
11 ms 11 ms 1 /root/website/actions/adstatus.cfm
9 ms 9 ms 1 /root/website/queries/qry_get_current_wordplay.cfm
8 ms 2 ms 4 /root/website/actions/act_spider_tracker.cfm
8 ms 8 ms 1 /root/website/queries/qry_get_books_by_author_id_lite.cfm
8 ms 8 ms 1 /root/website/site/blocks/dsp_book_giveaway.cfm
5 ms 5 ms 1 /root/website/queries/qry_get_bb_briefs_by_author.cfm
2 ms 2 ms 1 /root/website/queries/qry_get_all_books_by_author_id.cfm
2 ms 2 ms 1 /root/website/queries/qry_get_author_readalikes_by_id.cfm
1 ms 1 ms 1 /root/website/queries/qry_get_free_newsletters.cfm
1 ms 1 ms 1 /root/website/site/blocks/layout/dsp_bottom_block.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
1 ms 1 ms 1 /root/website/site/blocks/layout/main_menu.cfm
0 ms 0 ms 1 /root/website/Application.cfm
0 ms 0 ms 1 /root/website/act_libraryIPLogin.cfm
0 ms 0 ms 1 /root/website/actions/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_previous_arcs_for_ad.cfm
0 ms 0 ms 1 /root/website/site/blocks/dsp_border_booktalk.cfm
0 ms 0 ms 1 /root/website/site/blocks/dsp_header_newsletter.cfm
0 ms 0 ms 1 /root/website/site/blocks/dsp_top_author_block.cfm
0 ms 0 ms 1 /root/website/site/blocks/dsp_wordplay.cfm
0 ms 0 ms 1 /root/website/site/blocks/email_modal.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_search.cfm
2 ms  STARTUP, PARSING, COMPILING, LOADING, & SHUTDOWN
314 ms  TOTAL EXECUTION TIME
red = over 250 ms average execution time


SQL Queries

spidercheck (Datasource=bookbrowse_com_new, Time=7ms, Records=1) in /root/website/actions/act_spider_tracker.cfm @ 12:56:03.003
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=12ms, Records=0) in /root/website/queries/qry_get_member_info.cfm @ 12:56:03.003
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=10ms, Records=2) in /root/website/actions/adstatus.cfm @ 12:56:03.003
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 @ 12:56:03.003
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=8ms, Records=1) in /root/website/queries/qry_get_current_wordplay.cfm @ 12:56:03.003
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=6ms, Records=0) in /root/website/queries/qry_get_current_competition.cfm @ 12:56:03.003
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=7ms, Records=0) in /root/website/queries/qry_get_current_competition.cfm @ 12:56:03.003
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 @ 12:56:03.003
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=13ms, Records=0) in /root/website/queries/qry_get_active_obc.cfm @ 12:56:03.003
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=18ms, Records=1) in /root/website/queries/qry_get_active_obc.cfm @ 12:56:03.003
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=37ms, Records=4) in /root/website/queries/qry_get_active_obc.cfm @ 12:56:03.003
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_books_by_author_id (Datasource=bookbrowse_com_new, Time=4ms, Records=0) in /root/website/queries/qry_get_books_by_author_id_lite.cfm @ 12:56:03.003
select	a.book_number, a.book_title, a.book_sub_title, book_short_summary,
				(CASE WHEN f.edition_publish_dt < g.edition_publish_dt OR g.edition_publish_dt IS NULL THEN f.edition_publish_dt
                      ELSE g.edition_publish_dt 
                      END) "publish_dt"
		
        from 	books a
		inner join book_author_mapping e ON e.book_number = a.book_number
        inner join authors d ON d.author_number = e.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 
		
       	where 	d.author_number = ?
        and 	a.book_number IN (	select	distinct b.book_number 
        							from	categories a, category_book_mapping b 
                                    where 	a.category_number = b.category_number 
                                    and 	a.category_active_flag = 1)

		order by publish_dt DESC
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 1869

get_author_by_author_id (Datasource=bookbrowse_com_new, Time=4ms, Records=1) in /root/website/queries/qry_get_books_by_author_id_lite.cfm @ 12:56:03.003
select	d.author_number, d.author_first_name, d.author_middle_initial, d.author_last_name, d.author_pronunciation,
				i.author_info_number, i.author_number, i.author_info_image, i.author_info_entry_dt,
                i.author_info_url, i.author_info_interview_summary, i.author_info_interview, i.author_info_biography, i.author_info_copyright_info
                		
        from 	authors d, author_info i
		
        where 	d.author_number = ?
        and 	d.author_number = i.author_number
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 1869

get_all_books_by_author_id (Datasource=bookbrowse_com_new, Time=1ms, Records=3) in /root/website/queries/qry_get_all_books_by_author_id.cfm @ 12:56:03.003
select	a.book_number, 
        		'' AS ezine_preview_number,
                a.book_title, 
                a.book_sub_title, 
				(CASE WHEN f.edition_publish_dt < g.edition_publish_dt OR g.edition_publish_dt IS NULL THEN f.edition_publish_dt
                      ELSE g.edition_publish_dt 
                      END) "publish_dt",
                '' as "jacket"
		
        from 	books a
		inner join book_author_mapping e ON e.book_number = a.book_number
        inner join authors d ON d.author_number = e.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
		
        where 	d.author_number = ?
        and 	a.book_number IN (	select	distinct b.book_number 
        							from	categories a, category_book_mapping b 
                                    where 	a.category_number = b.category_number 
                                    and 	a.category_active_flag = 1)        
        UNION

		select	'' AS book_number,
        		ezine_preview_number, 
				ezine_preview_title AS "book_title", 
				ezine_preview_subtitle AS "book_sub_title",
                ezine_preview_publish_dt AS "publish_dt",
                ezine_preview_jacket_image as "jacket"
		
        from 	ezine_previews
		
        where 	ezine_preview_bb_author_link = ?
        and		ezine_preview_bb_link < 1
        
        order by publish_dt DESC
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 1869
Parameter #2(CF_SQL_INTEGER) = 1869

get_bb_briefs_by_author (Datasource=bookbrowse_com_new, Time=5ms, Records=3) in /root/website/queries/qry_get_bb_briefs_by_author.cfm @ 12:56:03.003
select	ezine_preview_number, 
				ezine_preview_title, 
				ezine_preview_subtitle,
                ezine_preview_publish_dt ,
                ezine_preview_jacket_image
		
        from 	ezine_previews
		
        where 	ezine_preview_bb_author_link = ?
        and		(ezine_preview_bb_link IS NULL
				 or ezine_preview_bb_link < 1)
        and		ezine_number > 0
        
		order by ezine_preview_publish_dt DESC
Query Parameter Value(s) -
Parameter #1(CF_SQL_INTEGER) = 1869

get_author_readalikes_by_id (Datasource=bookbrowse_com_new, Time=2ms, Records=0) in /root/website/queries/qry_get_author_readalikes_by_id.cfm @ 12:56:03.003
SELECT		a.author_number,
			CASE	WHEN datalength(a.author_middle_initial) > 0 
					THEN a.author_first_name + ' ' + a.author_middle_initial + ' ' + a.author_last_name
					ELSE a.author_first_name + ' ' + a.author_last_name
					END AS "author_full_name",
			b.book_number, 
			f.book_title as "book",

			CASE	WHEN datalength(e.author_middle_initial) > 0 
					THEN e.author_first_name + ' ' + e.author_middle_initial + ' ' + e.author_last_name
					ELSE e.author_first_name + ' ' + e.author_last_name
					END AS "liked_author_full_name",
			e.author_number as "liked_author_number", 
			g.book_title as "liked_book",
			c.liked_book_number as "liked_book_number" 

FROM		authors a
INNER JOIN	book_author_mapping b ON b.author_number = a.author_number
INNER JOIN	liked c ON c.book_number = b.book_number
INNER JOIN	book_author_mapping d ON d.book_number = c.liked_book_number
INNER JOIN	authors e ON e.author_number = d.author_number
INNER JOIN	books f on f.book_number = b.book_number
INNER JOIN	books g on g.book_number = c.liked_book_number

WHERE		a.author_number = ?

ORDER BY 	e.author_last_name, e.author_first_name
Query Parameter Value(s) -
Parameter #1(cf_sql_integer) = 1869

get_ads (Datasource=bookbrowse_com_new, Time=16ms, Records=0) in /root/website/adsystem/adsystem_mod.cfm @ 12:56:03.003
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) = adzone2
Parameter #2(CF_SQL_VARCHAR) = 0
Parameter #3(CF_SQL_VARCHAR) = 0

get_ads (Datasource=bookbrowse_com_new, Time=4ms, Records=0) in /root/website/adsystem/adsystem_mod.cfm @ 12:56:03.003
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) = adzone2

get_member_account_types (Datasource=bookbrowse_com_new, Time=11ms, Records=2) in /root/website/queries/qry_get_member_account_types.cfm @ 12:56:03.003
select member_account_type_number, member_account_type_name, member_account_type_charge, member_account_type_charge_frequency, member_account_type_postscript, member_account_type_months, member_account_type_stripe_lookup_key
from member_account_types
where member_account_type_number = (select top 1 member_account_type_number
									from member_account_types
									where member_account_type_months = 12
									and member_account_type_public = 1
									order by member_account_type_charge ASC)
									
or member_account_type_number =		(select top 1 member_account_type_number
									from member_account_types
									where member_account_type_months = 3
									and member_account_type_public = 1
									order by member_account_type_charge ASC)
									
order by member_account_type_sort_order ASC
get_member_account_types (Datasource=bookbrowse_com_new, Time=5ms, Records=2) in /root/website/queries/qry_get_member_account_types.cfm @ 12:56:03.003
select member_account_type_number, member_account_type_name, member_account_type_charge, member_account_type_charge_frequency, member_account_type_postscript, member_account_type_months, member_account_type_stripe_lookup_key
from member_account_types
where member_account_type_number = (select top 1 member_account_type_number
									from member_account_types
									where member_account_type_months = 12
									and member_account_type_public = 1
									order by member_account_type_charge ASC)
									
or member_account_type_number =		(select top 1 member_account_type_number
									from member_account_types
									where member_account_type_months = 3
									and member_account_type_public = 1
									order by member_account_type_charge ASC)
									
order by member_account_type_sort_order ASC
get_arcs_for_ad (Datasource=bookbrowse_com_new, Time=9ms, Records=0) in /root/website/queries/qry_get_arcs_for_ad.cfm @ 12:56:03.003
SELECT 	top 10 a.arc_number,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_publish_dt, 
		(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

FROM arcs a
INNER JOIN ezine_previews b ON b.ezine_preview_number = a.ezine_preview_number

WHERE arc_closed_flag = 1
AND arc_obc_flag = 0
AND getdate() >= arc_on_ad_dt
AND (select count(*) from arc_allocator d where d.arc_number = a.arc_number and arc_allocator_review_approved_flag = 1) > 1
and getdate() <= dateadd(day,1,a.arc_off_ad_dt)

ORDER BY NEWID()
get_arcs_for_ad (Datasource=bookbrowse_com_new, Time=28ms, Records=3) in /root/website/queries/qry_get_arcs_for_ad.cfm @ 12:56:03.003
SELECT 	top 3 a.arc_number,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_publish_dt, 
			(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

	FROM arcs a
	INNER JOIN ezine_previews b ON b.ezine_preview_number = a.ezine_preview_number

	WHERE arc_closed_flag = 1
	AND arc_obc_flag = 0
	AND getdate() >= arc_on_ad_dt
	AND (select count(*) from arc_allocator d where d.arc_number = a.arc_number and arc_allocator_review_approved_flag = 1) > 1

	ORDER BY a.arc_off_ad_dt DESC
get_ads (Datasource=bookbrowse_com_new, Time=9ms, Records=0) in /root/website/adsystem/adsystem_mod.cfm @ 12:56:03.003
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) = adzone6
Parameter #2(CF_SQL_VARCHAR) = 0
Parameter #3(CF_SQL_VARCHAR) = 0

get_ads (Datasource=bookbrowse_com_new, Time=8ms, Records=1) in /root/website/adsystem/adsystem_mod.cfm @ 12:56:03.003
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) = adzone6

get_type (Datasource=bookbrowse_com_new, Time=3ms, Records=1) in /root/website/adsystem/adsystem_mod.cfm @ 12:56:03.003
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) = 1112

get_quotes (Datasource=bookbrowse_com_new, Time=8ms, Records=1) in /root/website/site/blocks/dsp_book_giveaway.cfm @ 12:56:03.003
select top 1 ezine_number, ezine_quote, ezine_quote_title
	    from ezines
	    where len(ezine_quote_title) > 1
	    order by newid()
get_free_newsletters (Datasource=bookbrowse_com_new, Time=0ms, Records=4, Cached Query) in /root/website/queries/qry_get_free_newsletters.cfm @ 12:56:03.003
SELECT 	*
    FROM 	free_newsletters
get_ads (Datasource=bookbrowse_com_new, Time=8ms, Records=0) in /root/website/adsystem/adsystem_mod.cfm @ 12:56:03.003
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.adid NOT IN (?) 
	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_INTEGER) = 1112
Parameter #3(CF_SQL_VARCHAR) = 0
Parameter #4(CF_SQL_VARCHAR) = 0

get_ads (Datasource=bookbrowse_com_new, Time=8ms, Records=1) in /root/website/adsystem/adsystem_mod.cfm @ 12:56:03.003
SELECT	a.adid,	adweight
        FROM	adsystem a
        WHERE	a.section = ? 
        AND 	a.active  = 1 
        AND		a.start_date <= GETDATE()	
        		AND a.adid NOT IN (?) 
        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
Parameter #2(CF_SQL_INTEGER) = 1112

get_type (Datasource=bookbrowse_com_new, Time=7ms, Records=1) in /root/website/adsystem/adsystem_mod.cfm @ 12:56:03.003
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/author_interviews/full/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=FREEACCESSCOUNT=1; CFID=4100954; CFCLIENT_BOOKBROWSE=order%3Dp%23member%5Fnumber%3D0%23member%5Factive%5Fflag%3D0%23member%5Flogged%5Fin%5Fflag%3D0%23library%5Fuser%5Fflag%3D0%23view%3Dbooks%23; CFGLOBALS=urltoken%3DCFID%23%3D4100954%26CFTOKEN%23%3D8f3ea2625a891332%2D2089C899%2DD34A%2DD3D6%2D62468B68DF1195B7%23lastvisit%3D%7Bts%20%272026%2D06%2D01%2012%3A56%3A03%27%7D%23hitcount%3D185%23timecreated%3D%7Bts%20%272026%2D06%2D01%2012%3A55%3A34%27%7D%23cftoken%3D8f3ea2625a891332%2D2089C899%2DD34A%2DD3D6%2D62468B68DF1195B7%23cfid%3D4100954%23; CFTOKEN=8f3ea2625a891332-2089C899-D34A-D3D6-62468B68DF1195B7
HTTP_HOST=dev.bookbrowse.com
HTTP_REFERER=
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=/author_number/1869/author/shannon-hale
PATH_TRANSLATED=/root/website/author_interviews/full/index.cfm
QUERY_STRING=
REMOTE_ADDR=127.0.0.1
REMOTE_HOST=127.0.0.1
REMOTE_USER=
REQUEST_METHOD=GET
SCRIPT_NAME=/author_interviews/full/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=4100954
cftoken=8f3ea2625a891332-2089C899-D34A-D3D6-62468B68DF1195B7
hitcount=189
lastvisit={ts '2026-06-01 12:56:03'}
library_user_flag=0
member_active_flag=0
member_logged_in_flag=0
member_number=0
order=p
timecreated={ts '2026-06-01 12:55:34'}
urltoken=CFID=4100954&CFTOKEN=8f3ea2625a891332-2089C899-D34A-D3D6-62468B68DF1195B7
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#=4100954&CFTOKEN#=8f3ea2625a891332-2089C899-D34A-D3D6-62468B68DF1195B7#lastvisit={ts '2026-06-01 12:56:03'}#hitcount=185#timecreated={ts '2026-06-01 12:55:34'}#cftoken=8f3ea2625a891332-2089C899-D34A-D3D6-62468B68DF1195B7#cfid=4100954#
CFID=4100954
CFTOKEN=8f3ea2625a891332-2089C899-D34A-D3D6-62468B68DF1195B7
FREEACCESSCOUNT=1
Session Variables:
cfid=4100954
cftoken=8f3ea2625a891332-2089C899-D34A-D3D6-62468B68DF1195B7
sessionid=BOOKBROWSE_4100954_8f3ea2625a891332-2089C899-D34A-D3D6-62468B68DF1195B7
urltoken=CFID=4100954&CFTOKEN=8f3ea2625a891332-2089C899-D34A-D3D6-62468B68DF1195B7
URL Parameters:
author=shannon-hale
author_number=1869
Debug Rendering Time: 25 ms