I don’t know about y’all but I have to work with dirty data. A lot.
data:image/s3,"s3://crabby-images/91ac7/91ac7a78ee3b71121e46a1922defba48780a49fe" alt=""
When you’re working with dirty data, one of the many things you can run into is that when you try to divide two numbers – you can cause a huge error because you tried to perform a mathematical no-no – dividing by zero.
Today, in Snowflake, we’re going to talk through a few ways to get around that particular error.
First, we should create a table and insert some data to play with.
CREATE OR REPLACE TABLE public.DivideByZero
(Number1 number(10,0) NOT NULL,
Number2 number(10,0) NOT NULL);
INSERT INTO public.DivideByZero
SELECT 1, 3 UNION ALL
SELECT 4, 2 UNION ALL
SELECT 8, 0;
When we try the simple formula that we’re all used to, we get Mr. Grumpy Error:
data:image/s3,"s3://crabby-images/8d0ad/8d0ad7b321019aab45d40c1e1dba41b50f06f17f" alt=""
But now, let’s try it with a function in Snowflake – Div0.
It truly is used as a function with all of the data points pushed in as parameters.
data:image/s3,"s3://crabby-images/f3017/f3017a8f8a96eb1f537e5441e8157be6d9981751" alt=""
Notice that the Result column returns a 0 if Number2 – in this case – has a zero.
But what if…
data:image/s3,"s3://crabby-images/f54ae/f54ae718f63e49754ce6b00f4eca698f0110d247" alt=""
Sometimes, you’ll have even more garbage-y data by some poor soul having placed a NULL in column Number2. I’ve changed the Number2 column to allow NULLs – in this case – and now we get to insert some data.
INSERT INTO public.DivideByZero
SELECT 6, NULL;
If I run the same query as above, I get the following:
data:image/s3,"s3://crabby-images/45bc6/45bc6642f64e62417a759a3e1c12fd75f81b5e83" alt=""
At least the Div0 function didn’t allow the query to break – thank goodness. Sometimes our business partners will not find the NULL to be acceptable here, but not this time! Do I have to pull out my friend the CASE statement and wrap all kinds of business logic in here?
Not this time! Div0NULL to the rescue!
data:image/s3,"s3://crabby-images/9883a/9883aee8b26d387f1783e58c2e617b3a2752876f" alt=""
But, notice the most important thing here! No freakin’ errors!
data:image/s3,"s3://crabby-images/06d11/06d115f014135d6c5ac98d156cf8d84b3919dce3" alt=""
Which one of the above functions should you use? As always, it depends. If NULLs matter to you and your business partners – use the function that gives you the data you need to display. But always, use one of these functions, my friends – for safety’s sake.
With that, enjoy one of my favorite songs from Offspring about one of my favorite topics (at least for this week). Until next time my friends!