• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 1953
  • Last Modified:

Query contains an outer-join request that is not permitted - Sybase to SQL Server conversion

Hi guys!

Doing a project converting a Sybase ASE 12.0 database to SQL Server 2000.

Pretty much everything converts straight away with little syntax changes, but hit a bit of a stumbling block on this one:

SELECT  
 c.id,   c.centre_id,   c.client_code,   c.case_open,   c.open_by,   c.case_worker,   c.close_date,   c.closed_by,   c.closed_reason,  
 c.presenting_issue,   c.referral_src,   c.service_needed,   c.identity_proof,   c.referral_note,   centre.name as centre_name,  
 c.achieve_level,   c.graduated,   c.agree_case_mgnt,   c.referral_contact,   c.referral_address,   c.referral_phone,  
 cs.centre_id as user_logon_centre_id,   c.consent,   c.income_source,   c.living_situation, ref_no,  
 isNull(s.start_date, null) as last_assistance_date
 FROM
client_case c, centre, case_centre_share cs, service s, service_client sc, service_item si  
 WHERE
c.centre_id *= centre.id  
 AND   c.id *= cs.case_id  
 AND   c.id *= sc.case_id  
 AND       sc.service_id *= s.id  
 AND       s.service_item *= si.id  
 AND       sc.id = (select max(id) from service_client sc2 where sc2.case_id = sc.case_id)  
 AND       s.method = 'AE'  
ORDER BY c.id desc

The SQL runs fine in Sybase but when I try to run it against a SQL Server database I get
"Server: Msg 301, Level 16, State 1, Line 1
Query contains an outer-join request that is not permitted."

Now, I am aware that I SQL Server is using different sort of sytanx to create joins (LEFT OUTER, RIGHT OUTER etc) but the manual says that it would support a (*=) type of synax well. Could anyone tell me where the "non permitted" outer join is in my SQL?.. or even better.. what the proper syntax for SQL Server should be

Thanks!
P.S. I'll be online all day and will test any suggested SQLs against my database right away!

0
vlad_l
Asked:
vlad_l
  • 2
1 Solution
 
doryllisCommented:
My understanding on this is that order matters somewhat.  Try using this syntax for the SQL Server.

SELECT  
 c.id,   c.centre_id,   c.client_code,   c.case_open,   c.open_by,   c.case_worker,   c.close_date,   c.closed_by,   c.closed_reason,  
 c.presenting_issue,   c.referral_src,   c.service_needed,   c.identity_proof,   c.referral_note,   centre.name as centre_name,  
 c.achieve_level,   c.graduated,   c.agree_case_mgnt,   c.referral_contact,   c.referral_address,   c.referral_phone,  
 cs.centre_id as user_logon_centre_id,   c.consent,   c.income_source,   c.living_situation, ref_no,  
 isNull(s.start_date, null) as last_assistance_date
 FROM
 client_case c
  left outer join centre
    on c.centre_id = centre.id
  left outer join case_centre_share cs
    on  c.id = cs.case_id    
  left outer join service_client sc
    on   c.id = sc.case_id
  left outer join service s
    on   sc.service_id = s.id
  left outer join service_item si
    on s.service_item = si.id  
 WHERE
      sc.id = (select max(id) from service_client sc2 where sc2.case_id = sc.case_id)   AND      s.method = 'AE'  
ORDER BY c.id desc
0
 
vlad_lAuthor Commented:
thanks a lot! it works just fine! :-)
0
 
doryllisCommented:
Glad I could help.  
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Easily Design & Build Your Next Website

Squarespace’s all-in-one platform gives you everything you need to express yourself creatively online, whether it is with a domain, website, or online store. Get started with your free trial today, and when ready, take 10% off your first purchase with offer code 'EXPERTS'.

  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now