diff options
author | Mike Bayer <mike_mp@zzzcomputing.com> | 2008-09-08 03:51:47 +0000 |
---|---|---|
committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2008-09-08 03:51:47 +0000 |
commit | 58c5bb7fc104da26cd1797d9680a810a3b79ab0a (patch) | |
tree | db54cd7731a7a670b616136ff034b6a0f0b5d1b6 /lib/sqlalchemy/sql/functions.py | |
parent | cc0dcca7b4bf3ad05630c92012be715c6e515aaf (diff) | |
download | sqlalchemy-58c5bb7fc104da26cd1797d9680a810a3b79ab0a.tar.gz |
- Added func.min(), func.max(), func.sum() as "generic functions",
which basically allows for their return type to be determined
automatically. Helps with dates on SQLite, decimal types,
others. [ticket:1160]
- added decimal.Decimal as an "auto-detect" type; bind parameters
and generic functions will set their type to Numeric when a
Decimal is used.
Diffstat (limited to 'lib/sqlalchemy/sql/functions.py')
-rw-r--r-- | lib/sqlalchemy/sql/functions.py | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/lib/sqlalchemy/sql/functions.py b/lib/sqlalchemy/sql/functions.py index 7fce3b95b..c7a0f142d 100644 --- a/lib/sqlalchemy/sql/functions.py +++ b/lib/sqlalchemy/sql/functions.py @@ -36,12 +36,25 @@ class AnsiFunction(GenericFunction): def __init__(self, **kwargs): GenericFunction.__init__(self, **kwargs) - -class coalesce(GenericFunction): +class ReturnTypeFromArgs(GenericFunction): + """Define a function whose return type is the same as its arguments.""" + def __init__(self, *args, **kwargs): kwargs.setdefault('type_', _type_from_args(args)) GenericFunction.__init__(self, args=args, **kwargs) +class coalesce(ReturnTypeFromArgs): + pass + +class max(ReturnTypeFromArgs): + pass + +class min(ReturnTypeFromArgs): + pass + +class sum(ReturnTypeFromArgs): + pass + class now(GenericFunction): __return_type__ = sqltypes.DateTime |