Thursday, 6 June 2013

DQL (Document Query Language) for Documentum




DQL is Document Query Language for Documentum, which is a content management system used to create, manage, deliver, and archive all types of content. 


Some useful DQLs are :



·         Query to list objects having duplicate names
select object_name, count(*) FROM dm_document group by object_name having count(*) > 1 order by object_name

·         Query to find checked out documents
select * from dm_document where (r_lock_owner is not nullstring or r_lock_owner <> ' ')

·         Query to find documents without pdf rendition
select * from dm_document doc where not exists(select * from dmr_content where any parent_id=doc.r_object_id and full_format='pdf')

·         Query to find documents having file size more than 10 MB
select * from dm_document where r_full_content_size > 10000000;

·         Query to fetch specific number of documents
select * from dm_document enable (RETURN_TOP 50)

·         Query to fetch document owner name and number of document owns
select owner_name,count(*) from dm_document group by owner_name


·         Query to find all documents under a cabinet
select r_object_id, object_name from dm_document(all) where folder(’/[cabinet name]’, descend)

·         Query to find all documents which are modified from a particular date
select * from dm_document where r_modify_date > DATE('06/05/2013 00:00:00','MM/DD/YYYY hh:mm:ss') and r_modify_date < DATE('TODAY)


·         Query to find documents which are in workflows (active)
select r_object_id, object_name, title, owner_name,r_object_type, r_creation_date, r_modify_date, a_content_type from dm_document where r_object_id in(select r_component_id from dmi_package where r_workflow_id in (select r_object_id from dm_workflow where r_runtime_state = 1))

·         Query to find running workflow list
select distinct wi.r_object_id, wf.r_object_id as workflow_id, wf.object_name as workflow_name, wf.supervisor_name as supervisor_name,wi.r_performer_name as performer_name, wf.r_start_date as start_date from dm_workflow wf, dmi_package pkg, dmi_workitem wi where wf.r_runtime_state <2 and wf.r_object_id=pkg.r_workflow_id and wf.r_object_id=wi.r_workflow_id and pkg.r_workflow_id=wi.r_workflow_id and wi.r_runtime_state < 2 and any pkg.r_component_id in (select r_object_id from dm_document(all) where i_latest_flag=TRUE)

·         Query to find workflow id of a particular document
select r_workflow_id from dmi_package where any r_component_id ='[r_object_id]'



·         Query to find inbox details of an user
EXECUTE get_inbox WITH name='[user_name]'


·         Query to check registered types and the full-text user name
select distinct t.name, t.r_object_id, i.user_name from dm_type t,dmi_registry i where t.r_object_id = i.registered_id and i.user_name like '%fulltext%'

·         Query to verify that Content Server has loaded the correct full-text plugin

select r_object_id,object_name from dm_ftengine_config





·         Query to get all the users created from yesterday

Select user_name,user_os_name,user_address,user_group_name,r_modify_date from dm_user where r_modify_date >DATE('YESTERDAY')



·         Query to create user

create “dm_user” object
set client_capability=2,set default_folder=’’,
set home_docbase=’’,set user_address=’demo@test.com’,
set user_os_domain=’’,set user_name=’’,
set user_os_name=’’,set user_privileges=0,set user_source=’’


·         Query to retrieve group to which user has direct membership

Select group_name from dm_group where any users_names =’[user_name]’



·         Query to retrieve all groups to which user has membership

Select group_name from dm_group where any i_all_users_names =’[user_name]’




·         Query to get list of users and groups they directly belong to

select distinct ur.user_name,ur.user_os_name, gr.group_name FROM dm_user ur, dm_group gr where any gr.users_names = ur.user_name and r_is_group = 0 order by ur.user_name


·         Query to add user in group

alter group [group_name] add ‘user_name’

If wants to add more than one user then

alter group [group_name] add (select user_name from dm_user where user_name in (‘A’,’B’,’C’))


·         Query to drop user from a group

alter group [group_name] drop ‘user_name’


·         Query to get all the subgroups of a group

Select groups_names from dm_group where group_name=’[Group Name]’




·         Query to view details of active jobs

select r_object_id, object_name, method_name,start_date, expiration_date, run_interval, run_mode, a_last_invocation, a_last_completion, a_last_return_code as error_txt, a_next_invocation, a_iterations, a_current_status from dm_job where is_inactive=FALSE order by 2


·         Query to determine which jobs are currently running

select object_name, r_object_id from dm_job where a_special_app ='agentexec'


·         Query to get details virtual documents

select * from dm_document(all) where r_link_cnt>0


·         Query to get directly contained components of a virtual document

select r_object_id,r_object_type from dm_document(deleted) IN DOCUMENT ID ('[RootId]')


·         Query to get all contained components of a virtual document tree

select r_object_id,r_object_type from dm_document(deleted) IN DOCUMENT ID ('[RootId]') DESCEND




·         Query to execute SQL query

EXECUTE exec_sql WITH query=’sql_query’


·         Query to register a table from the underlying RDBMS with the Docbase

register table dm_dbo.testtable(id String(10),name String(35),address String(40))


·         Query to unregister a table from the underlying RDBMS with the Docbase

UNREGISTER TABLE testable


·         Query to get information of DAR installed in the Docbase

select * from dmc_dar


·         Query to get information of docbroker

execute list_targets


·         Query to retrieve the SQL translation of the last DQL statement

EXECUTE get_last_sql







Please feel free to contact me or just leave a comment if you want me to add any more DQL statements :-) :-). 
   
  

8 comments:

  1. Very Helpful, especially for Support Guys.
    Some suggestions/comments.

    1. Can you organize it as per topics [workflow, user/groups.. etc]
    2. Can you please add a DQL query template along with each query so that it can be added as favorite in DQL query tools like Samson or DQ-Man.

    e.g. For DQ-Man
    alter group {group_name} drop '{user_name}'

    For Samson
    to be added to samson.ini
    ->
    [QUERY_TOPIC_LIST]
    JOBS_METHOD = Jobs & Methods

    [JOBS_METHOD]
    QRY_JOBS_DETAILS=Query Currently Active Jobs

    [QRY_JOBS_DETAILS]
    QUERY=select * from dm_job where is_inactive=FALSE order by 3;

    ReplyDelete
  2. Hi Aniket,
    This is nice introdutory article.I also have installed D2 in my project.But i keep getting the below error in JMS.
    MSG: [DFC_BOF_CANNOT_FIND_OBJECT] Business object eu.c6.d2.api.methods.D2Method does not exist in docbase
    ERRORCODE: ff; NEXT: null
    at com.documentum.fc.client.impl.bof.registry.DocbaseModuleRegistry.lookup(DocbaseModuleRegistry.java:74)
    at com.documentum.fc.client.impl.bof.classmgmt.ModuleManager.lookupModuleMetadata(ModuleManager.java:202)
    at com.documentum.fc.client.impl.bof.classmgmt.ModuleManager.getModuleClass(ModuleManager.java:174)
    at com.documentum.fc.client.impl.bof.classmgmt.ModuleManager.newModule(ModuleManager.java:134)
    at com.documentum.fc.client.impl.bof.classmgmt.ModuleManager.newModule(ModuleManager.java:77)
    at com.documentum.fc.client.impl.bof.classmgmt.ModuleManager.newModule(ModuleManager.java:51)
    at com.documentum.fc.client.DfClient$ClientImpl.newModule(DfClient.java:460)
    at com.documentum.mthdservlet.ModuleLoader.getMethodObject(Unknown Source)
    at com.documentum.mthdservlet.DoMethod.getMethodObject(Unknown Source)
    at com.documentum.mthdservlet.DoMethod.invokeMethod(Unknown Source)
    at com.documentum.mthdservlet.DoMethod.doPost(Unknown Source)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.jboss.web.tomcat.filters.ReplyHeaderFilter.doFilter(ReplyHeaderFilter.java:96)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:235)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    at org.jboss.web.tomcat.security.SecurityAssociationValve.invoke(SecurityAssociationValve.java:190)
    at org.jboss.web.tomcat.security.JaccContextValve.invoke(JaccContextValve.java:92)


    Could you pls help.

    ReplyDelete
    Replies
    1. Hi,

      Looks like the D2 deployment was not completed correctly. You may be missing some Jar files.


      eu.c6.d2.api.methods.D2Method class is present inside of D2-API.jar

      Check whether this jar file is present in your JMS server.


      Thanks,
      Aniket

      Delete
  3. Hi Aniket,

    Very useful article.

    Lets assume I have table named xyz in documentum and i have column called frequency which can have value as monthly and quarterly. Now I have to write single DQL query to get records based on this column frequency. If frequency is monthly, then i need to fetch last 90 days of records and if frequency is quarterly then i need to fetch last 270 days of records.

    Thanks

    ReplyDelete
  4. Is it code a little complicated? I know companies who use virtual data rooms, as Ideals for example. And there is no problem. You need only one day to set the system for yourself and that`s all - all documentation is safely secured online.

    ReplyDelete
  5. Can anyone tell me query to concatenate two column values in DQL

    ReplyDelete
  6. Can you tell me a query to find all linked documents in a cabinet or folder

    ReplyDelete
  7. Thanks and I have a neat offer you: modern kitchen remodel

    ReplyDelete

Make life easier — Git automation with single command file

Make life easier — Git automation with single command file Posted on medium #makelifeeasier series - Automation of git related activity...