Is there a way other than SQL to cross-join two tables (Cartesian Product)?
I know that I can use SQL to cross-join two tables. However, that step is only a portion of my dataflow and I would like to use for the rest of the dataflow. Is there a way to cross-join in ETL or do I need to run my cross-join as a separate dataflow in SQL and use the output in my ETL?
Best Answers
-
Hi, @DougG ,
I did this recently. It isn't elegant, but it works just fine.
1) In each of the two tables you want to cross-join, add a whole number constant field using the "Add Constant" tiles. In both cases, assign some dummy value. It doesn't matter what value as long as you use the same value in both tiles.
2) Join the two datasets using your dummy constant fields
Note: this is equivalent to joining two tables in SQL using "on 1 = 1" in the join condition
1 -
I think you would be better off doing the SQL step, but I think it is possible in ETL as follows.
I utilized the tables from the cross join example on w3resource here
After adding these tables using excel upload to function as inputs, I used add constant to the company table of an ITEM_UNIT column containing string 'Pcs', to match the ITEM_UNIT field in the foods table.
I then did a full outer join on the ITEM_UNIT field.
I then did select columns to only return the desired fields of ITEM_NAME, ITEM_UNIT, COMPANY_NAME, and COMPANY_CITY.
This produced what I believe is the desired output.
2
Answers
-
I think you would be better off doing the SQL step, but I think it is possible in ETL as follows.
I utilized the tables from the cross join example on w3resource here
After adding these tables using excel upload to function as inputs, I used add constant to the company table of an ITEM_UNIT column containing string 'Pcs', to match the ITEM_UNIT field in the foods table.
I then did a full outer join on the ITEM_UNIT field.
I then did select columns to only return the desired fields of ITEM_NAME, ITEM_UNIT, COMPANY_NAME, and COMPANY_CITY.
This produced what I believe is the desired output.
**Say 'Thanks' by clicking the thumbs up in the post that helped you.
**Please mark the post that solves your problem as 'Accepted Solution'1 -
I think you would be better off doing the SQL step, but I think it is possible in ETL as follows.
I utilized the tables from the cross join example on w3resource here
After adding these tables using excel upload to function as inputs, I used add constant to the company table of an ITEM_UNIT column containing string 'Pcs', to match the ITEM_UNIT field in the foods table.
I then did a full outer join on the ITEM_UNIT field.
I then did select columns to only return the desired fields of ITEM_NAME, ITEM_UNIT, COMPANY_NAME, and COMPANY_CITY.
This produced what I believe is the desired output.
**Say 'Thanks' by clicking the thumbs up in the post that helped you.
**Please mark the post that solves your problem as 'Accepted Solution'0 -
I think you would be better off doing the SQL step, but I think it is possible in ETL as follows.
I utilized the tables from the cross join example on w3resource here
After adding these tables using excel upload to function as inputs, I used add constant to the company table of an ITEM_UNIT column containing string 'Pcs', to match the ITEM_UNIT field in the foods table.
I then did a full outer join on the ITEM_UNIT field.
I then did select columns to only return the desired fields of ITEM_NAME, ITEM_UNIT, COMPANY_NAME, and COMPANY_CITY.
This produced what I believe is the desired output.
**Say 'Thanks' by clicking the thumbs up in the post that helped you.
**Please mark the post that solves your problem as 'Accepted Solution'0 -
Hi, @DougG ,
I did this recently. It isn't elegant, but it works just fine.
1) In each of the two tables you want to cross-join, add a whole number constant field using the "Add Constant" tiles. In both cases, assign some dummy value. It doesn't matter what value as long as you use the same value in both tiles.
2) Join the two datasets using your dummy constant fields
Note: this is equivalent to joining two tables in SQL using "on 1 = 1" in the join condition
1 -
I think you would be better off doing the SQL step, but I think it is possible in ETL as follows.
I utilized the tables from the cross join example on w3resource here
After adding these tables using excel upload to function as inputs, I used add constant to the company table of an ITEM_UNIT column containing string 'Pcs', to match the ITEM_UNIT field in the foods table.
I then did a full outer join on the ITEM_UNIT field.
I then did select columns to only return the desired fields of ITEM_NAME, ITEM_UNIT, COMPANY_NAME, and COMPANY_CITY.
This produced what I believe is the desired output.
2 -
I think you would be better off doing the SQL step, but I think it is possible in ETL as follows.
I utilized the tables from the cross join example on w3resource here
After adding these tables using excel upload to function as inputs, I used add constant to the company table of an ITEM_UNIT column containing string 'Pcs', to match the ITEM_UNIT field in the foods table.
I then did a full outer join on the ITEM_UNIT field.
I then did select columns to only return the desired fields of ITEM_NAME, ITEM_UNIT, COMPANY_NAME, and COMPANY_CITY.
This produced what I believe is the desired output.
1
Categories
- All Categories
- 1.7K Product Ideas
- 1.7K Ideas Exchange
- 1.5K Connect
- 1.2K Connectors
- 292 Workbench
- 4 Cloud Amplifier
- 8 Federated
- 2.8K Transform
- 95 SQL DataFlows
- 600 Datasets
- 2.1K Magic ETL
- 3.7K Visualize
- 2.4K Charting
- 685 Beast Mode
- 43 App Studio
- 38 Variables
- 655 Automate
- 170 Apps
- 438 APIs & Domo Developer
- 42 Workflows
- 5 DomoAI
- 32 Predict
- 12 Jupyter Workspaces
- 20 R & Python Tiles
- 383 Distribute
- 110 Domo Everywhere
- 267 Scheduled Reports
- 6 Software Integrations
- 111 Manage
- 108 Governance & Security
- 8 Domo University
- 25 Product Releases
- Community Forums
- 39 Getting Started
- 29 Community Member Introductions
- 98 Community Announcements
- Domo Community Gallery
- 4.8K Archive