[Haskell-cafe] Maybe a, The Rationale

Jules Bean jules at jellybean.co.uk
Wed May 14 09:49:30 EDT 2008


PR Stanley wrote:
> 
>>         Paul:   What is the underlying rationale for the Maybe data type?
>>
>> It is the equivalent of a database field that can be NULL.
> 
>         Paul: shock, horror! the null value or the absence of any value 
> denoted by null is not really in harmony with the relational model.

Ketil should have said:

It is the equivalent of the extremely common way of misusing NULL.

It doesn't bring in all the unpleasant baggage of three valued logic, 
but simple indicates an exceptional value. This use of NULL, very common 
in practical databases, frowned on by DB designers who understand about 
relational theory and normalisation, is prevalent precisely because 
common SQL dialects really make it a pain to invent your own datatypes, 
so it's hard to "add an exceptional value".

Practical programming needs a particular exceptional value very often 
indeed, to model things like optional parameters.

If common SQL dialects supported types like 'Maybe Int' natively, then 
NULL could be used much less.

Jules

PS Students of NULL and 3-valued logic will note that some of the 
problem therein can be studied in Haskell by comparing (==) and liftM2 
(==) as functions on Maybe Bool, or (>) vs liftM2 (>) on Maybe Int.



More information about the Haskell-Cafe mailing list