SQL - join where a column is between a number range
data:image/s3,"s3://crabby-images/70474/70474220db456d0d1e80f61737c31773b5bd6177" alt="Jbrorby"
data:image/s3,"s3://crabby-images/4d5c6/4d5c66bf3a6b245d59b00eee333e22623ee584d6" alt=""
Hello,
I cannot for the life of me figure out why this "where" clause is giving me troubles, I have used this logic a thousand times with no problems.
The problem is coming on my join of c to a. Specifically, it seems to happen with my "where c.result_code is greater or equal to 9.5 and c.result_code is less than or equal to 11.99
When I run this, it returns 0 rows for me, which is not correct. there are many rows that fall between 11.99 and 9.5
If I remove either the greater equal to 9.5 or the less than or equal 11.99, i get results
The only thing I can thing of is that this column is a char column? (char(5), null) and it also sometimes stores letters? other than that I have no idea
select a.product_id,
a.unit_number,
b.status_code,
c.test_code,
c.result_code
From product_header a
left join product_latest_status b
on a.product_id = b.product_id
inner join lab_unit_test_result c
on a.unit_number = c.unit_number and (c.test_code = 'CCPQ' and (c.result_code >= '9.5' and c.result_code <= '11.99'))
Best Answer
-
If it is a char column, you can't do a numeric type between statement. You would need to convert your column to numeric and then either write it as
(c.result_code >= 9.5 and c.result_code <= 11.99)
or
(c.result_code BETWEEN 9.5' and 11.99)
If result_code contains non-numeric characters, you would need to create another column that only has the numeric values from result_code and use that column in your where clause
**Check out my Domo Tips & Tricks Videos
**Make sure toany users posts that helped you.
**Please mark as accepted the ones who solved your issue.1
Answers
-
If it is a char column, you can't do a numeric type between statement. You would need to convert your column to numeric and then either write it as
(c.result_code >= 9.5 and c.result_code <= 11.99)
or
(c.result_code BETWEEN 9.5' and 11.99)
If result_code contains non-numeric characters, you would need to create another column that only has the numeric values from result_code and use that column in your where clause
**Check out my Domo Tips & Tricks Videos
**Make sure toany users posts that helped you.
**Please mark as accepted the ones who solved your issue.1 -
Thanks, this was helpful. I did try_cast [column] as float between 9.5 and 11.99 and it is working now
First i tried to do it as numeric but for some reason it would include 12.0-12.2 in the return
1
Categories
- All Categories
- 1.9K Product Ideas
- 1.9K Ideas Exchange
- 1.6K Connect
- 1.3K Connectors
- 305 Workbench
- 6 Cloud Amplifier
- 9 Federated
- 3K Transform
- 107 SQL DataFlows
- 648 Datasets
- 2.2K Magic ETL
- 4K Visualize
- 2.5K Charting
- 774 Beast Mode
- 75 App Studio
- 43 Variables
- 733 Automate
- 186 Apps
- 471 APIs & Domo Developer
- 62 Workflows
- 14 DomoAI
- 40 Predict
- 17 Jupyter Workspaces
- 23 R & Python Tiles
- 403 Distribute
- 117 Domo Everywhere
- 277 Scheduled Reports
- 9 Software Integrations
- 137 Manage
- 134 Governance & Security
- 8 Domo Community Gallery
- 44 Product Releases
- 12 Domo University
- 5.4K Community Forums
- 40 Getting Started
- 30 Community Member Introductions
- 113 Community Announcements
- 4.8K Archive