Skip site navigation (1) Skip section navigation (2)

Re: dividing money by money

From: "Kevin Grittner" <Kevin(dot)Grittner(at)wicourts(dot)gov>
To: "Chris Travers" <chris(at)metatrontech(dot)com>
Cc: <pgsql-bugs(at)postgresql(dot)org>
Subject: Re: dividing money by money
Date: 2010-03-31 14:07:49
Message-ID: (view raw, whole thread or download thread mbox)
Lists: pgsql-bugs
Chris Travers <chris(at)metatrontech(dot)com> wrote:
> Just thinking about the more general problem and how things could
> be handled more gracefully...
Sure, but in the meantime, consider:
test=# select '12'::money * '2'::numeric;
(1 row)

test=# select '24'::money / '2'::numeric;
(1 row)

test=# select '24'::money / '12'::money;
ERROR:  operator does not exist: money / money
LINE 1: select '24'::money / '12'::money;
HINT:  No operator matches the given name and argument type(s). You
might need to add explicit type casts.
So we support:
a * b = c
c / b = a
but don't even *think* about c / a = b ???
The OP just wanted to add some symmetry to this, so that the
existing class could handle a not-uncommon use case more easily.  As
far as I can see, the implementation of this operator could convert
two int64 values to numeric values and perform numeric division to
get the result.  (I was going to mark the TODO as an easy one.)  I
don't see how this change would affect what you want to do, one way
or the other.

In response to


pgsql-bugs by date

Next:From: Tom LaneDate: 2010-03-31 14:35:17
Subject: Re: BUG #5400: Columns count mismatch in RULE with subquery
Previous:From: Ing . Marcos Luís Ortíz ValmasedaDate: 2010-03-31 13:31:15

Privacy Policy | About PostgreSQL
Copyright © 1996-2017 The PostgreSQL Global Development Group