Thread: create operator problem

create operator problem

From
"Vazsonyi Peter[ke]"
Date:
Hello!

I use an external function in postgres and here i try create operator for
like with regional character support ::

-----< Cut begin
create function mylike(text,text) returns bool
as '/home/vip/neko/tudakozo/comp.so' language 'c';
CREATE
select mylike('Jeno','Jen�'),mylike('aJenO','Jen�'),mylike('fJeNof','Jen�'),
       mylike('JEn�ke','Jen�');
mylike|mylike|mylike|mylike
------+------+------+------
t     |t     |t     |t
(1 row)

select 'f:', mylike('asd','fds');
?column?|mylike
--------+------
f:      |f
(1 row)

-- It works

drop operator ~~ (text,text);
DROP
create operator ~~ (leftarg=text,rightarg=text,procedure=mylike);
CREATE
select 'this will be true'::text ~~ 'true';
?column?
--------
f
(1 row)
-- it seems not ;(
-----< Cut end

I'm not a realy postgres guru, but whith postgres 6.2 can i use this
function as operator too. If that was a bug, this letter is a bug report,
but if it isn't please help me!  The used postgres's vn: 6.3-2, it runs on a
linux (RH4.2;i386 + updates)

sprintf         ("`-''-/").___..--''"`-._            Error In
("%|s",          `6_ 6  )   `-.  (     ).`-.__.`)    Loading Object
"Petike"         (_Y_.)'  ._   )  `._ `. ``-..-'     line:3
/* Neko */     _..`--'_..-_/  /--'_.' ,'             Before /*Neko*/
 );           (il),-''  (li),'  ((!.-'     see: http://lsc.kva.hu


Re: [HACKERS] create operator problem

From
Tom Ivar Helbekkmo
Date:
"Vazsonyi Peter[ke]" <neko@kornel.szif.hu> writes:

> drop operator ~~ (text,text);
> DROP
> create operator ~~ (leftarg=text,rightarg=text,procedure=mylike);
> CREATE
> select 'this will be true'::text ~~ 'true';
> ?column?
> --------
> f
> (1 row)
> -- it seems not ;(

I got bitten by this, too.  There's special handling of ~~ hardcoded
into the parser, which expects that it implements the vanilla flavor
of likeness testing.  It has to do with enabling the use of indices to
speed up the matching.  Bottom line: you can't redefine it.

-tih
--
Popularity is the hallmark of mediocrity.  --Niles Crane, "Frasier"

Re: [HACKERS] create operator problem

From
Bruce Momjian
Date:
>
> Hello!
>
> I use an external function in postgres and here i try create operator for
> like with regional character support ::
>
> -----< Cut begin
> create function mylike(text,text) returns bool
> as '/home/vip/neko/tudakozo/comp.so' language 'c';
> CREATE
> select mylike('Jeno','Jen�'),mylike('aJenO','Jen�'),mylike('fJeNof','Jen�'),
>        mylike('JEn�ke','Jen�');
> mylike|mylike|mylike|mylike
> ------+------+------+------
> t     |t     |t     |t
> (1 row)
>
> select 'f:', mylike('asd','fds');
> ?column?|mylike
> --------+------
> f:      |f
> (1 row)
>
> -- It works
>
> drop operator ~~ (text,text);
> DROP
> create operator ~~ (leftarg=text,rightarg=text,procedure=mylike);
> CREATE
> select 'this will be true'::text ~~ 'true';
> ?column?
> --------
> f
> (1 row)
> -- it seems not ;(
> -----< Cut end
>
> I'm not a realy postgres guru, but whith postgres 6.2 can i use this
> function as operator too. If that was a bug, this letter is a bug report,
> but if it isn't please help me!  The used postgres's vn: 6.3-2, it runs on a
> linux (RH4.2;i386 + updates)

We overload ~~ to allow indexing of LIKE operations.  Sorry.  I will add
something to error on redefine of ~~.

--
Bruce Momjian                          |  830 Blythe Avenue
maillist@candle.pha.pa.us              |  Drexel Hill, Pennsylvania 19026
  +  If your life is a hard drive,     |  (610) 353-9879(w)
  +  Christ can be your backup.        |  (610) 853-3000(h)