Advent of Code is back! Unwrap daily challenges to sharpen your Alteryx skills and earn badges along the way! Learn more now.
Community is experiencing an influx of spam. As we work toward a solution, please use the 'Notify Moderator' option on the ellipsis menu to flag inappropriate posts.

Alteryx Designer Desktop Discussions

Find answers, ask questions, and share expertise about Alteryx Designer Desktop and Intelligence Suite.
SOLVED

TABLEAU CUSTOM SQL NOT WORKING IN ALTERYX

Guansang
5 - Atom

Hi,

 

I am not well versed with SQL.  The SQL below is for Tableau Postgres.  In Tableau's custom SQL, it works.  When I transfer it to Alteryx input, the SQL runs but the output is not equal to Tableau's.  I do not know if "Union ALL" has something to do with it and how to change the SQL below to work in Alteryx. 

 

SELECT

CAST ('Workbook' as varchar) as object, --Set to either workbook or datasource

p.name as project, --project where item sits

s.name as Site_name,

w.name as Object_Name, --Workbook or datasource name

w.revision as Version, --Version where applicable

CAST ('User' as varchar) as Grantee_type, --means permission given to user or inherited from group

su.name as User_or_group_Name, --User name

c.name as Permission_type, --Type of permission

CASE

WHEN ngp.permission = 1 THEN 'Allow by Group'

WHEN ngp.permission = 2 THEN 'Deny by Group'

WHEN ngp.permission = 3 THEN 'Allow to User'

WHEN ngp.permission = 4 THEN 'Deny to User'

END as Granted_Denied --This shows if restriction is applied to user or group

FROM public.next_gen_permissions ngp

JOIN public.workbooks w ON ngp.authorizable_id=w.id

JOIN public.users u ON ngp.grantee_id=u.id

JOIN public.system_users su ON u.system_user_id=su.id

JOIN public.capabilities c ON ngp.capability_id=c.id

JOIN public.projects p ON w.project_id=p.id

JOIN public.sites s ON w.site_id=s.id

WHERE ngp.authorizable_type = 'Workbook'

AND ngp.grantee_type = 'User'

AND su.name <> 'guest'

UNION ALL

--Workbook Group Level Permissions

SELECT

CAST ('Workbook' as varchar) as object,

p.name as project,

s.name as Site_name,

w.name as Object_Name,

w.revision as Version,

CAST ('Group' as varchar) as Grantee_type,

u.name as User_or_group_Name,

c.name as Permission_type,

CASE

WHEN ngp.permission = 1 THEN 'Allow by Group'

WHEN ngp.permission = 2 THEN 'Deny by Group'

WHEN ngp.permission = 3 THEN 'Allow to User'

WHEN ngp.permission = 4 THEN 'Deny to User'

END as Granted_Denied

FROM public.next_gen_permissions ngp

JOIN public.workbooks w ON ngp.authorizable_id=w.id

JOIN public.groups u ON ngp.grantee_id=u.id

JOIN public.capabilities c ON ngp.capability_id=c.id

JOIN public.projects p ON w.project_id=p.id

JOIN public.sites s ON w.site_id=s.id

WHERE ngp.authorizable_type = 'Workbook'

AND ngp.grantee_type = 'Group'

UNION ALL

--Datasource User Level Permissions

SELECT

CAST ('Datasource' as varchar) as object,

p.name as project,

s.name as Site_name,

ds.name as Object_Name,

ds.revision as Version,

CAST ('User' as varchar) as Grantee_type,

su.name as User_or_group_Name,

c.name as Permission_type,

CASE

WHEN ngp.permission = 1 THEN 'Allow by Group'

WHEN ngp.permission = 2 THEN 'Deny by Group'

WHEN ngp.permission = 3 THEN 'Allow to User'

WHEN ngp.permission = 4 THEN 'Deny to User'

END as Granted_Denied

FROM public.next_gen_permissions ngp

JOIN public.datasources ds ON ngp.authorizable_id=ds.id

JOIN public.projects p ON ds.project_id=p.id

JOIN public.users u ON ngp.grantee_id=u.id

JOIN public.system_users su ON u.system_user_id=su.id

JOIN public.capabilities c ON ngp.capability_id=c.id

JOIN public.sites s on ds.site_id=s.id

WHERE ngp.authorizable_type = 'Datasource'

AND ngp.grantee_type = 'User'

AND su.name <> 'guest'

UNION ALL

--Datasource Group Level Permissions

SELECT

CAST ('Datasource' as varchar) as object,

p.name as project,

s.name as Site_name,

ds.name as Object_Name,

ds.revision as Version,

CAST ('Group' as varchar) as Grantee_type,

g.name as User_or_group_Name,

c.name as Permission_type,

CASE

WHEN ngp.permission = 1 THEN 'Allow by Group'

WHEN ngp.permission = 2 THEN 'Deny by Group'

WHEN ngp.permission = 3 THEN 'Allow to User'

WHEN ngp.permission = 4 THEN 'Deny to User'

END as Granted_Denied

FROM public.next_gen_permissions ngp

JOIN public.datasources ds ON ngp.authorizable_id=ds.id

JOIN public.projects p ON ds.project_id=p.id

JOIN public.groups g ON ngp.grantee_id=g.id

JOIN public.capabilities c ON ngp.capability_id=c.id

JOIN public.sites s on ds.site_id=s.id

WHERE ngp.authorizable_type = 'Datasource'

AND ngp.grantee_type = 'Group'

4 REPLIES 4
AbhilashR
15 - Aurora
15 - Aurora

Hi @Guansang, theoretically a SQL that runs in Tableau should give you the same result in Alteryx. Could you further elaborate on the issue you are running into?

You may have already checked this, but can you confirm if the environment your Alteryx Input tool is connecting to is the same as Tableau?

JonMcMillin
8 - Asteroid

Hi @Guansang 

 

You might want to check if you are using the same user between the Tableau SQL, and the Alteryx. If you are using different users, you will need to confirm if both users have the same levels of access.

Guansang
5 - Atom

I appreciate the help.  Let me make sure the environment is the same.  

Guansang
5 - Atom

I appreciate the help.  Let me make sure the environment is the same.  

Labels