| From: | SAKAIDA <sakaida(at)psn(dot)co(dot)jp> |
|---|---|
| To: | pgsql-interfaces(at)postgresql(dot)org |
| Subject: | String array type in ecpg. |
| Date: | 2001-05-26 13:08:23 |
| Message-ID: | 20010526210752.5CBA.SAKAIDA@psn.co.jp |
| Views: | Whole Thread | Raw Message | Download mbox | Resend email |
| Thread: | |
| Lists: | pgsql-interfaces |
Hi,
String array type in ecpg is strange.
> pgbash
pgbash> create table test_array(code varchar(4), name text[3]);
pgbash> insert into test_array values('c01','{"n01","n02","n03"}');
pgbash> select * from test_array;
code|name
----+-------------------
c01 |{"n01","n02","n03"}
(1 row)
--------------------( ECPG program)------------------------
# include <stdio.h>
exec sql include sqlca;
main()
{
exec sql begin declare section;
char code[5];
char name[256];
exec sql end declare section;
exec sql connect to admin user admin;
exec sql declare cur cursor for select * from test_array;
exec sql open cur;
while(1)
{
exec sql fetch cur into :code, :name;
if( sqlca.sqlcode == 100 ) break;
printf("# code=(%s) name=(%s)\n", code, name );
}
exec sql close cur;
}
------------------------------------------------------------
Results are as follows.
# code=("n02","n03"}) name=({"n01","n02","n03"})
Segmentation fault (core dumped)
Here is the patch which corrects this bug.
*** postgresql-7.1.2/src/interfaces/ecpg/lib/data.c.orig Sat May 26 20:47:53 2001
--- postgresql-7.1.2/src/interfaces/ecpg/lib/data.c Sat May 26 21:33:10 2001
***************
*** 337,342 ****
--- 337,344 ----
return (false);
break;
}
+ if (type == ECPGt_char || type == ECPGt_unsigned_char || type == ECPGt_varchar)
+ break;
if (isarray)
{
bool string = false;
--
SAKAIDA Masaaki
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Tulassay Zsolt | 2001-05-27 14:56:03 | large objects, visual basic, ADO |
| Previous Message | Randall Jonasz | 2001-05-25 23:43:27 | Re: C++ usage question |