Calling all developers! We invite you to provide your input on Feature Experimentation by completing this brief survey.
Calling all developers! We invite you to provide your input on Feature Experimentation by completing this brief survey.
Hello Dileep
Does this have to be a database query? Querying the DB isn't recommended as the schema can change without notice.
You can however find references to content using the IContentRepository. So something like this will allow you to do this work using the API:
IContentRepository repo;
repo.GetReferencesToContent(yourPdf.ContentLink, false).Any();
I managed to get this data using below queries.
-- GET PDF's INTO A TABLE
DECLARE @PDFTable TABLE(ContentId int, Name varchar(1000), pageguid varchar(50), ExpiryDate Datetime)
INSERT INTO @PDFTable
Select
T.pkID 'Content Id',
TPL.Name 'Content Name',
T.PageGUID,
TPL.StopPublish
from tblPage T
inner join tblPageLanguage TPL ON T.pkID = TPL.fkPageID
inner join tblPageType TP on T.fkPageTypeID = TP.pkID
where TP.Name = 'PDFTypeFile' -- This should be the type name used for the PDF or whatever media items you need
-- Get all articles where the pdf/media items is referenced with the field data where the media items are referenced. In my case it was in Related resources which can accept more than 1 media item
Declare @CustomTable TABLE (ContentId int, WebPageUrl varchar(500), WebpageName varchar(500), PropertyName varchar(50), PropertyValue varchar(max), PageType varchar(50))
Insert into @CustomTable
select tblPage.pkID, tblPageLanguage.LinkURL 'Web Page URL', tblPageLanguage.Name 'Web Page Name',tblPageDefinition.Name
'Property Name', tblProperty.LongString 'Property Value',
tblPageType.Name
from tblProperty
inner join tblPage on tblProperty.fkPageID = tblPage.pkID
inner join tblPageDefinition on tblProperty.fkPageDefinitionID = tblPageDefinition.pkID
inner join tblPageLanguage on tblpage.pkID = tblPageLanguage.fkPageID
inner join tblPageType on tblPageType.pkID = tblPage.fkPageTypeID
where tblPageType.Name in ('NewsPage', 'ArticlePage')
and tblPageDefinition.Name = 'RelatedResources'
and tblPageLanguage.StopPublish > GETDATE()
order by tblPageLanguage.Name
Once I have both these data, I used cursor to loop through all the media items and find their reference from the second table and either print or insert into a third table. Am no SQL expert but managed to get this done. If any one needs I can give the full query.
Again all credits to Khurram Khan from this article https://world.optimizely.com/blogs/K-Khan-/Dates/2013/4/EpiServer-CMS-6-Useful-SQL-Queries/
Hello,
How can I find list of media items (say PDF's) that are not referenced anywhere (on any pages or blocks) through Database query?
Thanks.