postgresql7.1
select cc.curriculum_id,
cc.name as curriculum_name,
substring(cc.description from 1 for :truncation_length) as curriculum_desc,
case when length(cc.description) > :truncation_length
then 1 else 0 end as curr_desc_trunc_p,
cc.sort_key as curriculum_sort_order,
ce.element_id,
ce.name as element_name,
substring(ce.description from 1 for :truncation_length) as element_desc,
case when length(ce.description) > :truncation_length
then 1 else 0 end as elem_desc_trunc_p,
ce.url as element_url,
ce.enabled_p as element_enabled_p,
ce.sort_key as element_sort_order,
author.first_names as author_first_names,
author.last_name as author_last_name,
author.email as author_email,
st.pretty_name as pretty_state,
st.short_name as state_short_name,
st.state_id,
st.hide_fields,
assignee.party_id as assignee_party_id,
assignee.email as assignee_email,
assignee.name as assignee_name
from cu_curriculums cc left outer join
cu_elements ce using (curriculum_id),
cc_users author,
workflow_cases cas left outer join
(select rpm.case_id,
p.party_id,
p.email,
acs_object__name(p.party_id) as name
from workflow_case_role_party_map rpm,
parties p
where rpm.role_id = :action_role
and p.party_id = rpm.party_id
) assignee using (case_id),
workflow_case_fsm cfsm,
workflow_fsm_states st
where cc.package_id = :package_id
and cfsm.case_id = cas.case_id
and st.state_id = cfsm.current_state
and cas.workflow_id = :workflow_id
and cas.object_id = cc.curriculum_id
$where_clauses
order by cc.sort_key,
ce.sort_key