Re: bit field changes in 7.2.1

From: Kevin Brannen <kevinb(at)nurseamerica(dot)net>
To: pgsql-sql(at)postgresql(dot)org
Subject: Re: bit field changes in 7.2.1
Date: 2002-07-08 15:10:46
Message-ID: 3D29AB76.4000502@nurseamerica.net
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

Peter Eisentraut wrote:
> Kevin Brannen writes:
>
>
>>EXCEPT that now fails in 7.2.1 (I just upgraded this afternoon). It
>>forces me to use "b'000000'" instead of "b'0'::bit(6)".
>
>
> Which is a problem why?

Because in the real system, it will be b'0'::bit(64) or b'001::bit(64)
or etc. A bit nasty to type isn't it. :-) And of course that's for 1
table, in another place it be 40 bits wide, and in yet a third 96 bits
wide. So a simple mechanism to make it the correct size (for
comparisons) is very useful (to maintain my sanity. :-)

...
>
>
> In your case the solution is to type the six zeroes.
>
> The comment referred to cases where the results of computations needed to
> be forced to the right length, in which case you could use something like
>
> substring(computation() || b'000000' for 6)
>
> The question whether the constant should go before or after the
> computation, and whether it should be zeros or ones is a matter of taste,
> which is why an example has been omitted.
>

I'm still not sure I see the problem, but that doesn't really matter.
If that's the explanation, then *that* should have been included with
the note, IMO. OTOH, I still don't see where that helps me. How does
it give me a string of bits like b'0'::64 does, or b'1'::64 does? And
something like:

select substring(1 || b'000000' for 6);

assuming some computation returns a "1", tells me:

ERROR: Unable to identify an operator '||' for types 'integer' and
'bit' You will have to retype this query using an explicit cast

In an email, Chris suggested using rpad(), which looks good but doesn't
quite work, unless I'm overlooking something (if so, pleeeeease point it
out!). When I try it in my query I get:

select ... from ...
where sp.bitmask != cast(rpad('0',6,'0') as bit(6));

ERROR: Cannot cast type 'text' to 'bit'

<whine>
I guess my issue is that when some feature is taken out, there needs to
be another way to do it, AND it needs to be documented. Or just leave
it in and flag it as an extension.
</whine> ;-)

I guess I'll just have to read the bits in from the DB reference table,
then store and manipulate them all in Perl...sigh...

Thanks for the effort though!
Kevin

In response to

Browse pgsql-sql by date

  From Date Subject
Next Message Jean-Luc Lachance 2002-07-08 15:22:31 Re: Bad SUM result
Previous Message Narendra A 2002-07-08 14:28:50 is there a way to get hh:mm:ss given seconds