Obtain ALL parents for a page using SQL in SQL Server

Im trying create a report that pulls out all pages not updated in the last month and I'm looking to try and show All Parents ( if any) of those pages.

Anyone out there who has tried this and suceeded?

Thanks

2 answers

1 accepted

0 votes
Answer accepted

I have a SQL query from a few years ago that found all descendants, so I imagine the same approach would work for finding ancestors/parents. You would also need to add a WHERE clause that looks for lastmoddate being outside the last 30 days.

-- Set variable representing the page whose descendants you want to find
DECLARE  @contentid NUMERIC(19, 0)
SET @contentid = 65106350				
-- Declare table to collect all descendants under a particular page
DECLARE @descendants TABLE
(
    contentid   NUMERIC(19, 0) NOT NULL PRIMARY KEY,
    tltitle     VARCHAR(255)       NULL,
    lltitle     VARCHAR(255)       NULL
)
-- Load @Descendants table with direct (i.e. top-level) descendants
INSERT @descendants
(
	contentid,
	tltitle,
	lltitle
)
SELECT C.contentid,
		C.title,
		C.title
FROM content C
WHERE parentid = @contentid
-- Load @Descendants table with indirect (lower-level) descendants, ensuring
-- no duplicates
WHILE @@rowcount <> 0
BEGIN
    INSERT @descendants
    (
    contentid,
    tltitle,
    lltitle
    )
    SELECT C.contentid,
        D.tltitle,
        C.title
    FROM @descendants   D 
    INNER JOIN content  C ON C.parentid = D.contentid
    WHERE NOT EXISTS(SELECT 1
                     FROM @descendants D2
                     WHERE D2.contentid = C.contentid)
END
-- Show results (abbreviated)
SELECT D.tltitle AS ParentPage, D.lltitle AS PageTitle,
	'http://wikiurl.com/pages/viewpage.action?pageId=' + CONVERT(VARCHAR(10),D.contentid) AS ViewPageURL,
	'http://wikiurl.com/pages/editpage.action?pageId=' + CONVERT(VARCHAR(10),D.contentid) AS EditPageURL
FROM @descendants D 
ORDER BY D.tltitle, D.lltitle

You can use this plugin, but it will only show page views from the day the plugin is added: https://marketplace.atlassian.com/plugins/net.customware.confluence.plugin.tracking/server/overview

Suggest an answer

Log in or Sign up to answer
Community showcase
Published Mar 12, 2019 in Confluence

Confluence Admin Certification now $150 for Community Members

More and more people are building their careers with Atlassian, and we want you to be at the front of this wave! Important Dates Start the Certification Prep Course by 2 April 2019 Take your e...

1,023 views 2 13
Read article

Atlassian User Groups

Connect with like-minded Atlassian users at free events near you!

Find a group

Connect with like-minded Atlassian users at free events near you!

Find my local user group

Unfortunately there are no AUG chapters near you at the moment.

Start an AUG

You're one step closer to meeting fellow Atlassian users at your local meet up. Learn more about AUGs

Groups near you