On 09/05/11 02:07, Marco Spiga wrote:
> The following bug has been logged online:
> Bug reference: 6015
> Logged by: Marco Spiga
> Email address: ctxspi(at)gmail(dot)com
> PostgreSQL version: 8.3.12
> Operating system: Ubuntu Linux on kernel version 126.96.36.199
> Description: to_hex and negative integer
> First, thank for your excellent software.
> My question is:
> Why when I try: SELECT to_hex(-1)
> it give me a strange result: ffffffff
That's not a bug, it's exactly what I'd expect to happen.
What did you expect to get instead? -0x01 ? 0xffff? 0xffffffffffffffff?
Don't understand why the result is the expected one by most people? Read
... so you understand how signed numbers are represented internally by
most binary computer systems.
As it happens, the real problem with to_hex() on a negative number is
that the result doesn't make much sense unless you know the size of the
representation. For example, ffff can mean 65535 if interpreted as an
unsigned 16-bit interger, or can mean -1 if interpreted as a signed
16-bit int. ffffffff can mean 4294967295 if interpreted as an unsigned
32 bit int or as a signed 64-bit integer, but is -1 if interpreted as a
signed 32-bit integer.
Essentially, to_hex takes the _size_ of the input datum as an implicit
input. This means that you should NOT USE IT in any context where you do
not know the data type of the input, because its results vary in meaning
depending on what you feed into it.
classads=> select to_hex(-1 :: integer);
classads=> select to_hex(-1 :: bigint);
In response to
pgsql-bugs by date
|Next:||From: Rodriguez Fernando||Date: 2011-05-09 11:36:53|
|Subject: column check mistake or not?|
|Previous:||From: Marco Spiga||Date: 2011-05-08 18:07:41|
|Subject: BUG #6015: to_hex and negative integer|