I’m a SQL noob, and I need a little bit of help understanding the big picture of if it is possible, and if so how to go about filtering a result set based on the return value of a function which is passed one of the fields of the record.
Let’s say I have a table called “Numbers” with just one field: “Value”.
How could I correctly specify the following “pseudo-sql”?:
SELECT Value FROM numbers WHERE IsPrime(Value)=true
Can I accomplish such a thing, and if so, where/how do I put/store “IsPrime”?
I’m using MySQL.
I agree with extraneon that it’s usually better to store this value in the database rather than compute it in the where clause. This way you can compute it once per row and index the data for faster performance.
As long as you are on MySQL 5.x, I would recommend a stored function, as opposed to a UDF. You can add an
IS_PRIMEcolumn of typeTINYINTto your DB, add an index on that column, then use the stored function to calculate the value at insert time. You can even calculate theIS_PRIMEvalue using a before insert trigger if you don’t want to change the insert code.The stored function would look something like this: