1 <!-- doc/src/sgml/ecpg.sgml -->
4 <title><application>ECPG
</application> — Embedded
<acronym>SQL
</acronym> in C
</title>
6 <indexterm zone=
"ecpg"><primary>embedded SQL
</primary><secondary>in C
</secondary></indexterm>
7 <indexterm zone=
"ecpg"><primary>C
</primary></indexterm>
8 <indexterm zone=
"ecpg"><primary>ECPG
</primary></indexterm>
11 This chapter describes the embedded
<acronym>SQL
</acronym> package
12 for
<productname>PostgreSQL
</productname>. It was written by
13 Linus Tolke (
<email>linus@epact.se
</email>) and Michael Meskes
14 (
<email>meskes@postgresql.org
</email>). Originally it was written to work with
15 <acronym>C
</acronym>. It also works with
<acronym>C++
</acronym>, but
16 it does not recognize all
<acronym>C++
</acronym> constructs yet.
20 This documentation is quite incomplete. But since this
21 interface is standardized, additional information can be found in
22 many resources about SQL.
25 <sect1 id=
"ecpg-concept">
26 <title>The Concept
</title>
29 An embedded SQL program consists of code written in an ordinary
30 programming language, in this case C, mixed with SQL commands in
31 specially marked sections. To build the program, the source code (
<filename>*.pgc
</filename>)
32 is first passed through the embedded SQL preprocessor, which converts it
33 to an ordinary C program (
<filename>*.c
</filename>), and afterwards it can be processed by a C
34 compiler. (For details about the compiling and linking see
<xref linkend=
"ecpg-process"/>.)
35 Converted ECPG applications call functions in the libpq library
36 through the embedded SQL library (ecpglib), and communicate with
37 the PostgreSQL server using the normal frontend-backend protocol.
41 Embedded
<acronym>SQL
</acronym> has advantages over other methods
42 for handling
<acronym>SQL
</acronym> commands from C code. First, it
43 takes care of the tedious passing of information to and from
44 variables in your
<acronym>C
</acronym> program. Second, the SQL
45 code in the program is checked at build time for syntactical
46 correctness. Third, embedded
<acronym>SQL
</acronym> in C is
47 specified in the
<acronym>SQL
</acronym> standard and supported by
48 many other
<acronym>SQL
</acronym> database systems. The
49 <productname>PostgreSQL
</productname> implementation is designed to match this
50 standard as much as possible, and it is usually possible to port
51 embedded
<acronym>SQL
</acronym> programs written for other SQL
52 databases to
<productname>PostgreSQL
</productname> with relative
57 As already stated, programs written for the embedded
58 <acronym>SQL
</acronym> interface are normal C programs with special
59 code inserted to perform database-related actions. This special
60 code always has the form:
64 These statements syntactically take the place of a C statement.
65 Depending on the particular statement, they can appear at the
66 global level or within a function.
71 <acronym>SQL
</acronym> statements follow the case-sensitivity rules of
72 normal
<acronym>SQL
</acronym> code, and not those of C. Also they allow nested
73 C-style comments as per the SQL standard. The C part of the
74 program, however, follows the C standard of not accepting nested comments.
75 Embedded
<acronym>SQL
</acronym> statements likewise use SQL rules, not
76 C rules, for parsing quoted strings and identifiers.
77 (See
<xref linkend=
"sql-syntax-strings"/> and
78 <xref linkend=
"sql-syntax-identifiers"/> respectively. Note that
79 ECPG assumes that
<varname>standard_conforming_strings
</varname>
80 is
<literal>on
</literal>.)
81 Of course, the C part of the program follows C quoting rules.
85 The following sections explain all the embedded SQL statements.
89 <sect1 id=
"ecpg-connect">
90 <title>Managing Database Connections
</title>
93 This section describes how to open, close, and switch database
97 <sect2 id=
"ecpg-connecting">
98 <title>Connecting to the Database Server
</title>
101 One connects to a database using the following statement:
103 EXEC SQL CONNECT TO
<replaceable>target
</replaceable> <optional>AS
<replaceable>connection-name
</replaceable></optional> <optional>USER
<replaceable>user-name
</replaceable></optional>;
105 The
<replaceable>target
</replaceable> can be specified in the
111 <literal><replaceable>dbname
</replaceable><optional>@
<replaceable>hostname
</replaceable></optional><optional>:
<replaceable>port
</replaceable></optional></literal>
117 <literal>tcp:postgresql://
<replaceable>hostname
</replaceable><optional>:
<replaceable>port
</replaceable></optional><optional>/
<replaceable>dbname
</replaceable></optional><optional>?
<replaceable>options
</replaceable></optional></literal>
123 <literal>unix:postgresql://localhost
<optional>:
<replaceable>port
</replaceable></optional><optional>/
<replaceable>dbname
</replaceable></optional><optional>?
<replaceable>options
</replaceable></optional></literal>
129 an SQL string literal containing one of the above forms
135 a reference to a character variable containing one of the above forms (see examples)
141 <literal>DEFAULT
</literal>
146 The connection target
<literal>DEFAULT
</literal> initiates a connection
147 to the default database under the default user name. No separate
148 user name or connection name can be specified in that case.
152 If you specify the connection target directly (that is, not as a string
153 literal or variable reference), then the components of the target are
154 passed through normal SQL parsing; this means that, for example,
155 the
<replaceable>hostname
</replaceable> must look like one or more SQL
156 identifiers separated by dots, and those identifiers will be
157 case-folded unless double-quoted. Values of
158 any
<replaceable>options
</replaceable> must be SQL identifiers,
159 integers, or variable references. Of course, you can put nearly
160 anything into an SQL identifier by double-quoting it.
161 In practice, it is probably less error-prone to use a (single-quoted)
162 string literal or a variable reference than to write the connection
167 There are also different ways to specify the user name:
172 <literal><replaceable>username
</replaceable></literal>
178 <literal><replaceable>username
</replaceable>/
<replaceable>password
</replaceable></literal>
184 <literal><replaceable>username
</replaceable> IDENTIFIED BY
<replaceable>password
</replaceable></literal>
190 <literal><replaceable>username
</replaceable> USING
<replaceable>password
</replaceable></literal>
195 As above, the parameters
<replaceable>username
</replaceable> and
196 <replaceable>password
</replaceable> can be an SQL identifier, an
197 SQL string literal, or a reference to a character variable.
201 If the connection target includes any
<replaceable>options
</replaceable>,
203 <literal><replaceable>keyword
</replaceable>=
<replaceable>value
</replaceable></literal>
204 specifications separated by ampersands (
<literal>&</literal>).
205 The allowed key words are the same ones recognized
206 by
<application>libpq
</application> (see
207 <xref linkend=
"libpq-paramkeywords"/>). Spaces are ignored before
208 any
<replaceable>keyword
</replaceable> or
<replaceable>value
</replaceable>,
209 though not within or after one. Note that there is no way to
210 write
<literal>&</literal> within a
<replaceable>value
</replaceable>.
214 Notice that when specifying a socket connection
215 (with the
<literal>unix:
</literal> prefix), the host name must be
216 exactly
<literal>localhost
</literal>. To select a non-default
217 socket directory, write the directory's pathname as the value of
218 a
<varname>host
</varname> option in
219 the
<replaceable>options
</replaceable> part of the target.
223 The
<replaceable>connection-name
</replaceable> is used to handle
224 multiple connections in one program. It can be omitted if a
225 program uses only one connection. The most recently opened
226 connection becomes the current connection, which is used by default
227 when an SQL statement is to be executed (see later in this
232 Here are some examples of
<command>CONNECT
</command> statements:
234 EXEC SQL CONNECT TO mydb@sql.mydomain.com;
236 EXEC SQL CONNECT TO tcp:postgresql://sql.mydomain.com/mydb AS myconnection USER john;
238 EXEC SQL BEGIN DECLARE SECTION;
239 const char *target =
"mydb@sql.mydomain.com";
240 const char *user =
"john";
241 const char *passwd =
"secret";
242 EXEC SQL END DECLARE SECTION;
244 EXEC SQL CONNECT TO :target USER :user USING :passwd;
245 /* or EXEC SQL CONNECT TO :target USER :user/:passwd; */
247 The last example makes use of the feature referred to above as
248 character variable references. You will see in later sections how C
249 variables can be used in SQL statements when you prefix them with a
254 Be advised that the format of the connection target is not
255 specified in the SQL standard. So if you want to develop portable
256 applications, you might want to use something based on the last
257 example above to encapsulate the connection target string
262 If untrusted users have access to a database that has not adopted a
263 <link linkend=
"ddl-schemas-patterns">secure schema usage pattern
</link>,
264 begin each session by removing publicly-writable schemas
265 from
<varname>search_path
</varname>. For example,
266 add
<literal>options=-c search_path=
</literal>
267 to
<literal><replaceable>options
</replaceable></literal>, or
268 issue
<literal>EXEC SQL SELECT pg_catalog.set_config('search_path', '',
269 false);
</literal> after connecting. This consideration is not specific to
270 ECPG; it applies to every interface for executing arbitrary SQL commands.
274 <sect2 id=
"ecpg-set-connection">
275 <title>Choosing a Connection
</title>
278 SQL statements in embedded SQL programs are by default executed on
279 the current connection, that is, the most recently opened one. If
280 an application needs to manage multiple connections, then there are
281 three ways to handle this.
285 The first option is to explicitly choose a connection for each SQL
286 statement, for example:
288 EXEC SQL AT
<replaceable>connection-name
</replaceable> SELECT ...;
290 This option is particularly suitable if the application needs to
291 use several connections in mixed order.
295 If your application uses multiple threads of execution, they cannot share a
296 connection concurrently. You must either explicitly control access to the connection
297 (using mutexes) or use a connection for each thread.
301 The second option is to execute a statement to switch the current
302 connection. That statement is:
304 EXEC SQL SET CONNECTION
<replaceable>connection-name
</replaceable>;
306 This option is particularly convenient if many statements are to be
307 executed on the same connection.
311 Here is an example program managing multiple database connections:
312 <programlisting><![CDATA[
315 EXEC SQL BEGIN DECLARE SECTION;
317 EXEC SQL END DECLARE SECTION;
322 EXEC SQL CONNECT TO testdb1 AS con1 USER testuser;
323 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
324 EXEC SQL CONNECT TO testdb2 AS con2 USER testuser;
325 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
326 EXEC SQL CONNECT TO testdb3 AS con3 USER testuser;
327 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
329 /* This query would be executed in the last opened database
"testdb3". */
330 EXEC SQL SELECT current_database() INTO :dbname;
331 printf(
"current=%s (should be testdb3)\n", dbname);
333 /* Using
"AT" to run a query in
"testdb2" */
334 EXEC SQL AT con2 SELECT current_database() INTO :dbname;
335 printf(
"current=%s (should be testdb2)\n", dbname);
337 /* Switch the current connection to
"testdb1". */
338 EXEC SQL SET CONNECTION con1;
340 EXEC SQL SELECT current_database() INTO :dbname;
341 printf(
"current=%s (should be testdb1)\n", dbname);
343 EXEC SQL DISCONNECT ALL;
348 This example would produce this output:
350 current=testdb3 (should be testdb3)
351 current=testdb2 (should be testdb2)
352 current=testdb1 (should be testdb1)
357 The third option is to declare an SQL identifier linked to
358 the connection, for example:
360 EXEC SQL AT
<replaceable>connection-name
</replaceable> DECLARE
<replaceable>statement-name
</replaceable> STATEMENT;
361 EXEC SQL PREPARE
<replaceable>statement-name
</replaceable> FROM :
<replaceable>dyn-string
</replaceable>;
363 Once you link an SQL identifier to a connection, you execute dynamic SQL
364 without an AT clause. Note that this option behaves like preprocessor
365 directives, therefore the link is enabled only in the file.
368 Here is an example program using this option:
369 <programlisting><![CDATA[
372 EXEC SQL BEGIN DECLARE SECTION;
374 char *dyn_sql =
"SELECT current_database()";
375 EXEC SQL END DECLARE SECTION;
378 EXEC SQL CONNECT TO postgres AS con1;
379 EXEC SQL CONNECT TO testdb AS con2;
380 EXEC SQL AT con1 DECLARE stmt STATEMENT;
381 EXEC SQL PREPARE stmt FROM :dyn_sql;
382 EXEC SQL EXECUTE stmt INTO :dbname;
383 printf(
"%s\n", dbname);
385 EXEC SQL DISCONNECT ALL;
390 This example would produce this output, even if the default connection is testdb:
397 <sect2 id=
"ecpg-disconnect">
398 <title>Closing a Connection
</title>
401 To close a connection, use the following statement:
403 EXEC SQL DISCONNECT
<optional><replaceable>connection
</replaceable></optional>;
405 The
<replaceable>connection
</replaceable> can be specified
406 in the following ways:
411 <literal><replaceable>connection-name
</replaceable></literal>
417 <literal>CURRENT
</literal>
423 <literal>ALL
</literal>
428 If no connection name is specified, the current connection is
433 It is good style that an application always explicitly disconnect
434 from every connection it opened.
440 <sect1 id=
"ecpg-commands">
441 <title>Running SQL Commands
</title>
444 Any SQL command can be run from within an embedded SQL application.
445 Below are some examples of how to do that.
448 <sect2 id=
"ecpg-executing">
449 <title>Executing SQL Statements
</title>
454 EXEC SQL CREATE TABLE foo (number integer, ascii char(
16));
455 EXEC SQL CREATE UNIQUE INDEX num1 ON foo(number);
463 EXEC SQL INSERT INTO foo (number, ascii) VALUES (
9999, 'doodad');
471 EXEC SQL DELETE FROM foo WHERE number =
9999;
487 <literal>SELECT
</literal> statements that return a single result
488 row can also be executed using
489 <literal>EXEC SQL
</literal> directly. To handle result sets with
490 multiple rows, an application has to use a cursor;
491 see
<xref linkend=
"ecpg-cursors"/> below. (As a special case, an
492 application can fetch multiple rows at once into an array host
493 variable; see
<xref linkend=
"ecpg-variables-arrays"/>.)
499 EXEC SQL SELECT foo INTO :FooBar FROM table1 WHERE ascii = 'doodad';
504 Also, a configuration parameter can be retrieved with the
505 <literal>SHOW
</literal> command:
507 EXEC SQL SHOW search_path INTO :var;
512 The tokens of the form
513 <literal>:
<replaceable>something
</replaceable></literal> are
514 <firstterm>host variables
</firstterm>, that is, they refer to
515 variables in the C program. They are explained in
<xref
516 linkend=
"ecpg-variables"/>.
520 <sect2 id=
"ecpg-cursors">
521 <title>Using Cursors
</title>
524 To retrieve a result set holding multiple rows, an application has
525 to declare a cursor and fetch each row from the cursor. The steps
526 to use a cursor are the following: declare a cursor, open it, fetch
527 a row from the cursor, repeat, and finally close it.
531 Select using cursors:
533 EXEC SQL DECLARE foo_bar CURSOR FOR
534 SELECT number, ascii FROM foo
536 EXEC SQL OPEN foo_bar;
537 EXEC SQL FETCH foo_bar INTO :FooBar, DooDad;
539 EXEC SQL CLOSE foo_bar;
545 For more details about declaring a cursor, see
<xref
546 linkend=
"ecpg-sql-declare"/>; for more details about fetching rows from a
547 cursor, see
<xref linkend=
"sql-fetch"/>.
552 The ECPG
<command>DECLARE
</command> command does not actually
553 cause a statement to be sent to the PostgreSQL backend. The
554 cursor is opened in the backend (using the
555 backend's
<command>DECLARE
</command> command) at the point when
556 the
<command>OPEN
</command> command is executed.
561 <sect2 id=
"ecpg-transactions">
562 <title>Managing Transactions
</title>
565 In the default mode, statements are committed only when
566 <command>EXEC SQL COMMIT
</command> is issued. The embedded SQL
567 interface also supports autocommit of transactions (similar to
568 <application>psql
</application>'s default behavior) via the
<option>-t
</option>
569 command-line option to
<command>ecpg
</command> (see
<xref
570 linkend=
"app-ecpg"/>) or via the
<literal>EXEC SQL SET AUTOCOMMIT TO
571 ON
</literal> statement. In autocommit mode, each command is
572 automatically committed unless it is inside an explicit transaction
573 block. This mode can be explicitly turned off using
<literal>EXEC
574 SQL SET AUTOCOMMIT TO OFF
</literal>.
578 The following transaction management commands are available:
581 <varlistentry id=
"ecpg-transactions-exec-sql-commit">
582 <term><literal>EXEC SQL COMMIT
</literal></term>
585 Commit an in-progress transaction.
590 <varlistentry id=
"ecpg-transactions-exec-sql-rollback">
591 <term><literal>EXEC SQL ROLLBACK
</literal></term>
594 Roll back an in-progress transaction.
599 <varlistentry id=
"ecpg-transactions-exec-sql-prepare-transaction">
600 <term><literal>EXEC SQL PREPARE TRANSACTION
</literal><replaceable class=
"parameter">transaction_id
</replaceable></term>
603 Prepare the current transaction for two-phase commit.
608 <varlistentry id=
"ecpg-transactions-exec-sql-commit-prepared">
609 <term><literal>EXEC SQL COMMIT PREPARED
</literal><replaceable class=
"parameter">transaction_id
</replaceable></term>
612 Commit a transaction that is in prepared state.
617 <varlistentry id=
"ecpg-transactions-exec-sql-rollback-prepared">
618 <term><literal>EXEC SQL ROLLBACK PREPARED
</literal><replaceable class=
"parameter">transaction_id
</replaceable></term>
621 Roll back a transaction that is in prepared state.
626 <varlistentry id=
"ecpg-transactions-exec-sql-autocommit-on">
627 <term><literal>EXEC SQL SET AUTOCOMMIT TO ON
</literal></term>
630 Enable autocommit mode.
635 <varlistentry id=
"ecpg-transactions-exec-sql-autocommit-off">
636 <term><literal>EXEC SQL SET AUTOCOMMIT TO OFF
</literal></term>
639 Disable autocommit mode. This is the default.
647 <sect2 id=
"ecpg-prepared">
648 <title>Prepared Statements
</title>
651 When the values to be passed to an SQL statement are not known at
652 compile time, or the same statement is going to be used many
653 times, then prepared statements can be useful.
657 The statement is prepared using the
658 command
<literal>PREPARE
</literal>. For the values that are not
660 placeholder
<quote><literal>?
</literal></quote>:
662 EXEC SQL PREPARE stmt1 FROM
"SELECT oid, datname FROM pg_database WHERE oid = ?";
667 If a statement returns a single row, the application can
668 call
<literal>EXECUTE
</literal> after
669 <literal>PREPARE
</literal> to execute the statement, supplying the
670 actual values for the placeholders with a
<literal>USING
</literal>
673 EXEC SQL EXECUTE stmt1 INTO :dboid, :dbname USING
1;
678 If a statement returns multiple rows, the application can use a
679 cursor declared based on the prepared statement. To bind input
680 parameters, the cursor must be opened with
681 a
<literal>USING
</literal> clause:
683 EXEC SQL PREPARE stmt1 FROM
"SELECT oid,datname FROM pg_database WHERE oid > ?";
684 EXEC SQL DECLARE foo_bar CURSOR FOR stmt1;
686 /* when end of result set reached, break out of while loop */
687 EXEC SQL WHENEVER NOT FOUND DO BREAK;
689 EXEC SQL OPEN foo_bar USING
100;
693 EXEC SQL FETCH NEXT FROM foo_bar INTO :dboid, :dbname;
696 EXEC SQL CLOSE foo_bar;
701 When you don't need the prepared statement anymore, you should
704 EXEC SQL DEALLOCATE PREPARE
<replaceable>name
</replaceable>;
709 For more details about
<literal>PREPARE
</literal>,
710 see
<xref linkend=
"ecpg-sql-prepare"/>. Also
711 see
<xref linkend=
"ecpg-dynamic"/> for more details about using
712 placeholders and input parameters.
717 <sect1 id=
"ecpg-variables">
718 <title>Using Host Variables
</title>
721 In
<xref linkend=
"ecpg-commands"/> you saw how you can execute SQL
722 statements from an embedded SQL program. Some of those statements
723 only used fixed values and did not provide a way to insert
724 user-supplied values into statements or have the program process
725 the values returned by the query. Those kinds of statements are
726 not really useful in real applications. This section explains in
727 detail how you can pass data between your C program and the
728 embedded SQL statements using a simple mechanism called
729 <firstterm>host variables
</firstterm>. In an embedded SQL program we
730 consider the SQL statements to be
<firstterm>guests
</firstterm> in the C
731 program code which is the
<firstterm>host language
</firstterm>. Therefore
732 the variables of the C program are called
<firstterm>host
733 variables
</firstterm>.
737 Another way to exchange values between PostgreSQL backends and ECPG
738 applications is the use of SQL descriptors, described
739 in
<xref linkend=
"ecpg-descriptors"/>.
742 <sect2 id=
"ecpg-variables-overview">
743 <title>Overview
</title>
746 Passing data between the C program and the SQL statements is
747 particularly simple in embedded SQL. Instead of having the
748 program paste the data into the statement, which entails various
749 complications, such as properly quoting the value, you can simply
750 write the name of a C variable into the SQL statement, prefixed by
751 a colon. For example:
753 EXEC SQL INSERT INTO sometable VALUES (:v1, 'foo', :v2);
755 This statement refers to two C variables named
756 <varname>v1
</varname> and
<varname>v2
</varname> and also uses a
757 regular SQL string literal, to illustrate that you are not
758 restricted to use one kind of data or the other.
762 This style of inserting C variables in SQL statements works
763 anywhere a value expression is expected in an SQL statement.
767 <sect2 id=
"ecpg-declare-sections">
768 <title>Declare Sections
</title>
771 To pass data from the program to the database, for example as
772 parameters in a query, or to pass data from the database back to
773 the program, the C variables that are intended to contain this
774 data need to be declared in specially marked sections, so the
775 embedded SQL preprocessor is made aware of them.
779 This section starts with:
781 EXEC SQL BEGIN DECLARE SECTION;
785 EXEC SQL END DECLARE SECTION;
787 Between those lines, there must be normal C variable declarations,
791 char foo[
16], bar[
16];
793 As you can see, you can optionally assign an initial value to the variable.
794 The variable's scope is determined by the location of its declaring
795 section within the program.
796 You can also declare variables with the following syntax which implicitly
797 creates a declare section:
801 You can have as many declare sections in a program as you like.
805 The declarations are also echoed to the output file as normal C
806 variables, so there's no need to declare them again. Variables
807 that are not intended to be used in SQL commands can be declared
808 normally outside these special sections.
812 The definition of a structure or union also must be listed inside
813 a
<literal>DECLARE
</literal> section. Otherwise the preprocessor cannot
814 handle these types since it does not know the definition.
818 <sect2 id=
"ecpg-retrieving">
819 <title>Retrieving Query Results
</title>
822 Now you should be able to pass data generated by your program into
823 an SQL command. But how do you retrieve the results of a query?
824 For that purpose, embedded SQL provides special variants of the
825 usual commands
<command>SELECT
</command> and
826 <command>FETCH
</command>. These commands have a special
827 <literal>INTO
</literal> clause that specifies which host variables
828 the retrieved values are to be stored in.
829 <command>SELECT
</command> is used for a query that returns only
830 single row, and
<command>FETCH
</command> is used for a query that
831 returns multiple rows, using a cursor.
839 * CREATE TABLE test1 (a int, b varchar(
50));
842 EXEC SQL BEGIN DECLARE SECTION;
845 EXEC SQL END DECLARE SECTION;
849 EXEC SQL SELECT a, b INTO :v1, :v2 FROM test;
851 So the
<literal>INTO
</literal> clause appears between the select
852 list and the
<literal>FROM
</literal> clause. The number of
853 elements in the select list and the list after
854 <literal>INTO
</literal> (also called the target list) must be
859 Here is an example using the command
<command>FETCH
</command>:
861 EXEC SQL BEGIN DECLARE SECTION;
864 EXEC SQL END DECLARE SECTION;
868 EXEC SQL DECLARE foo CURSOR FOR SELECT a, b FROM test;
875 EXEC SQL FETCH NEXT FROM foo INTO :v1, :v2;
879 Here the
<literal>INTO
</literal> clause appears after all the
885 <sect2 id=
"ecpg-variables-type-mapping">
886 <title>Type Mapping
</title>
889 When ECPG applications exchange values between the PostgreSQL
890 server and the C application, such as when retrieving query
891 results from the server or executing SQL statements with input
892 parameters, the values need to be converted between PostgreSQL
893 data types and host language variable types (C language data
894 types, concretely). One of the main points of ECPG is that it
895 takes care of this automatically in most cases.
899 In this respect, there are two kinds of data types: Some simple
900 PostgreSQL data types, such as
<type>integer
</type>
901 and
<type>text
</type>, can be read and written by the application
902 directly. Other PostgreSQL data types, such
903 as
<type>timestamp
</type> and
<type>numeric
</type> can only be
904 accessed through special library functions; see
905 <xref linkend=
"ecpg-special-types"/>.
909 <xref linkend=
"ecpg-datatype-hostvars-table"/> shows which PostgreSQL
910 data types correspond to which C data types. When you wish to
911 send or receive a value of a given PostgreSQL data type, you
912 should declare a C variable of the corresponding C data type in
916 <table id=
"ecpg-datatype-hostvars-table">
917 <title>Mapping Between PostgreSQL Data Types and C Variable Types
</title>
921 <entry>PostgreSQL data type
</entry>
922 <entry>Host variable type
</entry>
928 <entry><type>smallint
</type></entry>
929 <entry><type>short
</type></entry>
933 <entry><type>integer
</type></entry>
934 <entry><type>int
</type></entry>
938 <entry><type>bigint
</type></entry>
939 <entry><type>long long int
</type></entry>
943 <entry><type>decimal
</type></entry>
944 <entry><type>decimal
</type><footnote id=
"ecpg-datatype-table-fn"><para>This type can only be accessed through special library functions; see
<xref linkend=
"ecpg-special-types"/>.
</para></footnote></entry>
948 <entry><type>numeric
</type></entry>
949 <entry><type>numeric
</type><footnoteref linkend=
"ecpg-datatype-table-fn"/></entry>
953 <entry><type>real
</type></entry>
954 <entry><type>float
</type></entry>
958 <entry><type>double precision
</type></entry>
959 <entry><type>double
</type></entry>
963 <entry><type>smallserial
</type></entry>
964 <entry><type>short
</type></entry>
968 <entry><type>serial
</type></entry>
969 <entry><type>int
</type></entry>
973 <entry><type>bigserial
</type></entry>
974 <entry><type>long long int
</type></entry>
978 <entry><type>oid
</type></entry>
979 <entry><type>unsigned int
</type></entry>
983 <entry><type>character(
<replaceable>n
</replaceable>)
</type>,
<type>varchar(
<replaceable>n
</replaceable>)
</type>,
<type>text
</type></entry>
984 <entry><type>char[
<replaceable>n
</replaceable>+
1]
</type>,
<type>VARCHAR[
<replaceable>n
</replaceable>+
1]
</type></entry>
988 <entry><type>name
</type></entry>
989 <entry><type>char[NAMEDATALEN]
</type></entry>
993 <entry><type>timestamp
</type></entry>
994 <entry><type>timestamp
</type><footnoteref linkend=
"ecpg-datatype-table-fn"/></entry>
998 <entry><type>interval
</type></entry>
999 <entry><type>interval
</type><footnoteref linkend=
"ecpg-datatype-table-fn"/></entry>
1003 <entry><type>date
</type></entry>
1004 <entry><type>date
</type><footnoteref linkend=
"ecpg-datatype-table-fn"/></entry>
1008 <entry><type>boolean
</type></entry>
1009 <entry><type>bool
</type><footnote><para>declared in
<filename>ecpglib.h
</filename> if not native
</para></footnote></entry>
1013 <entry><type>bytea
</type></entry>
1014 <entry><type>char *
</type>,
<type>bytea[
<replaceable>n
</replaceable>]
</type></entry>
1020 <sect3 id=
"ecpg-char">
1021 <title>Handling Character Strings
</title>
1024 To handle SQL character string data types, such
1025 as
<type>varchar
</type> and
<type>text
</type>, there are two
1026 possible ways to declare the host variables.
1030 One way is using
<type>char[]
</type>, an array
1031 of
<type>char
</type>, which is the most common way to handle
1032 character data in C.
1034 EXEC SQL BEGIN DECLARE SECTION;
1036 EXEC SQL END DECLARE SECTION;
1038 Note that you have to take care of the length yourself. If you
1039 use this host variable as the target variable of a query which
1040 returns a string with more than
49 characters, a buffer overflow
1045 The other way is using the
<type>VARCHAR
</type> type, which is a
1046 special type provided by ECPG. The definition on an array of
1047 type
<type>VARCHAR
</type> is converted into a
1048 named
<type>struct
</type> for every variable. A declaration like:
1054 struct varchar_var { int len; char arr[
180]; } var;
1056 The member
<structfield>arr
</structfield> hosts the string
1057 including a terminating zero byte. Thus, to store a string in
1058 a
<type>VARCHAR
</type> host variable, the host variable has to be
1059 declared with the length including the zero byte terminator. The
1060 member
<structfield>len
</structfield> holds the length of the
1061 string stored in the
<structfield>arr
</structfield> without the
1062 terminating zero byte. When a host variable is used as input for
1063 a query, if
<literal>strlen(arr)
</literal>
1064 and
<structfield>len
</structfield> are different, the shorter one
1069 <type>VARCHAR
</type> can be written in upper or lower case, but
1074 <type>char
</type> and
<type>VARCHAR
</type> host variables can
1075 also hold values of other SQL types, which will be stored in
1080 <sect3 id=
"ecpg-special-types">
1081 <title>Accessing Special Data Types
</title>
1084 ECPG contains some special types that help you to interact easily
1085 with some special data types from the PostgreSQL server. In
1086 particular, it has implemented support for the
1087 <type>numeric
</type>,
<type>decimal
</type>,
<type>date
</type>,
<type>timestamp
</type>,
1088 and
<type>interval
</type> types. These data types cannot usefully be
1089 mapped to primitive host variable types (such
1090 as
<type>int
</type>,
<type>long long int
</type>,
1091 or
<type>char[]
</type>), because they have a complex internal
1092 structure. Applications deal with these types by declaring host
1093 variables in special types and accessing them using functions in
1094 the pgtypes library. The pgtypes library, described in detail
1095 in
<xref linkend=
"ecpg-pgtypes"/> contains basic functions to deal
1096 with those types, such that you do not need to send a query to
1097 the SQL server just for adding an interval to a time stamp for
1102 The follow subsections describe these special data types. For
1103 more details about pgtypes library functions,
1104 see
<xref linkend=
"ecpg-pgtypes"/>.
1107 <sect4 id=
"ecpg-special-types-timestamp-date">
1108 <title>timestamp, date
</title>
1111 Here is a pattern for handling
<type>timestamp
</type> variables
1112 in the ECPG host application.
1116 First, the program has to include the header file for the
1117 <type>timestamp
</type> type:
1119 #include
<pgtypes_timestamp.h
>
1124 Next, declare a host variable as type
<type>timestamp
</type> in
1125 the declare section:
1127 EXEC SQL BEGIN DECLARE SECTION;
1129 EXEC SQL END DECLARE SECTION;
1134 And after reading a value into the host variable, process it
1135 using pgtypes library functions. In following example, the
1136 <type>timestamp
</type> value is converted into text (ASCII) form
1137 with the
<function>PGTYPEStimestamp_to_asc()
</function>
1140 EXEC SQL SELECT now()::timestamp INTO :ts;
1142 printf(
"ts = %s\n", PGTYPEStimestamp_to_asc(ts));
1144 This example will show some result like following:
1146 ts =
2010-
06-
27 18:
03:
56.949343
1151 In addition, the DATE type can be handled in the same way. The
1152 program has to include
<filename>pgtypes_date.h
</filename>, declare a host variable
1153 as the date type and convert a DATE value into a text form using
1154 <function>PGTYPESdate_to_asc()
</function> function. For more details about the
1155 pgtypes library functions, see
<xref linkend=
"ecpg-pgtypes"/>.
1159 <sect4 id=
"ecpg-type-interval">
1160 <title>interval
</title>
1163 The handling of the
<type>interval
</type> type is also similar
1164 to the
<type>timestamp
</type> and
<type>date
</type> types. It
1165 is required, however, to allocate memory for
1166 an
<type>interval
</type> type value explicitly. In other words,
1167 the memory space for the variable has to be allocated in the
1168 heap memory, not in the stack memory.
1172 Here is an example program:
1174 #include
<stdio.h
>
1175 #include
<stdlib.h
>
1176 #include
<pgtypes_interval.h
>
1181 EXEC SQL BEGIN DECLARE SECTION;
1183 EXEC SQL END DECLARE SECTION;
1185 EXEC SQL CONNECT TO testdb;
1186 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
1188 in = PGTYPESinterval_new();
1189 EXEC SQL SELECT '
1 min'::interval INTO :in;
1190 printf(
"interval = %s\n", PGTYPESinterval_to_asc(in));
1191 PGTYPESinterval_free(in);
1194 EXEC SQL DISCONNECT ALL;
1201 <sect4 id=
"ecpg-type-numeric-decimal">
1202 <title>numeric, decimal
</title>
1205 The handling of the
<type>numeric
</type>
1206 and
<type>decimal
</type> types is similar to the
1207 <type>interval
</type> type: It requires defining a pointer,
1208 allocating some memory space on the heap, and accessing the
1209 variable using the pgtypes library functions. For more details
1210 about the pgtypes library functions,
1211 see
<xref linkend=
"ecpg-pgtypes"/>.
1215 No functions are provided specifically for
1216 the
<type>decimal
</type> type. An application has to convert it
1217 to a
<type>numeric
</type> variable using a pgtypes library
1218 function to do further processing.
1222 Here is an example program handling
<type>numeric
</type>
1223 and
<type>decimal
</type> type variables.
1225 #include
<stdio.h
>
1226 #include
<stdlib.h
>
1227 #include
<pgtypes_numeric.h
>
1229 EXEC SQL WHENEVER SQLERROR STOP;
1234 EXEC SQL BEGIN DECLARE SECTION;
1238 EXEC SQL END DECLARE SECTION;
1240 EXEC SQL CONNECT TO testdb;
1241 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
1243 num = PGTYPESnumeric_new();
1244 dec = PGTYPESdecimal_new();
1246 EXEC SQL SELECT
12.345::numeric(
4,
2),
23.456::decimal(
4,
2) INTO :num, :dec;
1248 printf(
"numeric = %s\n", PGTYPESnumeric_to_asc(num,
0));
1249 printf(
"numeric = %s\n", PGTYPESnumeric_to_asc(num,
1));
1250 printf(
"numeric = %s\n", PGTYPESnumeric_to_asc(num,
2));
1252 /* Convert decimal to numeric to show a decimal value. */
1253 num2 = PGTYPESnumeric_new();
1254 PGTYPESnumeric_from_decimal(dec, num2);
1256 printf(
"decimal = %s\n", PGTYPESnumeric_to_asc(num2,
0));
1257 printf(
"decimal = %s\n", PGTYPESnumeric_to_asc(num2,
1));
1258 printf(
"decimal = %s\n", PGTYPESnumeric_to_asc(num2,
2));
1260 PGTYPESnumeric_free(num2);
1261 PGTYPESdecimal_free(dec);
1262 PGTYPESnumeric_free(num);
1265 EXEC SQL DISCONNECT ALL;
1272 <sect4 id=
"ecpg-special-types-bytea">
1273 <title>bytea
</title>
1276 The handling of the
<type>bytea
</type> type is similar to
1277 that of
<type>VARCHAR
</type>. The definition on an array of type
1278 <type>bytea
</type> is converted into a named struct for every
1279 variable. A declaration like:
1285 struct bytea_var { int len; char arr[
180]; } var;
1287 The member
<structfield>arr
</structfield> hosts binary format
1288 data. It can also handle
<literal>'\
0'
</literal> as part of
1289 data, unlike
<type>VARCHAR
</type>.
1290 The data is converted from/to hex format and sent/received by
1296 <type>bytea
</type> variable can be used only when
1297 <xref linkend=
"guc-bytea-output"/> is set to
<literal>hex
</literal>.
1303 <sect3 id=
"ecpg-variables-nonprimitive-c">
1304 <title>Host Variables with Nonprimitive Types
</title>
1307 As a host variable you can also use arrays, typedefs, structs, and
1311 <sect4 id=
"ecpg-variables-arrays">
1312 <title>Arrays
</title>
1315 There are two use cases for arrays as host variables. The first
1316 is a way to store some text string in
<type>char[]
</type>
1317 or
<type>VARCHAR[]
</type>, as
1318 explained in
<xref linkend=
"ecpg-char"/>. The second use case is to
1319 retrieve multiple rows from a query result without using a
1320 cursor. Without an array, to process a query result consisting
1321 of multiple rows, it is required to use a cursor and
1322 the
<command>FETCH
</command> command. But with array host
1323 variables, multiple rows can be received at once. The length of
1324 the array has to be defined to be able to accommodate all rows,
1325 otherwise a buffer overflow will likely occur.
1329 Following example scans the
<literal>pg_database
</literal>
1330 system table and shows all OIDs and names of the available
1336 EXEC SQL BEGIN DECLARE SECTION;
1340 EXEC SQL END DECLARE SECTION;
1342 memset(dbname,
0, sizeof(char)*
16 *
8);
1343 memset(dbid,
0, sizeof(int) *
8);
1345 EXEC SQL CONNECT TO testdb;
1346 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
1348 /* Retrieve multiple rows into arrays at once. */
1349 EXEC SQL SELECT oid,datname INTO :dbid, :dbname FROM pg_database;
1351 for (i =
0; i
< 8; i++)
1352 printf(
"oid=%d, dbname=%s\n", dbid[i], dbname[i]);
1355 EXEC SQL DISCONNECT ALL;
1360 This example shows following result. (The exact values depend on
1361 local circumstances.)
1363 oid=
1, dbname=template1
1364 oid=
11510, dbname=template0
1365 oid=
11511, dbname=postgres
1366 oid=
313780, dbname=testdb
1374 <sect4 id=
"ecpg-variables-struct">
1375 <title>Structures
</title>
1378 A structure whose member names match the column names of a query
1379 result, can be used to retrieve multiple columns at once. The
1380 structure enables handling multiple column values in a single
1385 The following example retrieves OIDs, names, and sizes of the
1386 available databases from the
<literal>pg_database
</literal>
1387 system table and using
1388 the
<function>pg_database_size()
</function> function. In this
1389 example, a structure variable
<varname>dbinfo_t
</varname> with
1390 members whose names match each column in
1391 the
<literal>SELECT
</literal> result is used to retrieve one
1392 result row without putting multiple host variables in
1393 the
<literal>FETCH
</literal> statement.
1395 EXEC SQL BEGIN DECLARE SECTION;
1404 EXEC SQL END DECLARE SECTION;
1406 memset(
&dbval,
0, sizeof(dbinfo_t));
1408 EXEC SQL DECLARE cur1 CURSOR FOR SELECT oid, datname, pg_database_size(oid) AS size FROM pg_database;
1411 /* when end of result set reached, break out of while loop */
1412 EXEC SQL WHENEVER NOT FOUND DO BREAK;
1416 /* Fetch multiple columns into one structure. */
1417 EXEC SQL FETCH FROM cur1 INTO :dbval;
1419 /* Print members of the structure. */
1420 printf(
"oid=%d, datname=%s, size=%lld\n", dbval.oid, dbval.datname, dbval.size);
1423 EXEC SQL CLOSE cur1;
1428 This example shows following result. (The exact values depend on
1429 local circumstances.)
1431 oid=
1, datname=template1, size=
4324580
1432 oid=
11510, datname=template0, size=
4243460
1433 oid=
11511, datname=postgres, size=
4324580
1434 oid=
313780, datname=testdb, size=
8183012
1439 Structure host variables
<quote>absorb
</quote> as many columns
1440 as the structure as fields. Additional columns can be assigned
1441 to other host variables. For example, the above program could
1442 also be restructured like this, with the
<varname>size
</varname>
1443 variable outside the structure:
1445 EXEC SQL BEGIN DECLARE SECTION;
1454 EXEC SQL END DECLARE SECTION;
1456 memset(
&dbval,
0, sizeof(dbinfo_t));
1458 EXEC SQL DECLARE cur1 CURSOR FOR SELECT oid, datname, pg_database_size(oid) AS size FROM pg_database;
1461 /* when end of result set reached, break out of while loop */
1462 EXEC SQL WHENEVER NOT FOUND DO BREAK;
1466 /* Fetch multiple columns into one structure. */
1467 EXEC SQL FETCH FROM cur1 INTO :dbval, :size;
1469 /* Print members of the structure. */
1470 printf(
"oid=%d, datname=%s, size=%lld\n", dbval.oid, dbval.datname, size);
1473 EXEC SQL CLOSE cur1;
1478 <sect4 id=
"ecpg-variables-nonprimitive-c-typedefs">
1479 <title>Typedefs
</title>
1481 <primary>typedef
</primary>
1482 <secondary>in ECPG
</secondary>
1486 Use the
<literal>typedef
</literal> keyword to map new types to already
1489 EXEC SQL BEGIN DECLARE SECTION;
1490 typedef char mychartype[
40];
1491 typedef long serial_t;
1492 EXEC SQL END DECLARE SECTION;
1494 Note that you could also use:
1496 EXEC SQL TYPE serial_t IS long;
1498 This declaration does not need to be part of a declare section;
1499 that is, you can also write typedefs as normal C statements.
1503 Any word you declare as a
<literal>typedef
</literal> cannot be used as
1504 an SQL keyword in
<literal>EXEC SQL
</literal> commands later in the same
1505 program. For example, this won't work:
1507 EXEC SQL BEGIN DECLARE SECTION;
1509 EXEC SQL END DECLARE SECTION;
1511 EXEC SQL START TRANSACTION;
1513 ECPG will report a syntax error for
<literal>START
1514 TRANSACTION
</literal>, because it no longer
1515 recognizes
<literal>START
</literal> as an SQL keyword,
1517 (If you have such a conflict, and renaming the typedef
1518 seems impractical, you could write the SQL command
1519 using
<link linkend=
"ecpg-dynamic">dynamic SQL
</link>.)
1524 In
<productname>PostgreSQL
</productname> releases before v16, use
1525 of SQL keywords as typedef names was likely to result in syntax
1526 errors associated with use of the typedef itself, rather than use
1527 of the name as an SQL keyword. The new behavior is less likely to
1528 cause problems when an existing ECPG application is recompiled in
1529 a new
<productname>PostgreSQL
</productname> release with new
1535 <sect4 id=
"ecpg-variables-nonprimitive-c-pointers">
1536 <title>Pointers
</title>
1539 You can declare pointers to the most common types. Note however
1540 that you cannot use pointers as target variables of queries
1541 without auto-allocation. See
<xref linkend=
"ecpg-descriptors"/>
1542 for more information on auto-allocation.
1547 EXEC SQL BEGIN DECLARE SECTION;
1550 EXEC SQL END DECLARE SECTION;
1557 <sect2 id=
"ecpg-variables-nonprimitive-sql">
1558 <title>Handling Nonprimitive SQL Data Types
</title>
1561 This section contains information on how to handle nonscalar and
1562 user-defined SQL-level data types in ECPG applications. Note that
1563 this is distinct from the handling of host variables of
1564 nonprimitive types, described in the previous section.
1567 <sect3 id=
"ecpg-variables-nonprimitive-sql-arrays">
1568 <title>Arrays
</title>
1571 Multi-dimensional SQL-level arrays are not directly supported in ECPG.
1572 One-dimensional SQL-level arrays can be mapped into C array host
1573 variables and vice-versa. However, when creating a statement ecpg does
1574 not know the types of the columns, so that it cannot check if a C array
1575 is input into a corresponding SQL-level array. When processing the
1576 output of an SQL statement, ecpg has the necessary information and thus
1577 checks if both are arrays.
1581 If a query accesses
<emphasis>elements
</emphasis> of an array
1582 separately, then this avoids the use of arrays in ECPG. Then, a
1583 host variable with a type that can be mapped to the element type
1584 should be used. For example, if a column type is array of
1585 <type>integer
</type>, a host variable of type
<type>int
</type>
1586 can be used. Also if the element type is
<type>varchar
</type>
1587 or
<type>text
</type>, a host variable of type
<type>char[]
</type>
1588 or
<type>VARCHAR[]
</type> can be used.
1592 Here is an example. Assume the following table:
1598 testdb=
> SELECT * FROM t3;
1605 The following example program retrieves the
4th element of the
1606 array and stores it into a host variable of
1607 type
<type>int
</type>:
1609 EXEC SQL BEGIN DECLARE SECTION;
1611 EXEC SQL END DECLARE SECTION;
1613 EXEC SQL DECLARE cur1 CURSOR FOR SELECT ii[
4] FROM t3;
1616 EXEC SQL WHENEVER NOT FOUND DO BREAK;
1620 EXEC SQL FETCH FROM cur1 INTO :ii ;
1621 printf(
"ii=%d\n", ii);
1624 EXEC SQL CLOSE cur1;
1627 This example shows the following result:
1634 To map multiple array elements to the multiple elements in an
1635 array type host variables each element of array column and each
1636 element of the host variable array have to be managed separately,
1639 EXEC SQL BEGIN DECLARE SECTION;
1641 EXEC SQL END DECLARE SECTION;
1643 EXEC SQL DECLARE cur1 CURSOR FOR SELECT ii[
1], ii[
2], ii[
3], ii[
4] FROM t3;
1646 EXEC SQL WHENEVER NOT FOUND DO BREAK;
1650 EXEC SQL FETCH FROM cur1 INTO :ii_a[
0], :ii_a[
1], :ii_a[
2], :ii_a[
3];
1659 EXEC SQL BEGIN DECLARE SECTION;
1661 EXEC SQL END DECLARE SECTION;
1663 EXEC SQL DECLARE cur1 CURSOR FOR SELECT ii FROM t3;
1666 EXEC SQL WHENEVER NOT FOUND DO BREAK;
1671 EXEC SQL FETCH FROM cur1 INTO :ii_a;
1675 would not work correctly in this case, because you cannot map an
1676 array type column to an array host variable directly.
1680 Another workaround is to store arrays in their external string
1681 representation in host variables of type
<type>char[]
</type>
1682 or
<type>VARCHAR[]
</type>. For more details about this
1683 representation, see
<xref linkend=
"arrays-input"/>. Note that
1684 this means that the array cannot be accessed naturally as an
1685 array in the host program (without further processing that parses
1686 the text representation).
1690 <sect3 id=
"ecpg-variables-nonprimitive-sql-composite">
1691 <title>Composite Types
</title>
1694 Composite types are not directly supported in ECPG, but an easy workaround is possible.
1696 available workarounds are similar to the ones described for
1697 arrays above: Either access each attribute separately or use the
1698 external string representation.
1702 For the following examples, assume the following type and table:
1704 CREATE TYPE comp_t AS (intval integer, textval varchar(
32));
1705 CREATE TABLE t4 (compval comp_t);
1706 INSERT INTO t4 VALUES ( (
256, 'PostgreSQL') );
1709 The most obvious solution is to access each attribute separately.
1710 The following program retrieves data from the example table by
1711 selecting each attribute of the type
<type>comp_t
</type>
1714 EXEC SQL BEGIN DECLARE SECTION;
1716 varchar textval[
33];
1717 EXEC SQL END DECLARE SECTION;
1719 /* Put each element of the composite type column in the SELECT list. */
1720 EXEC SQL DECLARE cur1 CURSOR FOR SELECT (compval).intval, (compval).textval FROM t4;
1723 EXEC SQL WHENEVER NOT FOUND DO BREAK;
1727 /* Fetch each element of the composite type column into host variables. */
1728 EXEC SQL FETCH FROM cur1 INTO :intval, :textval;
1730 printf(
"intval=%d, textval=%s\n", intval, textval.arr);
1733 EXEC SQL CLOSE cur1;
1738 To enhance this example, the host variables to store values in
1739 the
<command>FETCH
</command> command can be gathered into one
1740 structure. For more details about the host variable in the
1741 structure form, see
<xref linkend=
"ecpg-variables-struct"/>.
1742 To switch to the structure, the example can be modified as below.
1743 The two host variables,
<varname>intval
</varname>
1744 and
<varname>textval
</varname>, become members of
1745 the
<structname>comp_t
</structname> structure, and the structure
1746 is specified on the
<command>FETCH
</command> command.
1748 EXEC SQL BEGIN DECLARE SECTION;
1752 varchar textval[
33];
1756 EXEC SQL END DECLARE SECTION;
1758 /* Put each element of the composite type column in the SELECT list. */
1759 EXEC SQL DECLARE cur1 CURSOR FOR SELECT (compval).intval, (compval).textval FROM t4;
1762 EXEC SQL WHENEVER NOT FOUND DO BREAK;
1766 /* Put all values in the SELECT list into one structure. */
1767 EXEC SQL FETCH FROM cur1 INTO :compval;
1769 printf(
"intval=%d, textval=%s\n", compval.intval, compval.textval.arr);
1772 EXEC SQL CLOSE cur1;
1775 Although a structure is used in the
<command>FETCH
</command>
1776 command, the attribute names in the
<command>SELECT
</command>
1777 clause are specified one by one. This can be enhanced by using
1778 a
<literal>*
</literal> to ask for all attributes of the composite
1782 EXEC SQL DECLARE cur1 CURSOR FOR SELECT (compval).* FROM t4;
1785 EXEC SQL WHENEVER NOT FOUND DO BREAK;
1789 /* Put all values in the SELECT list into one structure. */
1790 EXEC SQL FETCH FROM cur1 INTO :compval;
1792 printf(
"intval=%d, textval=%s\n", compval.intval, compval.textval.arr);
1796 This way, composite types can be mapped into structures almost
1797 seamlessly, even though ECPG does not understand the composite
1802 Finally, it is also possible to store composite type values in
1803 their external string representation in host variables of
1804 type
<type>char[]
</type> or
<type>VARCHAR[]
</type>. But that
1805 way, it is not easily possible to access the fields of the value
1806 from the host program.
1810 <sect3 id=
"ecpg-variables-nonprimitive-sql-user-defined-base-types">
1811 <title>User-Defined Base Types
</title>
1814 New user-defined base types are not directly supported by ECPG.
1815 You can use the external string representation and host variables
1816 of type
<type>char[]
</type> or
<type>VARCHAR[]
</type>, and this
1817 solution is indeed appropriate and sufficient for many types.
1821 Here is an example using the data type
<type>complex
</type> from
1822 the example in
<xref linkend=
"xtypes"/>. The external string
1823 representation of that type is
<literal>(%f,%f)
</literal>,
1824 which is defined in the
1825 functions
<function>complex_in()
</function>
1826 and
<function>complex_out()
</function> functions
1827 in
<xref linkend=
"xtypes"/>. The following example inserts the
1828 complex type values
<literal>(
1,
1)
</literal>
1829 and
<literal>(
3,
3)
</literal> into the
1830 columns
<literal>a
</literal> and
<literal>b
</literal>, and select
1831 them from the table after that.
1834 EXEC SQL BEGIN DECLARE SECTION;
1837 EXEC SQL END DECLARE SECTION;
1839 EXEC SQL INSERT INTO test_complex VALUES ('(
1,
1)', '(
3,
3)');
1841 EXEC SQL DECLARE cur1 CURSOR FOR SELECT a, b FROM test_complex;
1844 EXEC SQL WHENEVER NOT FOUND DO BREAK;
1848 EXEC SQL FETCH FROM cur1 INTO :a, :b;
1849 printf(
"a=%s, b=%s\n", a.arr, b.arr);
1852 EXEC SQL CLOSE cur1;
1855 This example shows following result:
1862 Another workaround is avoiding the direct use of the user-defined
1863 types in ECPG and instead create a function or cast that converts
1864 between the user-defined type and a primitive type that ECPG can
1865 handle. Note, however, that type casts, especially implicit
1866 ones, should be introduced into the type system very carefully.
1872 CREATE FUNCTION create_complex(r double, i double) RETURNS complex
1875 AS $$ SELECT $
1 * complex '(
1,
0')' + $
2 * complex '(
0,
1)' $$;
1877 After this definition, the following
1879 EXEC SQL BEGIN DECLARE SECTION;
1881 EXEC SQL END DECLARE SECTION;
1888 EXEC SQL INSERT INTO test_complex VALUES (create_complex(:a, :b), create_complex(:c, :d));
1890 has the same effect as
1892 EXEC SQL INSERT INTO test_complex VALUES ('(
1,
2)', '(
3,
4)');
1898 <sect2 id=
"ecpg-indicators">
1899 <title>Indicators
</title>
1902 The examples above do not handle null values. In fact, the
1903 retrieval examples will raise an error if they fetch a null value
1904 from the database. To be able to pass null values to the database
1905 or retrieve null values from the database, you need to append a
1906 second host variable specification to each host variable that
1907 contains data. This second host variable is called the
1908 <firstterm>indicator
</firstterm> and contains a flag that tells
1909 whether the datum is null, in which case the value of the real
1910 host variable is ignored. Here is an example that handles the
1911 retrieval of null values correctly:
1913 EXEC SQL BEGIN DECLARE SECTION;
1916 EXEC SQL END DECLARE SECTION:
1920 EXEC SQL SELECT b INTO :val :val_ind FROM test1;
1922 The indicator variable
<varname>val_ind
</varname> will be zero if
1923 the value was not null, and it will be negative if the value was
1924 null. (See
<xref linkend=
"ecpg-oracle-compat"/> to enable
1925 Oracle-specific behavior.)
1929 The indicator has another function: if the indicator value is
1930 positive, it means that the value is not null, but it was
1931 truncated when it was stored in the host variable.
1935 If the argument
<literal>-r no_indicator
</literal> is passed to
1936 the preprocessor
<command>ecpg
</command>, it works in
1937 <quote>no-indicator
</quote> mode. In no-indicator mode, if no
1938 indicator variable is specified, null values are signaled (on
1939 input and output) for character string types as empty string and
1940 for integer types as the lowest possible value for type (for
1941 example,
<symbol>INT_MIN
</symbol> for
<type>int
</type>).
1946 <sect1 id=
"ecpg-dynamic">
1947 <title>Dynamic SQL
</title>
1950 In many cases, the particular SQL statements that an application
1951 has to execute are known at the time the application is written.
1952 In some cases, however, the SQL statements are composed at run time
1953 or provided by an external source. In these cases you cannot embed
1954 the SQL statements directly into the C source code, but there is a
1955 facility that allows you to call arbitrary SQL statements that you
1956 provide in a string variable.
1959 <sect2 id=
"ecpg-dynamic-without-result">
1960 <title>Executing Statements without a Result Set
</title>
1963 The simplest way to execute an arbitrary SQL statement is to use
1964 the command
<command>EXECUTE IMMEDIATE
</command>. For example:
1966 EXEC SQL BEGIN DECLARE SECTION;
1967 const char *stmt =
"CREATE TABLE test1 (...);";
1968 EXEC SQL END DECLARE SECTION;
1970 EXEC SQL EXECUTE IMMEDIATE :stmt;
1972 <command>EXECUTE IMMEDIATE
</command> can be used for SQL
1973 statements that do not return a result set (e.g.,
1974 DDL,
<command>INSERT
</command>,
<command>UPDATE
</command>,
1975 <command>DELETE
</command>). You cannot execute statements that
1976 retrieve data (e.g.,
<command>SELECT
</command>) this way. The
1977 next section describes how to do that.
1981 <sect2 id=
"ecpg-dynamic-input">
1982 <title>Executing a Statement with Input Parameters
</title>
1985 A more powerful way to execute arbitrary SQL statements is to
1986 prepare them once and execute the prepared statement as often as
1987 you like. It is also possible to prepare a generalized version of
1988 a statement and then execute specific versions of it by
1989 substituting parameters. When preparing the statement, write
1990 question marks where you want to substitute parameters later. For
1993 EXEC SQL BEGIN DECLARE SECTION;
1994 const char *stmt =
"INSERT INTO test1 VALUES(?, ?);";
1995 EXEC SQL END DECLARE SECTION;
1997 EXEC SQL PREPARE mystmt FROM :stmt;
1999 EXEC SQL EXECUTE mystmt USING
42, 'foobar';
2004 When you don't need the prepared statement anymore, you should
2007 EXEC SQL DEALLOCATE PREPARE
<replaceable>name
</replaceable>;
2012 <sect2 id=
"ecpg-dynamic-with-result">
2013 <title>Executing a Statement with a Result Set
</title>
2016 To execute an SQL statement with a single result row,
2017 <command>EXECUTE
</command> can be used. To save the result, add
2018 an
<literal>INTO
</literal> clause.
2019 <programlisting><![CDATA[
2020 EXEC SQL BEGIN DECLARE SECTION;
2021 const char *stmt =
"SELECT a, b, c FROM test1 WHERE a > ?";
2024 EXEC SQL END DECLARE SECTION;
2026 EXEC SQL PREPARE mystmt FROM :stmt;
2028 EXEC SQL EXECUTE mystmt INTO :v1, :v2, :v3 USING
37;
2031 An
<command>EXECUTE
</command> command can have an
2032 <literal>INTO
</literal> clause, a
<literal>USING
</literal> clause,
2037 If a query is expected to return more than one result row, a
2038 cursor should be used, as in the following example.
2039 (See
<xref linkend=
"ecpg-cursors"/> for more details about the
2042 EXEC SQL BEGIN DECLARE SECTION;
2045 char *stmt =
"SELECT u.usename as dbaname, d.datname "
2046 " FROM pg_database d, pg_user u "
2047 " WHERE d.datdba = u.usesysid";
2048 EXEC SQL END DECLARE SECTION;
2050 EXEC SQL CONNECT TO testdb AS con1 USER testuser;
2051 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
2053 EXEC SQL PREPARE stmt1 FROM :stmt;
2055 EXEC SQL DECLARE cursor1 CURSOR FOR stmt1;
2056 EXEC SQL OPEN cursor1;
2058 EXEC SQL WHENEVER NOT FOUND DO BREAK;
2062 EXEC SQL FETCH cursor1 INTO :dbaname,:datname;
2063 printf(
"dbaname=%s, datname=%s\n", dbaname, datname);
2066 EXEC SQL CLOSE cursor1;
2069 EXEC SQL DISCONNECT ALL;
2075 <sect1 id=
"ecpg-pgtypes">
2076 <title>pgtypes Library
</title>
2079 The pgtypes library maps
<productname>PostgreSQL
</productname> database
2080 types to C equivalents that can be used in C programs. It also offers
2081 functions to do basic calculations with those types within C, i.e., without
2082 the help of the
<productname>PostgreSQL
</productname> server. See the
2084 <programlisting><![CDATA[
2085 EXEC SQL BEGIN DECLARE SECTION;
2087 timestamp ts1, tsout;
2090 EXEC SQL END DECLARE SECTION;
2092 PGTYPESdate_today(&date1);
2093 EXEC SQL SELECT started, duration INTO :ts1, :iv1 FROM datetbl WHERE d=:date1;
2094 PGTYPEStimestamp_add_interval(&ts1, &iv1, &tsout);
2095 out = PGTYPEStimestamp_to_asc(&tsout);
2096 printf(
"Started + duration: %s\n", out);
2097 PGTYPESchar_free(out);
2102 <sect2 id=
"ecpg-pgtypes-cstrings">
2103 <title>Character Strings
</title>
2105 Some functions such as
<function>PGTYPESnumeric_to_asc
</function> return
2106 a pointer to a freshly allocated character string. These results should be
2107 freed with
<function>PGTYPESchar_free
</function> instead of
2108 <function>free
</function>. (This is important only on Windows, where
2109 memory allocation and release sometimes need to be done by the same
2114 <sect2 id=
"ecpg-pgtypes-numeric">
2115 <title>The numeric Type
</title>
2117 The numeric type offers to do calculations with arbitrary precision. See
2118 <xref linkend=
"datatype-numeric"/> for the equivalent type in the
2119 <productname>PostgreSQL
</productname> server. Because of the arbitrary precision this
2120 variable needs to be able to expand and shrink dynamically. That's why you
2121 can only create numeric variables on the heap, by means of the
2122 <function>PGTYPESnumeric_new
</function> and
<function>PGTYPESnumeric_free
</function>
2123 functions. The decimal type, which is similar but limited in precision,
2124 can be created on the stack as well as on the heap.
2127 The following functions can be used to work with the numeric type:
2129 <varlistentry id=
"ecpg-pgtypes-numeric-new">
2130 <term><function>PGTYPESnumeric_new
</function></term>
2133 Request a pointer to a newly allocated numeric variable.
2135 numeric *PGTYPESnumeric_new(void);
2141 <varlistentry id=
"ecpg-pgtypes-numeric-free">
2142 <term><function>PGTYPESnumeric_free
</function></term>
2145 Free a numeric type, release all of its memory.
2147 void PGTYPESnumeric_free(numeric *var);
2153 <varlistentry id=
"ecpg-pgtypes-numeric-from-asc">
2154 <term><function>PGTYPESnumeric_from_asc
</function></term>
2157 Parse a numeric type from its string notation.
2159 numeric *PGTYPESnumeric_from_asc(char *str, char **endptr);
2161 Valid formats are for example:
2162 <literal>-
2</literal>,
2163 <literal>.794</literal>,
2164 <literal>+
3.44</literal>,
2165 <literal>592.49E07
</literal> or
2166 <literal>-
32.84e-4</literal>.
2167 If the value could be parsed successfully, a valid pointer is returned,
2168 else the NULL pointer. At the moment ECPG always parses the complete
2169 string and so it currently does not support to store the address of the
2170 first invalid character in
<literal>*endptr
</literal>. You can safely
2171 set
<literal>endptr
</literal> to NULL.
2176 <varlistentry id=
"ecpg-pgtypes-numeric-to-asc">
2177 <term><function>PGTYPESnumeric_to_asc
</function></term>
2180 Returns a pointer to a string allocated by
<function>malloc
</function> that contains the string
2181 representation of the numeric type
<literal>num
</literal>.
2183 char *PGTYPESnumeric_to_asc(numeric *num, int dscale);
2185 The numeric value will be printed with
<literal>dscale
</literal> decimal
2186 digits, with rounding applied if necessary.
2187 The result must be freed with
<function>PGTYPESchar_free()
</function>.
2192 <varlistentry id=
"ecpg-pgtypes-numeric-add">
2193 <term><function>PGTYPESnumeric_add
</function></term>
2196 Add two numeric variables into a third one.
2198 int PGTYPESnumeric_add(numeric *var1, numeric *var2, numeric *result);
2200 The function adds the variables
<literal>var1
</literal> and
2201 <literal>var2
</literal> into the result variable
2202 <literal>result
</literal>.
2203 The function returns
0 on success and -
1 in case of error.
2208 <varlistentry id=
"ecpg-pgtypes-numeric-sub">
2209 <term><function>PGTYPESnumeric_sub
</function></term>
2212 Subtract two numeric variables and return the result in a third one.
2214 int PGTYPESnumeric_sub(numeric *var1, numeric *var2, numeric *result);
2216 The function subtracts the variable
<literal>var2
</literal> from
2217 the variable
<literal>var1
</literal>. The result of the operation is
2218 stored in the variable
<literal>result
</literal>.
2219 The function returns
0 on success and -
1 in case of error.
2224 <varlistentry id=
"ecpg-pgtypes-numeric-mul">
2225 <term><function>PGTYPESnumeric_mul
</function></term>
2228 Multiply two numeric variables and return the result in a third one.
2230 int PGTYPESnumeric_mul(numeric *var1, numeric *var2, numeric *result);
2232 The function multiplies the variables
<literal>var1
</literal> and
2233 <literal>var2
</literal>. The result of the operation is stored in the
2234 variable
<literal>result
</literal>.
2235 The function returns
0 on success and -
1 in case of error.
2240 <varlistentry id=
"ecpg-pgtypes-numeric-div">
2241 <term><function>PGTYPESnumeric_div
</function></term>
2244 Divide two numeric variables and return the result in a third one.
2246 int PGTYPESnumeric_div(numeric *var1, numeric *var2, numeric *result);
2248 The function divides the variables
<literal>var1
</literal> by
2249 <literal>var2
</literal>. The result of the operation is stored in the
2250 variable
<literal>result
</literal>.
2251 The function returns
0 on success and -
1 in case of error.
2256 <varlistentry id=
"ecpg-pgtypes-numeric-cmp">
2257 <term><function>PGTYPESnumeric_cmp
</function></term>
2260 Compare two numeric variables.
2262 int PGTYPESnumeric_cmp(numeric *var1, numeric *var2)
2264 This function compares two numeric variables. In case of error,
2265 <literal>INT_MAX
</literal> is returned. On success, the function
2266 returns one of three possible results:
2270 1, if
<literal>var1
</literal> is bigger than
<literal>var2
</literal>
2275 -
1, if
<literal>var1
</literal> is smaller than
<literal>var2
</literal>
2280 0, if
<literal>var1
</literal> and
<literal>var2
</literal> are equal
2288 <varlistentry id=
"ecpg-pgtypes-numeric-from-int">
2289 <term><function>PGTYPESnumeric_from_int
</function></term>
2292 Convert an int variable to a numeric variable.
2294 int PGTYPESnumeric_from_int(signed int int_val, numeric *var);
2296 This function accepts a variable of type signed int and stores it
2297 in the numeric variable
<literal>var
</literal>. Upon success,
0 is returned and
2298 -
1 in case of a failure.
2303 <varlistentry id=
"ecpg-pgtypes-numeric-from-long">
2304 <term><function>PGTYPESnumeric_from_long
</function></term>
2307 Convert a long int variable to a numeric variable.
2309 int PGTYPESnumeric_from_long(signed long int long_val, numeric *var);
2311 This function accepts a variable of type signed long int and stores it
2312 in the numeric variable
<literal>var
</literal>. Upon success,
0 is returned and
2313 -
1 in case of a failure.
2318 <varlistentry id=
"ecpg-pgtypes-numeric-copy">
2319 <term><function>PGTYPESnumeric_copy
</function></term>
2322 Copy over one numeric variable into another one.
2324 int PGTYPESnumeric_copy(numeric *src, numeric *dst);
2326 This function copies over the value of the variable that
2327 <literal>src
</literal> points to into the variable that
<literal>dst
</literal>
2328 points to. It returns
0 on success and -
1 if an error occurs.
2333 <varlistentry id=
"ecpg-pgtypes-numeric-from-double">
2334 <term><function>PGTYPESnumeric_from_double
</function></term>
2337 Convert a variable of type double to a numeric.
2339 int PGTYPESnumeric_from_double(double d, numeric *dst);
2341 This function accepts a variable of type double and stores the result
2342 in the variable that
<literal>dst
</literal> points to. It returns
0 on success
2343 and -
1 if an error occurs.
2348 <varlistentry id=
"ecpg-pgtypes-numeric-to-double">
2349 <term><function>PGTYPESnumeric_to_double
</function></term>
2352 Convert a variable of type numeric to double.
2354 int PGTYPESnumeric_to_double(numeric *nv, double *dp)
2356 The function converts the numeric value from the variable that
2357 <literal>nv
</literal> points to into the double variable that
<literal>dp
</literal> points
2358 to. It returns
0 on success and -
1 if an error occurs, including
2359 overflow. On overflow, the global variable
<literal>errno
</literal> will be set
2360 to
<literal>PGTYPES_NUM_OVERFLOW
</literal> additionally.
2365 <varlistentry id=
"ecpg-pgtypes-numeric-to-int">
2366 <term><function>PGTYPESnumeric_to_int
</function></term>
2369 Convert a variable of type numeric to int.
2371 int PGTYPESnumeric_to_int(numeric *nv, int *ip);
2373 The function converts the numeric value from the variable that
2374 <literal>nv
</literal> points to into the integer variable that
<literal>ip
</literal>
2375 points to. It returns
0 on success and -
1 if an error occurs, including
2376 overflow. On overflow, the global variable
<literal>errno
</literal> will be set
2377 to
<literal>PGTYPES_NUM_OVERFLOW
</literal> additionally.
2382 <varlistentry id=
"ecpg-pgtypes-numeric-to-long">
2383 <term><function>PGTYPESnumeric_to_long
</function></term>
2386 Convert a variable of type numeric to long.
2388 int PGTYPESnumeric_to_long(numeric *nv, long *lp);
2390 The function converts the numeric value from the variable that
2391 <literal>nv
</literal> points to into the long integer variable that
2392 <literal>lp
</literal> points to. It returns
0 on success and -
1 if an error
2393 occurs, including overflow and underflow. On overflow, the global variable
2394 <literal>errno
</literal> will be set to
<literal>PGTYPES_NUM_OVERFLOW
</literal>
2395 and on underflow
<literal>errno
</literal> will be set to
2396 <literal>PGTYPES_NUM_UNDERFLOW
</literal>.
2401 <varlistentry id=
"ecpg-pgtypes-numeric-to-decimal">
2402 <term><function>PGTYPESnumeric_to_decimal
</function></term>
2405 Convert a variable of type numeric to decimal.
2407 int PGTYPESnumeric_to_decimal(numeric *src, decimal *dst);
2409 The function converts the numeric value from the variable that
2410 <literal>src
</literal> points to into the decimal variable that
2411 <literal>dst
</literal> points to. It returns
0 on success and -
1 if an error
2412 occurs, including overflow. On overflow, the global variable
2413 <literal>errno
</literal> will be set to
<literal>PGTYPES_NUM_OVERFLOW
</literal>
2419 <varlistentry id=
"ecpg-pgtypes-numeric-from-decimal">
2420 <term><function>PGTYPESnumeric_from_decimal
</function></term>
2423 Convert a variable of type decimal to numeric.
2425 int PGTYPESnumeric_from_decimal(decimal *src, numeric *dst);
2427 The function converts the decimal value from the variable that
2428 <literal>src
</literal> points to into the numeric variable that
2429 <literal>dst
</literal> points to. It returns
0 on success and -
1 if an error
2430 occurs. Since the decimal type is implemented as a limited version of
2431 the numeric type, overflow cannot occur with this conversion.
2439 <sect2 id=
"ecpg-pgtypes-date">
2440 <title>The date Type
</title>
2442 The date type in C enables your programs to deal with data of the SQL type
2443 date. See
<xref linkend=
"datatype-datetime"/> for the equivalent type in the
2444 <productname>PostgreSQL
</productname> server.
2447 The following functions can be used to work with the date type:
2449 <varlistentry id=
"pgtypesdatefromtimestamp">
2450 <term><function>PGTYPESdate_from_timestamp
</function></term>
2453 Extract the date part from a timestamp.
2455 date PGTYPESdate_from_timestamp(timestamp dt);
2457 The function receives a timestamp as its only argument and returns the
2458 extracted date part from this timestamp.
2463 <varlistentry id=
"pgtypesdatefromasc">
2464 <term><function>PGTYPESdate_from_asc
</function></term>
2467 Parse a date from its textual representation.
2469 date PGTYPESdate_from_asc(char *str, char **endptr);
2471 The function receives a C char* string
<literal>str
</literal> and a pointer to
2472 a C char* string
<literal>endptr
</literal>. At the moment ECPG always parses
2473 the complete string and so it currently does not support to store the
2474 address of the first invalid character in
<literal>*endptr
</literal>.
2475 You can safely set
<literal>endptr
</literal> to NULL.
2478 Note that the function always assumes MDY-formatted dates and there is
2479 currently no variable to change that within ECPG.
2482 <xref linkend=
"ecpg-pgtypesdate-from-asc-table"/> shows the allowed input formats.
2484 <table id=
"ecpg-pgtypesdate-from-asc-table">
2485 <title>Valid Input Formats for
<function>PGTYPESdate_from_asc
</function></title>
2489 <entry>Input
</entry>
2490 <entry>Result
</entry>
2495 <entry><literal>January
8,
1999</literal></entry>
2496 <entry><literal>January
8,
1999</literal></entry>
2499 <entry><literal>1999-
01-
08</literal></entry>
2500 <entry><literal>January
8,
1999</literal></entry>
2503 <entry><literal>1/
8/
1999</literal></entry>
2504 <entry><literal>January
8,
1999</literal></entry>
2507 <entry><literal>1/
18/
1999</literal></entry>
2508 <entry><literal>January
18,
1999</literal></entry>
2511 <entry><literal>01/
02/
03</literal></entry>
2512 <entry><literal>February
1,
2003</literal></entry>
2515 <entry><literal>1999-Jan-
08</literal></entry>
2516 <entry><literal>January
8,
1999</literal></entry>
2519 <entry><literal>Jan-
08-
1999</literal></entry>
2520 <entry><literal>January
8,
1999</literal></entry>
2523 <entry><literal>08-Jan-
1999</literal></entry>
2524 <entry><literal>January
8,
1999</literal></entry>
2527 <entry><literal>99-Jan-
08</literal></entry>
2528 <entry><literal>January
8,
1999</literal></entry>
2531 <entry><literal>08-Jan-
99</literal></entry>
2532 <entry><literal>January
8,
1999</literal></entry>
2535 <entry><literal>08-Jan-
06</literal></entry>
2536 <entry><literal>January
8,
2006</literal></entry>
2539 <entry><literal>Jan-
08-
99</literal></entry>
2540 <entry><literal>January
8,
1999</literal></entry>
2543 <entry><literal>19990108</literal></entry>
2544 <entry><literal>ISO
8601; January
8,
1999</literal></entry>
2547 <entry><literal>990108</literal></entry>
2548 <entry><literal>ISO
8601; January
8,
1999</literal></entry>
2551 <entry><literal>1999.008</literal></entry>
2552 <entry><literal>year and day of year
</literal></entry>
2555 <entry><literal>J2451187
</literal></entry>
2556 <entry><literal>Julian day
</literal></entry>
2559 <entry><literal>January
8,
99 BC
</literal></entry>
2560 <entry><literal>year
99 before the Common Era
</literal></entry>
2568 <varlistentry id=
"pgtypesdatetoasc">
2569 <term><function>PGTYPESdate_to_asc
</function></term>
2572 Return the textual representation of a date variable.
2574 char *PGTYPESdate_to_asc(date dDate);
2576 The function receives the date
<literal>dDate
</literal> as its only parameter.
2577 It will output the date in the form
<literal>1999-
01-
18</literal>, i.e., in the
2578 <literal>YYYY-MM-DD
</literal> format.
2579 The result must be freed with
<function>PGTYPESchar_free()
</function>.
2584 <varlistentry id=
"pgtypesdatejulmdy">
2585 <term><function>PGTYPESdate_julmdy
</function></term>
2588 Extract the values for the day, the month and the year from a variable
2591 void PGTYPESdate_julmdy(date d, int *mdy);
2593 <!-- almost same description as for rjulmdy() -->
2594 The function receives the date
<literal>d
</literal> and a pointer to an array
2595 of
3 integer values
<literal>mdy
</literal>. The variable name indicates
2596 the sequential order:
<literal>mdy[
0]
</literal> will be set to contain the
2597 number of the month,
<literal>mdy[
1]
</literal> will be set to the value of the
2598 day and
<literal>mdy[
2]
</literal> will contain the year.
2603 <varlistentry id=
"pgtypesdatemdyjul">
2604 <term><function>PGTYPESdate_mdyjul
</function></term>
2607 Create a date value from an array of
3 integers that specify the
2608 day, the month and the year of the date.
2610 void PGTYPESdate_mdyjul(int *mdy, date *jdate);
2612 The function receives the array of the
3 integers (
<literal>mdy
</literal>) as
2613 its first argument and as its second argument a pointer to a variable
2614 of type date that should hold the result of the operation.
2619 <varlistentry id=
"pgtypesdatedayofweek">
2620 <term><function>PGTYPESdate_dayofweek
</function></term>
2623 Return a number representing the day of the week for a date value.
2625 int PGTYPESdate_dayofweek(date d);
2627 The function receives the date variable
<literal>d
</literal> as its only
2628 argument and returns an integer that indicates the day of the week for
2671 <varlistentry id=
"pgtypesdatetoday">
2672 <term><function>PGTYPESdate_today
</function></term>
2675 Get the current date.
2677 void PGTYPESdate_today(date *d);
2679 The function receives a pointer to a date variable (
<literal>d
</literal>)
2680 that it sets to the current date.
2685 <varlistentry id=
"pgtypesdatefmtasc">
2686 <term><function>PGTYPESdate_fmt_asc
</function></term>
2689 Convert a variable of type date to its textual representation using a
2692 int PGTYPESdate_fmt_asc(date dDate, char *fmtstring, char *outbuf);
2694 The function receives the date to convert (
<literal>dDate
</literal>), the
2695 format mask (
<literal>fmtstring
</literal>) and the string that will hold the
2696 textual representation of the date (
<literal>outbuf
</literal>).
2699 On success,
0 is returned and a negative value if an error occurred.
2702 The following literals are the field specifiers you can use:
2706 <literal>dd
</literal> - The number of the day of the month.
2711 <literal>mm
</literal> - The number of the month of the year.
2716 <literal>yy
</literal> - The number of the year as a two digit number.
2721 <literal>yyyy
</literal> - The number of the year as a four digit number.
2726 <literal>ddd
</literal> - The name of the day (abbreviated).
2731 <literal>mmm
</literal> - The name of the month (abbreviated).
2735 All other characters are copied
1:
1 to the output string.
2738 <xref linkend=
"ecpg-pgtypesdate-fmt-asc-example-table"/> indicates a few possible formats. This will give
2739 you an idea of how to use this function. All output lines are based on
2740 the same date: November
23,
1959.
2742 <table id=
"ecpg-pgtypesdate-fmt-asc-example-table">
2743 <title>Valid Input Formats for
<function>PGTYPESdate_fmt_asc
</function></title>
2747 <entry>Format
</entry>
2748 <entry>Result
</entry>
2753 <entry><literal>mmddyy
</literal></entry>
2754 <entry><literal>112359</literal></entry>
2757 <entry><literal>ddmmyy
</literal></entry>
2758 <entry><literal>231159</literal></entry>
2761 <entry><literal>yymmdd
</literal></entry>
2762 <entry><literal>591123</literal></entry>
2765 <entry><literal>yy/mm/dd
</literal></entry>
2766 <entry><literal>59/
11/
23</literal></entry>
2769 <entry><literal>yy mm dd
</literal></entry>
2770 <entry><literal>59 11 23</literal></entry>
2773 <entry><literal>yy.mm.dd
</literal></entry>
2774 <entry><literal>59.11.23</literal></entry>
2777 <entry><literal>.mm.yyyy.dd.
</literal></entry>
2778 <entry><literal>.11.1959.23.
</literal></entry>
2781 <entry><literal>mmm. dd, yyyy
</literal></entry>
2782 <entry><literal>Nov.
23,
1959</literal></entry>
2785 <entry><literal>mmm dd yyyy
</literal></entry>
2786 <entry><literal>Nov
23 1959</literal></entry>
2789 <entry><literal>yyyy dd mm
</literal></entry>
2790 <entry><literal>1959 23 11</literal></entry>
2793 <entry><literal>ddd, mmm. dd, yyyy
</literal></entry>
2794 <entry><literal>Mon, Nov.
23,
1959</literal></entry>
2797 <entry><literal>(ddd) mmm. dd, yyyy
</literal></entry>
2798 <entry><literal>(Mon) Nov.
23,
1959</literal></entry>
2806 <varlistentry id=
"pgtypesdatedefmtasc">
2807 <term><function>PGTYPESdate_defmt_asc
</function></term>
2810 Use a format mask to convert a C
<type>char*
</type> string to a value of type
2813 int PGTYPESdate_defmt_asc(date *d, char *fmt, char *str);
2815 <!-- same description as rdefmtdate -->
2816 The function receives a pointer to the date value that should hold the
2817 result of the operation (
<literal>d
</literal>), the format mask to use for
2818 parsing the date (
<literal>fmt
</literal>) and the C char* string containing
2819 the textual representation of the date (
<literal>str
</literal>). The textual
2820 representation is expected to match the format mask. However you do not
2821 need to have a
1:
1 mapping of the string to the format mask. The
2822 function only analyzes the sequential order and looks for the literals
2823 <literal>yy
</literal> or
<literal>yyyy
</literal> that indicate the
2824 position of the year,
<literal>mm
</literal> to indicate the position of
2825 the month and
<literal>dd
</literal> to indicate the position of the
2829 <xref linkend=
"ecpg-rdefmtdate-example-table"/> indicates a few possible formats. This will give
2830 you an idea of how to use this function.
2832 <table id=
"ecpg-rdefmtdate-example-table">
2833 <title>Valid Input Formats for
<function>rdefmtdate
</function></title>
2837 <entry>Format
</entry>
2838 <entry>String
</entry>
2839 <entry>Result
</entry>
2844 <entry><literal>ddmmyy
</literal></entry>
2845 <entry><literal>21-
2-
54</literal></entry>
2846 <entry><literal>1954-
02-
21</literal></entry>
2849 <entry><literal>ddmmyy
</literal></entry>
2850 <entry><literal>2-
12-
54</literal></entry>
2851 <entry><literal>1954-
12-
02</literal></entry>
2854 <entry><literal>ddmmyy
</literal></entry>
2855 <entry><literal>20111954</literal></entry>
2856 <entry><literal>1954-
11-
20</literal></entry>
2859 <entry><literal>ddmmyy
</literal></entry>
2860 <entry><literal>130464</literal></entry>
2861 <entry><literal>1964-
04-
13</literal></entry>
2864 <entry><literal>mmm.dd.yyyy
</literal></entry>
2865 <entry><literal>MAR-
12-
1967</literal></entry>
2866 <entry><literal>1967-
03-
12</literal></entry>
2869 <entry><literal>yy/mm/dd
</literal></entry>
2870 <entry><literal>1954, February
3rd
</literal></entry>
2871 <entry><literal>1954-
02-
03</literal></entry>
2874 <entry><literal>mmm.dd.yyyy
</literal></entry>
2875 <entry><literal>041269</literal></entry>
2876 <entry><literal>1969-
04-
12</literal></entry>
2879 <entry><literal>yy/mm/dd
</literal></entry>
2880 <entry><literal>In the year
2525, in the month of July, mankind will be alive on the
28th day
</literal></entry>
2881 <entry><literal>2525-
07-
28</literal></entry>
2884 <entry><literal>dd-mm-yy
</literal></entry>
2885 <entry><literal>I said on the
28th of July in the year
2525</literal></entry>
2886 <entry><literal>2525-
07-
28</literal></entry>
2889 <entry><literal>mmm.dd.yyyy
</literal></entry>
2890 <entry><literal>9/
14/
58</literal></entry>
2891 <entry><literal>1958-
09-
14</literal></entry>
2894 <entry><literal>yy/mm/dd
</literal></entry>
2895 <entry><literal>47/
03/
29</literal></entry>
2896 <entry><literal>1947-
03-
29</literal></entry>
2899 <entry><literal>mmm.dd.yyyy
</literal></entry>
2900 <entry><literal>oct
28 1975</literal></entry>
2901 <entry><literal>1975-
10-
28</literal></entry>
2904 <entry><literal>mmddyy
</literal></entry>
2905 <entry><literal>Nov
14th,
1985</literal></entry>
2906 <entry><literal>1985-
11-
14</literal></entry>
2917 <sect2 id=
"ecpg-pgtypes-timestamp">
2918 <title>The timestamp Type
</title>
2920 The timestamp type in C enables your programs to deal with data of the SQL
2921 type timestamp. See
<xref linkend=
"datatype-datetime"/> for the equivalent
2922 type in the
<productname>PostgreSQL
</productname> server.
2925 The following functions can be used to work with the timestamp type:
2927 <varlistentry id=
"pgtypestimestampfromasc">
2928 <term><function>PGTYPEStimestamp_from_asc
</function></term>
2931 Parse a timestamp from its textual representation into a timestamp
2934 timestamp PGTYPEStimestamp_from_asc(char *str, char **endptr);
2936 The function receives the string to parse (
<literal>str
</literal>) and a
2937 pointer to a C char* (
<literal>endptr
</literal>).
2938 At the moment ECPG always parses
2939 the complete string and so it currently does not support to store the
2940 address of the first invalid character in
<literal>*endptr
</literal>.
2941 You can safely set
<literal>endptr
</literal> to NULL.
2944 The function returns the parsed timestamp on success. On error,
2945 <literal>PGTYPESInvalidTimestamp
</literal> is returned and
<varname>errno
</varname> is
2946 set to
<literal>PGTYPES_TS_BAD_TIMESTAMP
</literal>. See
<xref linkend=
"pgtypesinvalidtimestamp"/> for important notes on this value.
2949 In general, the input string can contain any combination of an allowed
2950 date specification, a whitespace character and an allowed time
2951 specification. Note that time zones are not supported by ECPG. It can
2952 parse them but does not apply any calculation as the
2953 <productname>PostgreSQL
</productname> server does for example. Timezone
2954 specifiers are silently discarded.
2957 <xref linkend=
"ecpg-pgtypestimestamp-from-asc-example-table"/> contains a few examples for input strings.
2959 <table id=
"ecpg-pgtypestimestamp-from-asc-example-table">
2960 <title>Valid Input Formats for
<function>PGTYPEStimestamp_from_asc
</function></title>
2964 <entry>Input
</entry>
2965 <entry>Result
</entry>
2970 <entry><literal>1999-
01-
08 04:
05:
06</literal></entry>
2971 <entry><literal>1999-
01-
08 04:
05:
06</literal></entry>
2974 <entry><literal>January
8 04:
05:
06 1999 PST
</literal></entry>
2975 <entry><literal>1999-
01-
08 04:
05:
06</literal></entry>
2978 <entry><literal>1999-Jan-
08 04:
05:
06.789-
8</literal></entry>
2979 <entry><literal>1999-
01-
08 04:
05:
06.789 (time zone specifier ignored)
</literal></entry>
2982 <entry><literal>J2451187
04:
05-
08:
00</literal></entry>
2983 <entry><literal>1999-
01-
08 04:
05:
00 (time zone specifier ignored)
</literal></entry>
2991 <varlistentry id=
"pgtypestimestamptoasc">
2992 <term><function>PGTYPEStimestamp_to_asc
</function></term>
2995 Converts a date to a C char* string.
2997 char *PGTYPEStimestamp_to_asc(timestamp tstamp);
2999 The function receives the timestamp
<literal>tstamp
</literal> as
3000 its only argument and returns an allocated string that contains the
3001 textual representation of the timestamp.
3002 The result must be freed with
<function>PGTYPESchar_free()
</function>.
3007 <varlistentry id=
"pgtypestimestampcurrent">
3008 <term><function>PGTYPEStimestamp_current
</function></term>
3011 Retrieve the current timestamp.
3013 void PGTYPEStimestamp_current(timestamp *ts);
3015 The function retrieves the current timestamp and saves it into the
3016 timestamp variable that
<literal>ts
</literal> points to.
3021 <varlistentry id=
"pgtypestimestampfmtasc">
3022 <term><function>PGTYPEStimestamp_fmt_asc
</function></term>
3025 Convert a timestamp variable to a C char* using a format mask.
3027 int PGTYPEStimestamp_fmt_asc(timestamp *ts, char *output, int str_len, char *fmtstr);
3029 The function receives a pointer to the timestamp to convert as its
3030 first argument (
<literal>ts
</literal>), a pointer to the output buffer
3031 (
<literal>output
</literal>), the maximal length that has been allocated for
3032 the output buffer (
<literal>str_len
</literal>) and the format mask to
3033 use for the conversion (
<literal>fmtstr
</literal>).
3036 Upon success, the function returns
0 and a negative value if an
3040 You can use the following format specifiers for the format mask. The
3041 format specifiers are the same ones that are used in the
3042 <function>strftime
</function> function in
<productname>libc
</productname>. Any
3043 non-format specifier will be copied into the output buffer.
3044 <!-- This is from the FreeBSD man page:
3045 http://www.freebsd.org/cgi/man.cgi?query=strftime&apropos=0&sektion=3&manpath=FreeBSD+7.0-current&format=html
3050 <literal>%A
</literal> - is replaced by national representation of
3051 the full weekday name.
3056 <literal>%a
</literal> - is replaced by national representation of
3057 the abbreviated weekday name.
3062 <literal>%B
</literal> - is replaced by national representation of
3063 the full month name.
3068 <literal>%b
</literal> - is replaced by national representation of
3069 the abbreviated month name.
3074 <literal>%C
</literal> - is replaced by (year /
100) as decimal
3075 number; single digits are preceded by a zero.
3080 <literal>%c
</literal> - is replaced by national representation of
3086 <literal>%D
</literal> - is equivalent to
3087 <literal>%m/%d/%y
</literal>.
3092 <literal>%d
</literal> - is replaced by the day of the month as a
3093 decimal number (
01–31).
3098 <literal>%E*
</literal> <literal>%O*
</literal> - POSIX locale
3099 extensions. The sequences
3100 <literal>%Ec
</literal>
3101 <literal>%EC
</literal>
3102 <literal>%Ex
</literal>
3103 <literal>%EX
</literal>
3104 <literal>%Ey
</literal>
3105 <literal>%EY
</literal>
3106 <literal>%Od
</literal>
3107 <literal>%Oe
</literal>
3108 <literal>%OH
</literal>
3109 <literal>%OI
</literal>
3110 <literal>%Om
</literal>
3111 <literal>%OM
</literal>
3112 <literal>%OS
</literal>
3113 <literal>%Ou
</literal>
3114 <literal>%OU
</literal>
3115 <literal>%OV
</literal>
3116 <literal>%Ow
</literal>
3117 <literal>%OW
</literal>
3118 <literal>%Oy
</literal>
3119 are supposed to provide alternative representations.
3122 Additionally
<literal>%OB
</literal> implemented to represent
3123 alternative months names (used standalone, without day mentioned).
3128 <literal>%e
</literal> - is replaced by the day of month as a decimal
3129 number (
1–31); single digits are preceded by a blank.
3134 <literal>%F
</literal> - is equivalent to
<literal>%Y-%m-%d
</literal>.
3139 <literal>%G
</literal> - is replaced by a year as a decimal number
3140 with century. This year is the one that contains the greater part of
3141 the week (Monday as the first day of the week).
3146 <literal>%g
</literal> - is replaced by the same year as in
3147 <literal>%G
</literal>, but as a decimal number without century
3153 <literal>%H
</literal> - is replaced by the hour (
24-hour clock) as a
3154 decimal number (
00–23).
3159 <literal>%h
</literal> - the same as
<literal>%b
</literal>.
3164 <literal>%I
</literal> - is replaced by the hour (
12-hour clock) as a
3165 decimal number (
01–12).
3170 <literal>%j
</literal> - is replaced by the day of the year as a
3171 decimal number (
001–366).
3176 <literal>%k
</literal> - is replaced by the hour (
24-hour clock) as a
3177 decimal number (
0–23); single digits are preceded by a blank.
3182 <literal>%l
</literal> - is replaced by the hour (
12-hour clock) as a
3183 decimal number (
1–12); single digits are preceded by a blank.
3188 <literal>%M
</literal> - is replaced by the minute as a decimal
3189 number (
00–59).
3194 <literal>%m
</literal> - is replaced by the month as a decimal number
3200 <literal>%n
</literal> - is replaced by a newline.
3205 <literal>%O*
</literal> - the same as
<literal>%E*
</literal>.
3210 <literal>%p
</literal> - is replaced by national representation of
3211 either
<quote>ante meridiem
</quote> or
<quote>post meridiem
</quote> as appropriate.
3216 <literal>%R
</literal> - is equivalent to
<literal>%H:%M
</literal>.
3221 <literal>%r
</literal> - is equivalent to
<literal>%I:%M:%S
3227 <literal>%S
</literal> - is replaced by the second as a decimal
3228 number (
00–60).
3233 <literal>%s
</literal> - is replaced by the number of seconds since
3239 <literal>%T
</literal> - is equivalent to
<literal>%H:%M:%S
</literal>
3244 <literal>%t
</literal> - is replaced by a tab.
3249 <literal>%U
</literal> - is replaced by the week number of the year
3250 (Sunday as the first day of the week) as a decimal number (
00–53).
3255 <literal>%u
</literal> - is replaced by the weekday (Monday as the
3256 first day of the week) as a decimal number (
1–7).
3261 <literal>%V
</literal> - is replaced by the week number of the year
3262 (Monday as the first day of the week) as a decimal number (
01–53).
3263 If the week containing January
1 has four or more days in the new
3264 year, then it is week
1; otherwise it is the last week of the
3265 previous year, and the next week is week
1.
3270 <literal>%v
</literal> - is equivalent to
3271 <literal>%e-%b-%Y
</literal>.
3276 <literal>%W
</literal> - is replaced by the week number of the year
3277 (Monday as the first day of the week) as a decimal number (
00–53).
3282 <literal>%w
</literal> - is replaced by the weekday (Sunday as the
3283 first day of the week) as a decimal number (
0–6).
3288 <literal>%X
</literal> - is replaced by national representation of
3294 <literal>%x
</literal> - is replaced by national representation of
3300 <literal>%Y
</literal> - is replaced by the year with century as a
3306 <literal>%y
</literal> - is replaced by the year without century as a
3307 decimal number (
00–99).
3312 <literal>%Z
</literal> - is replaced by the time zone name.
3317 <literal>%z
</literal> - is replaced by the time zone offset from
3318 UTC; a leading plus sign stands for east of UTC, a minus sign for
3319 west of UTC, hours and minutes follow with two digits each and no
3320 delimiter between them (common form for
<ulink url=
"https://datatracker.ietf.org/doc/html/rfc822">RFC
822</ulink> date headers).
3325 <literal>%+
</literal> - is replaced by national representation of
3331 <literal>%-*
</literal> - GNU libc extension. Do not do any padding
3332 when performing numerical outputs.
3337 $_* - GNU libc extension. Explicitly specify space for padding.
3342 <literal>%
0*
</literal> - GNU libc extension. Explicitly specify zero
3348 <literal>%%
</literal> - is replaced by
<literal>%
</literal>.
3356 <varlistentry id=
"pgtypestimestampsub">
3357 <term><function>PGTYPEStimestamp_sub
</function></term>
3360 Subtract one timestamp from another one and save the result in a
3361 variable of type interval.
3363 int PGTYPEStimestamp_sub(timestamp *ts1, timestamp *ts2, interval *iv);
3365 The function will subtract the timestamp variable that
<literal>ts2
</literal>
3366 points to from the timestamp variable that
<literal>ts1
</literal> points to
3367 and will store the result in the interval variable that
<literal>iv
</literal>
3371 Upon success, the function returns
0 and a negative value if an
3377 <varlistentry id=
"pgtypestimestampdefmtasc">
3378 <term><function>PGTYPEStimestamp_defmt_asc
</function></term>
3381 Parse a timestamp value from its textual representation using a
3384 int PGTYPEStimestamp_defmt_asc(char *str, char *fmt, timestamp *d);
3386 The function receives the textual representation of a timestamp in the
3387 variable
<literal>str
</literal> as well as the formatting mask to use in the
3388 variable
<literal>fmt
</literal>. The result will be stored in the variable
3389 that
<literal>d
</literal> points to.
3392 If the formatting mask
<literal>fmt
</literal> is NULL, the function will fall
3393 back to the default formatting mask which is
<literal>%Y-%m-%d
3397 This is the reverse function to
<xref
3398 linkend=
"pgtypestimestampfmtasc"/>. See the documentation there in
3399 order to find out about the possible formatting mask entries.
3404 <varlistentry id=
"pgtypestimestampaddinterval">
3405 <term><function>PGTYPEStimestamp_add_interval
</function></term>
3408 Add an interval variable to a timestamp variable.
3410 int PGTYPEStimestamp_add_interval(timestamp *tin, interval *span, timestamp *tout);
3412 The function receives a pointer to a timestamp variable
<literal>tin
</literal>
3413 and a pointer to an interval variable
<literal>span
</literal>. It adds the
3414 interval to the timestamp and saves the resulting timestamp in the
3415 variable that
<literal>tout
</literal> points to.
3418 Upon success, the function returns
0 and a negative value if an
3424 <varlistentry id=
"pgtypestimestampsubinterval">
3425 <term><function>PGTYPEStimestamp_sub_interval
</function></term>
3428 Subtract an interval variable from a timestamp variable.
3430 int PGTYPEStimestamp_sub_interval(timestamp *tin, interval *span, timestamp *tout);
3432 The function subtracts the interval variable that
<literal>span
</literal>
3433 points to from the timestamp variable that
<literal>tin
</literal> points to
3434 and saves the result into the variable that
<literal>tout
</literal> points
3438 Upon success, the function returns
0 and a negative value if an
3447 <sect2 id=
"ecpg-pgtypes-interval">
3448 <title>The interval Type
</title>
3450 The interval type in C enables your programs to deal with data of the SQL
3451 type interval. See
<xref linkend=
"datatype-datetime"/> for the equivalent
3452 type in the
<productname>PostgreSQL
</productname> server.
3455 The following functions can be used to work with the interval type:
3458 <varlistentry id=
"pgtypesintervalnew">
3459 <term><function>PGTYPESinterval_new
</function></term>
3462 Return a pointer to a newly allocated interval variable.
3464 interval *PGTYPESinterval_new(void);
3470 <varlistentry id=
"pgtypesintervalfree">
3471 <term><function>PGTYPESinterval_free
</function></term>
3474 Release the memory of a previously allocated interval variable.
3476 void PGTYPESinterval_free(interval *intvl);
3482 <varlistentry id=
"pgtypesintervalfromasc">
3483 <term><function>PGTYPESinterval_from_asc
</function></term>
3486 Parse an interval from its textual representation.
3488 interval *PGTYPESinterval_from_asc(char *str, char **endptr);
3490 The function parses the input string
<literal>str
</literal> and returns a
3491 pointer to an allocated interval variable.
3492 At the moment ECPG always parses
3493 the complete string and so it currently does not support to store the
3494 address of the first invalid character in
<literal>*endptr
</literal>.
3495 You can safely set
<literal>endptr
</literal> to NULL.
3500 <varlistentry id=
"pgtypesintervaltoasc">
3501 <term><function>PGTYPESinterval_to_asc
</function></term>
3504 Convert a variable of type interval to its textual representation.
3506 char *PGTYPESinterval_to_asc(interval *span);
3508 The function converts the interval variable that
<literal>span
</literal>
3509 points to into a C char*. The output looks like this example:
3510 <literal>@
1 day
12 hours
59 mins
10 secs
</literal>.
3511 The result must be freed with
<function>PGTYPESchar_free()
</function>.
3516 <varlistentry id=
"pgtypesintervalcopy">
3517 <term><function>PGTYPESinterval_copy
</function></term>
3520 Copy a variable of type interval.
3522 int PGTYPESinterval_copy(interval *intvlsrc, interval *intvldest);
3524 The function copies the interval variable that
<literal>intvlsrc
</literal>
3525 points to into the variable that
<literal>intvldest
</literal> points to. Note
3526 that you need to allocate the memory for the destination variable
3535 <sect2 id=
"ecpg-pgtypes-decimal">
3536 <title>The decimal Type
</title>
3538 The decimal type is similar to the numeric type. However it is limited to
3539 a maximum precision of
30 significant digits. In contrast to the numeric
3540 type which can be created on the heap only, the decimal type can be
3541 created either on the stack or on the heap (by means of the functions
3542 <function>PGTYPESdecimal_new
</function> and
3543 <function>PGTYPESdecimal_free
</function>).
3544 There are a lot of other functions that deal with the decimal type in the
3545 <productname>Informix
</productname> compatibility mode described in
<xref
3546 linkend=
"ecpg-informix-compat"/>.
3549 The following functions can be used to work with the decimal type and are
3550 not only contained in the
<literal>libcompat
</literal> library.
3552 <varlistentry id=
"ecpg-pgtypes-decimal-new">
3553 <term><function>PGTYPESdecimal_new
</function></term>
3556 Request a pointer to a newly allocated decimal variable.
3558 decimal *PGTYPESdecimal_new(void);
3564 <varlistentry id=
"ecpg-pgtypes-decimal-free">
3565 <term><function>PGTYPESdecimal_free
</function></term>
3568 Free a decimal type, release all of its memory.
3570 void PGTYPESdecimal_free(decimal *var);
3579 <sect2 id=
"ecpg-pgtypes-errno">
3580 <title>errno Values of pgtypeslib
</title>
3583 <varlistentry id=
"ecpg-pgtypes-errno-pgtypes-num-bad-numeric">
3584 <term><literal>PGTYPES_NUM_BAD_NUMERIC
</literal></term>
3587 An argument should contain a numeric variable (or point to a numeric
3588 variable) but in fact its in-memory representation was invalid.
3593 <varlistentry id=
"ecpg-pgtypes-errno-pgtypes-num-overflow">
3594 <term><literal>PGTYPES_NUM_OVERFLOW
</literal></term>
3597 An overflow occurred. Since the numeric type can deal with almost
3598 arbitrary precision, converting a numeric variable into other types
3599 might cause overflow.
3604 <varlistentry id=
"ecpg-pgtypes-errno-pgtypes-num-underflow">
3605 <term><literal>PGTYPES_NUM_UNDERFLOW
</literal></term>
3608 An underflow occurred. Since the numeric type can deal with almost
3609 arbitrary precision, converting a numeric variable into other types
3610 might cause underflow.
3615 <varlistentry id=
"ecpg-pgtypes-errno-pgtypes-num-divide-zero">
3616 <term><literal>PGTYPES_NUM_DIVIDE_ZERO
</literal></term>
3619 A division by zero has been attempted.
3624 <varlistentry id=
"ecpg-pgtypes-errno-pgtypes-date-bad-date">
3625 <term><literal>PGTYPES_DATE_BAD_DATE
</literal></term>
3628 An invalid date string was passed to
3629 the
<function>PGTYPESdate_from_asc
</function> function.
3634 <varlistentry id=
"ecpg-pgtypes-errno-pgtypes-date-err-eargs">
3635 <term><literal>PGTYPES_DATE_ERR_EARGS
</literal></term>
3638 Invalid arguments were passed to the
3639 <function>PGTYPESdate_defmt_asc
</function> function.
3644 <varlistentry id=
"ecpg-pgtypes-errno-pgtypes-date-err-enoshortdate">
3645 <term><literal>PGTYPES_DATE_ERR_ENOSHORTDATE
</literal></term>
3648 An invalid token in the input string was found by the
3649 <function>PGTYPESdate_defmt_asc
</function> function.
3654 <varlistentry id=
"ecpg-pgtypes-errno-pgtypes-intvl-bad-interval">
3655 <term><literal>PGTYPES_INTVL_BAD_INTERVAL
</literal></term>
3658 An invalid interval string was passed to the
3659 <function>PGTYPESinterval_from_asc
</function> function, or an
3660 invalid interval value was passed to the
3661 <function>PGTYPESinterval_to_asc
</function> function.
3666 <varlistentry id=
"ecpg-pgtypes-errno-pgtypes-date-err-enotdmy">
3667 <term><literal>PGTYPES_DATE_ERR_ENOTDMY
</literal></term>
3670 There was a mismatch in the day/month/year assignment in the
3671 <function>PGTYPESdate_defmt_asc
</function> function.
3676 <varlistentry id=
"ecpg-pgtypes-errno-pgtypes-date-bad-day">
3677 <term><literal>PGTYPES_DATE_BAD_DAY
</literal></term>
3680 An invalid day of the month value was found by
3681 the
<function>PGTYPESdate_defmt_asc
</function> function.
3686 <varlistentry id=
"ecpg-pgtypes-errno-pgtypes-date-bad-month">
3687 <term><literal>PGTYPES_DATE_BAD_MONTH
</literal></term>
3690 An invalid month value was found by
3691 the
<function>PGTYPESdate_defmt_asc
</function> function.
3696 <varlistentry id=
"ecpg-pgtypes-errno-pgtypes-ts-bad-timestamp">
3697 <term><literal>PGTYPES_TS_BAD_TIMESTAMP
</literal></term>
3700 An invalid timestamp string pass passed to
3701 the
<function>PGTYPEStimestamp_from_asc
</function> function,
3702 or an invalid timestamp value was passed to
3703 the
<function>PGTYPEStimestamp_to_asc
</function> function.
3708 <varlistentry id=
"ecpg-pgtypes-errno-pgtypes-ts-err-einftime">
3709 <term><literal>PGTYPES_TS_ERR_EINFTIME
</literal></term>
3712 An infinite timestamp value was encountered in a context that
3721 <sect2 id=
"ecpg-pgtypes-constants">
3722 <title>Special Constants of pgtypeslib
</title>
3725 <varlistentry id=
"pgtypesinvalidtimestamp">
3726 <term><literal>PGTYPESInvalidTimestamp
</literal></term>
3729 A value of type timestamp representing an invalid time stamp. This is
3730 returned by the function
<function>PGTYPEStimestamp_from_asc
</function> on
3732 Note that due to the internal representation of the
<type>timestamp
</type> data type,
3733 <literal>PGTYPESInvalidTimestamp
</literal> is also a valid timestamp at
3734 the same time. It is set to
<literal>1899-
12-
31 23:
59:
59</literal>. In order
3735 to detect errors, make sure that your application does not only test
3736 for
<literal>PGTYPESInvalidTimestamp
</literal> but also for
3737 <literal>errno !=
0</literal> after each call to
3738 <function>PGTYPEStimestamp_from_asc
</function>.
3747 <sect1 id=
"ecpg-descriptors">
3748 <title>Using Descriptor Areas
</title>
3751 An SQL descriptor area is a more sophisticated method for processing
3752 the result of a
<command>SELECT
</command>,
<command>FETCH
</command> or
3753 a
<command>DESCRIBE
</command> statement. An SQL descriptor area groups
3754 the data of one row of data together with metadata items into one
3755 data structure. The metadata is particularly useful when executing
3756 dynamic SQL statements, where the nature of the result columns might
3757 not be known ahead of time. PostgreSQL provides two ways to use
3758 Descriptor Areas: the named SQL Descriptor Areas and the C-structure
3762 <sect2 id=
"ecpg-named-descriptors">
3763 <title>Named SQL Descriptor Areas
</title>
3766 A named SQL descriptor area consists of a header, which contains
3767 information concerning the entire descriptor, and one or more item
3768 descriptor areas, which basically each describe one column in the
3773 Before you can use an SQL descriptor area, you need to allocate one:
3775 EXEC SQL ALLOCATE DESCRIPTOR
<replaceable>identifier
</replaceable>;
3777 The identifier serves as the
<quote>variable name
</quote> of the
3778 descriptor area.
<!-- The scope of the allocated descriptor is WHAT?. -->
3779 When you don't need the descriptor anymore, you should deallocate
3782 EXEC SQL DEALLOCATE DESCRIPTOR
<replaceable>identifier
</replaceable>;
3787 To use a descriptor area, specify it as the storage target in an
3788 <literal>INTO
</literal> clause, instead of listing host variables:
3790 EXEC SQL FETCH NEXT FROM mycursor INTO SQL DESCRIPTOR mydesc;
3792 If the result set is empty, the Descriptor Area will still contain
3793 the metadata from the query, i.e., the field names.
3797 For not yet executed prepared queries, the
<command>DESCRIBE
</command>
3798 statement can be used to get the metadata of the result set:
3800 EXEC SQL BEGIN DECLARE SECTION;
3801 char *sql_stmt =
"SELECT * FROM table1";
3802 EXEC SQL END DECLARE SECTION;
3804 EXEC SQL PREPARE stmt1 FROM :sql_stmt;
3805 EXEC SQL DESCRIBE stmt1 INTO SQL DESCRIPTOR mydesc;
3810 Before PostgreSQL
9.0, the
<literal>SQL
</literal> keyword was optional,
3811 so using
<literal>DESCRIPTOR
</literal> and
<literal>SQL DESCRIPTOR
</literal>
3812 produced named SQL Descriptor Areas. Now it is mandatory, omitting
3813 the
<literal>SQL
</literal> keyword produces SQLDA Descriptor Areas,
3814 see
<xref linkend=
"ecpg-sqlda-descriptors"/>.
3818 In
<command>DESCRIBE
</command> and
<command>FETCH
</command> statements,
3819 the
<literal>INTO
</literal> and
<literal>USING
</literal> keywords can be
3820 used to similarly: they produce the result set and the metadata in a
3825 Now how do you get the data out of the descriptor area? You can
3826 think of the descriptor area as a structure with named fields. To
3827 retrieve the value of a field from the header and store it into a
3828 host variable, use the following command:
3830 EXEC SQL GET DESCRIPTOR
<replaceable>name
</replaceable> :
<replaceable>hostvar
</replaceable> =
<replaceable>field
</replaceable>;
3832 Currently, there is only one header field defined:
3833 <replaceable>COUNT
</replaceable>, which tells how many item
3834 descriptor areas exist (that is, how many columns are contained in
3835 the result). The host variable needs to be of an integer type. To
3836 get a field from the item descriptor area, use the following
3839 EXEC SQL GET DESCRIPTOR
<replaceable>name
</replaceable> VALUE
<replaceable>num
</replaceable> :
<replaceable>hostvar
</replaceable> =
<replaceable>field
</replaceable>;
3841 <replaceable>num
</replaceable> can be a literal integer or a host
3842 variable containing an integer. Possible fields are:
3845 <varlistentry id=
"ecpg-named-descriptors-cardinality">
3846 <term><literal>CARDINALITY
</literal> (integer)
</term>
3849 number of rows in the result set
3854 <varlistentry id=
"ecpg-named-descriptors-data">
3855 <term><literal>DATA
</literal></term>
3858 actual data item (therefore, the data type of this field
3859 depends on the query)
3864 <varlistentry id=
"ecpg-named-descriptors-datetime-interval-code">
3865 <term><literal>DATETIME_INTERVAL_CODE
</literal> (integer)
</term>
3868 When
<literal>TYPE
</literal> is
<literal>9</literal>,
3869 <literal>DATETIME_INTERVAL_CODE
</literal> will have a value of
3870 <literal>1</literal> for
<literal>DATE
</literal>,
3871 <literal>2</literal> for
<literal>TIME
</literal>,
3872 <literal>3</literal> for
<literal>TIMESTAMP
</literal>,
3873 <literal>4</literal> for
<literal>TIME WITH TIME ZONE
</literal>, or
3874 <literal>5</literal> for
<literal>TIMESTAMP WITH TIME ZONE
</literal>.
3879 <varlistentry id=
"ecpg-named-descriptors-datetime-interval-precision">
3880 <term><literal>DATETIME_INTERVAL_PRECISION
</literal> (integer)
</term>
3888 <varlistentry id=
"ecpg-named-descriptors-indicator">
3889 <term><literal>INDICATOR
</literal> (integer)
</term>
3892 the indicator (indicating a null value or a value truncation)
3897 <varlistentry id=
"ecpg-named-descriptors-key-member">
3898 <term><literal>KEY_MEMBER
</literal> (integer)
</term>
3906 <varlistentry id=
"ecpg-named-descriptors-length">
3907 <term><literal>LENGTH
</literal> (integer)
</term>
3910 length of the datum in characters
3915 <varlistentry id=
"ecpg-named-descriptors-name">
3916 <term><literal>NAME
</literal> (string)
</term>
3924 <varlistentry id=
"ecpg-named-descriptors-nullable">
3925 <term><literal>NULLABLE
</literal> (integer)
</term>
3933 <varlistentry id=
"ecpg-named-descriptors-octet-length">
3934 <term><literal>OCTET_LENGTH
</literal> (integer)
</term>
3937 length of the character representation of the datum in bytes
3942 <varlistentry id=
"ecpg-named-descriptors-precision">
3943 <term><literal>PRECISION
</literal> (integer)
</term>
3946 precision (for type
<type>numeric
</type>)
3951 <varlistentry id=
"ecpg-named-descriptors-returned-length">
3952 <term><literal>RETURNED_LENGTH
</literal> (integer)
</term>
3955 length of the datum in characters
3960 <varlistentry id=
"ecpg-named-descriptors-returned-octet-length">
3961 <term><literal>RETURNED_OCTET_LENGTH
</literal> (integer)
</term>
3964 length of the character representation of the datum in bytes
3969 <varlistentry id=
"ecpg-named-descriptors-scale">
3970 <term><literal>SCALE
</literal> (integer)
</term>
3973 scale (for type
<type>numeric
</type>)
3978 <varlistentry id=
"ecpg-named-descriptors-type">
3979 <term><literal>TYPE
</literal> (integer)
</term>
3982 numeric code of the data type of the column
3990 In
<command>EXECUTE
</command>,
<command>DECLARE
</command> and
<command>OPEN
</command>
3991 statements, the effect of the
<literal>INTO
</literal> and
<literal>USING
</literal>
3992 keywords are different. A Descriptor Area can also be manually built to
3993 provide the input parameters for a query or a cursor and
3994 <literal>USING SQL DESCRIPTOR
<replaceable>name
</replaceable></literal>
3995 is the way to pass the input parameters into a parameterized query. The statement
3996 to build a named SQL Descriptor Area is below:
3998 EXEC SQL SET DESCRIPTOR
<replaceable>name
</replaceable> VALUE
<replaceable>num
</replaceable> <replaceable>field
</replaceable> = :
<replaceable>hostvar
</replaceable>;
4003 PostgreSQL supports retrieving more that one record in one
<command>FETCH
</command>
4004 statement and storing the data in host variables in this case assumes that the
4005 variable is an array. E.g.:
4007 EXEC SQL BEGIN DECLARE SECTION;
4009 EXEC SQL END DECLARE SECTION;
4011 EXEC SQL FETCH
5 FROM mycursor INTO SQL DESCRIPTOR mydesc;
4013 EXEC SQL GET DESCRIPTOR mydesc VALUE
1 :id = DATA;
4020 <sect2 id=
"ecpg-sqlda-descriptors">
4021 <title>SQLDA Descriptor Areas
</title>
4024 An SQLDA Descriptor Area is a C language structure which can be also used
4025 to get the result set and the metadata of a query. One structure stores one
4026 record from the result set.
4028 EXEC SQL include sqlda.h;
4031 EXEC SQL FETCH
3 FROM mycursor INTO DESCRIPTOR mysqlda;
4033 Note that the
<literal>SQL
</literal> keyword is omitted. The paragraphs about
4034 the use cases of the
<literal>INTO
</literal> and
<literal>USING
</literal>
4035 keywords in
<xref linkend=
"ecpg-named-descriptors"/> also apply here with an addition.
4036 In a
<command>DESCRIBE
</command> statement the
<literal>DESCRIPTOR
</literal>
4037 keyword can be completely omitted if the
<literal>INTO
</literal> keyword is used:
4039 EXEC SQL DESCRIBE prepared_statement INTO mysqlda;
4045 The general flow of a program that uses SQLDA is:
4047 <step><simpara>Prepare a query, and declare a cursor for it.
</simpara></step>
4048 <step><simpara>Declare an SQLDA for the result rows.
</simpara></step>
4049 <step><simpara>Declare an SQLDA for the input parameters, and initialize them (memory allocation, parameter settings).
</simpara></step>
4050 <step><simpara>Open a cursor with the input SQLDA.
</simpara></step>
4051 <step><simpara>Fetch rows from the cursor, and store them into an output SQLDA.
</simpara></step>
4052 <step><simpara>Read values from the output SQLDA into the host variables (with conversion if necessary).
</simpara></step>
4053 <step><simpara>Close the cursor.
</simpara></step>
4054 <step><simpara>Free the memory area allocated for the input SQLDA.
</simpara></step>
4057 <sect3 id=
"ecpg-sqlda-descriptors-sqlda">
4058 <title>SQLDA Data Structure
</title>
4061 SQLDA uses three data structure
4062 types:
<type>sqlda_t
</type>,
<type>sqlvar_t
</type>,
4063 and
<type>struct sqlname
</type>.
4068 PostgreSQL's SQLDA has a similar data structure to the one in
4069 IBM DB2 Universal Database, so some technical information on
4070 DB2's SQLDA could help understanding PostgreSQL's one better.
4074 <sect4 id=
"ecpg-sqlda-sqlda">
4075 <title>sqlda_t Structure
</title>
4078 The structure type
<type>sqlda_t
</type> is the type of the
4079 actual SQLDA. It holds one record. And two or
4080 more
<type>sqlda_t
</type> structures can be connected in a
4081 linked list with the pointer in
4082 the
<structfield>desc_next
</structfield> field, thus
4083 representing an ordered collection of rows. So, when two or
4084 more rows are fetched, the application can read them by
4085 following the
<structfield>desc_next
</structfield> pointer in
4086 each
<type>sqlda_t
</type> node.
4090 The definition of
<type>sqlda_t
</type> is:
4098 struct sqlda_struct *desc_next;
4099 struct sqlvar_struct sqlvar[
1];
4102 typedef struct sqlda_struct sqlda_t;
4105 The meaning of the fields is:
4108 <varlistentry id=
"ecpg-sqlda-sqlda-sqldaid">
4109 <term><literal>sqldaid
</literal></term>
4112 It contains the literal string
<literal>"SQLDA "</literal>.
4117 <varlistentry id=
"ecpg-sqlda-sqlda-sqldabc">
4118 <term><literal>sqldabc
</literal></term>
4121 It contains the size of the allocated space in bytes.
4126 <varlistentry id=
"ecpg-sqlda-sqlda-sqln">
4127 <term><literal>sqln
</literal></term>
4130 It contains the number of input parameters for a parameterized query in
4131 case it's passed into
<command>OPEN
</command>,
<command>DECLARE
</command> or
4132 <command>EXECUTE
</command> statements using the
<literal>USING
</literal>
4133 keyword. In case it's used as output of
<command>SELECT
</command>,
4134 <command>EXECUTE
</command> or
<command>FETCH
</command> statements,
4135 its value is the same as
<literal>sqld
</literal>
4141 <varlistentry id=
"ecpg-sqlda-sqlda-sqld">
4142 <term><literal>sqld
</literal></term>
4145 It contains the number of fields in a result set.
4150 <varlistentry id=
"ecpg-sqlda-sqlda-desc-next">
4151 <term><literal>desc_next
</literal></term>
4154 If the query returns more than one record, multiple linked
4155 SQLDA structures are returned, and
<literal>desc_next
</literal> holds
4156 a pointer to the next entry in the list.
4160 <varlistentry id=
"ecpg-sqlda-sqlda-sqlvar">
4161 <term><literal>sqlvar
</literal></term>
4164 This is the array of the columns in the result set.
4172 <sect4 id=
"ecpg-sqlda-sqlvar">
4173 <title>sqlvar_t Structure
</title>
4176 The structure type
<type>sqlvar_t
</type> holds a column value
4177 and metadata such as type and length. The definition of the type
4181 struct sqlvar_struct
4187 struct sqlname sqlname;
4190 typedef struct sqlvar_struct sqlvar_t;
4193 The meaning of the fields is:
4196 <varlistentry id=
"ecpg-sqlda-sqlvar-sqltype">
4197 <term><literal>sqltype
</literal></term>
4200 Contains the type identifier of the field. For values,
4201 see
<literal>enum ECPGttype
</literal> in
<literal>ecpgtype.h
</literal>.
4206 <varlistentry id=
"ecpg-sqlda-sqlvar-sqllen">
4207 <term><literal>sqllen
</literal></term>
4210 Contains the binary length of the field. e.g.,
4 bytes for
<type>ECPGt_int
</type>.
4215 <varlistentry id=
"ecpg-sqlda-sqlvar-sqldata">
4216 <term><literal>sqldata
</literal></term>
4219 Points to the data. The format of the data is described
4220 in
<xref linkend=
"ecpg-variables-type-mapping"/>.
4225 <varlistentry id=
"ecpg-sqlda-sqlvar-sqlind">
4226 <term><literal>sqlind
</literal></term>
4229 Points to the null indicator.
0 means not null, -
1 means
4235 <varlistentry id=
"ecpg-sqlda-sqlvar-sqlname">
4236 <term><literal>sqlname
</literal></term>
4239 The name of the field.
4247 <sect4 id=
"ecpg-sqlda-sqlname">
4248 <title>struct sqlname Structure
</title>
4251 A
<type>struct sqlname
</type> structure holds a column name. It
4252 is used as a member of the
<type>sqlvar_t
</type> structure. The
4253 definition of the structure is:
4255 #define NAMEDATALEN
64
4260 char data[NAMEDATALEN];
4263 The meaning of the fields is:
4265 <varlistentry id=
"ecpg-sqlda-sqlname-length">
4266 <term><literal>length
</literal></term>
4269 Contains the length of the field name.
4273 <varlistentry id=
"ecpg-sqlda-sqlname-data">
4274 <term><literal>data
</literal></term>
4277 Contains the actual field name.
4286 <sect3 id=
"ecpg-sqlda-output">
4287 <title>Retrieving a Result Set Using an SQLDA
</title>
4291 The general steps to retrieve a query result set through an
4294 <step><simpara>Declare an
<type>sqlda_t
</type> structure to receive the result set.
</simpara></step>
4295 <step><simpara>Execute
<command>FETCH
</command>/
<command>EXECUTE
</command>/
<command>DESCRIBE
</command> commands to process a query specifying the declared SQLDA.
</simpara></step>
4296 <step><simpara>Check the number of records in the result set by looking at
<structfield>sqln
</structfield>, a member of the
<type>sqlda_t
</type> structure.
</simpara></step>
4297 <step><simpara>Get the values of each column from
<literal>sqlvar[
0]
</literal>,
<literal>sqlvar[
1]
</literal>, etc., members of the
<type>sqlda_t
</type> structure.
</simpara></step>
4298 <step><simpara>Go to next row (
<type>sqlda_t
</type> structure) by following the
<structfield>desc_next
</structfield> pointer, a member of the
<type>sqlda_t
</type> structure.
</simpara></step>
4299 <step><simpara>Repeat above as you need.
</simpara></step>
4303 Here is an example retrieving a result set through an SQLDA.
4307 First, declare a
<type>sqlda_t
</type> structure to receive the result set.
4314 Next, specify the SQLDA in a command. This is
4315 a
<command>FETCH
</command> command example.
4317 EXEC SQL FETCH NEXT FROM cur1 INTO DESCRIPTOR sqlda1;
4322 Run a loop following the linked list to retrieve the rows.
4326 for (cur_sqlda = sqlda1;
4328 cur_sqlda = cur_sqlda-
>desc_next)
4336 Inside the loop, run another loop to retrieve each column data
4337 (
<type>sqlvar_t
</type> structure) of the row.
4339 for (i =
0; i
< cur_sqlda-
>sqld; i++)
4341 sqlvar_t v = cur_sqlda-
>sqlvar[i];
4342 char *sqldata = v.sqldata;
4343 short sqllen = v.sqllen;
4350 To get a column value, check the
<structfield>sqltype
</structfield> value,
4351 a member of the
<type>sqlvar_t
</type> structure. Then, switch
4352 to an appropriate way, depending on the column type, to copy
4353 data from the
<structfield>sqlvar
</structfield> field to a host variable.
4360 memset(
&var_buf,
0, sizeof(var_buf));
4361 memcpy(
&var_buf, sqldata, (sizeof(var_buf)
<= sqllen ? sizeof(var_buf) -
1 : sqllen));
4364 case ECPGt_int: /* integer */
4365 memcpy(
&intval, sqldata, sqllen);
4366 snprintf(var_buf, sizeof(var_buf),
"%d", intval);
4375 <sect3 id=
"ecpg-sqlda-input">
4376 <title>Passing Query Parameters Using an SQLDA
</title>
4380 The general steps to use an SQLDA to pass input
4381 parameters to a prepared query are:
4383 <step><simpara>Create a prepared query (prepared statement)
</simpara></step>
4384 <step><simpara>Declare an sqlda_t structure as an input SQLDA.
</simpara></step>
4385 <step><simpara>Allocate memory area (as sqlda_t structure) for the input SQLDA.
</simpara></step>
4386 <step><simpara>Set (copy) input values in the allocated memory.
</simpara></step>
4387 <step><simpara>Open a cursor with specifying the input SQLDA.
</simpara></step>
4395 First, create a prepared statement.
4397 EXEC SQL BEGIN DECLARE SECTION;
4398 char query[
1024] =
"SELECT d.oid, * FROM pg_database d, pg_stat_database s WHERE d.oid = s.datid AND (d.datname = ? OR d.oid = ?)";
4399 EXEC SQL END DECLARE SECTION;
4401 EXEC SQL PREPARE stmt1 FROM :query;
4406 Next, allocate memory for an SQLDA, and set the number of input
4407 parameters in
<structfield>sqln
</structfield>, a member variable of
4408 the
<type>sqlda_t
</type> structure. When two or more input
4409 parameters are required for the prepared query, the application
4410 has to allocate additional memory space which is calculated by
4411 (nr. of params -
1) * sizeof(sqlvar_t). The example shown here
4412 allocates memory space for two input parameters.
4416 sqlda2 = (sqlda_t *) malloc(sizeof(sqlda_t) + sizeof(sqlvar_t));
4417 memset(sqlda2,
0, sizeof(sqlda_t) + sizeof(sqlvar_t));
4419 sqlda2-
>sqln =
2; /* number of input variables */
4424 After memory allocation, store the parameter values into the
4425 <literal>sqlvar[]
</literal> array. (This is same array used for
4426 retrieving column values when the SQLDA is receiving a result
4427 set.) In this example, the input parameters
4428 are
<literal>"postgres"</literal>, having a string type,
4429 and
<literal>1</literal>, having an integer type.
4431 sqlda2-
>sqlvar[
0].sqltype = ECPGt_char;
4432 sqlda2-
>sqlvar[
0].sqldata =
"postgres";
4433 sqlda2-
>sqlvar[
0].sqllen =
8;
4436 sqlda2-
>sqlvar[
1].sqltype = ECPGt_int;
4437 sqlda2-
>sqlvar[
1].sqldata = (char *)
&intval;
4438 sqlda2-
>sqlvar[
1].sqllen = sizeof(intval);
4443 By opening a cursor and specifying the SQLDA that was set up
4444 beforehand, the input parameters are passed to the prepared
4447 EXEC SQL OPEN cur1 USING DESCRIPTOR sqlda2;
4452 Finally, after using input SQLDAs, the allocated memory space
4453 must be freed explicitly, unlike SQLDAs used for receiving query
4461 <sect3 id=
"ecpg-sqlda-example">
4462 <title>A Sample Application Using SQLDA
</title>
4465 Here is an example program, which describes how to fetch access
4466 statistics of the databases, specified by the input parameters,
4467 from the system catalogs.
4471 This application joins two system tables, pg_database and
4472 pg_stat_database on the database OID, and also fetches and shows
4473 the database statistics which are retrieved by two input
4474 parameters (a database
<literal>postgres
</literal>, and OID
<literal>1</literal>).
4478 First, declare an SQLDA for input and an SQLDA for output.
4480 EXEC SQL include sqlda.h;
4482 sqlda_t *sqlda1; /* an output descriptor */
4483 sqlda_t *sqlda2; /* an input descriptor */
4488 Next, connect to the database, prepare a statement, and declare a
4489 cursor for the prepared statement.
4494 EXEC SQL BEGIN DECLARE SECTION;
4495 char query[
1024] =
"SELECT d.oid,* FROM pg_database d, pg_stat_database s WHERE d.oid=s.datid AND ( d.datname=? OR d.oid=? )";
4496 EXEC SQL END DECLARE SECTION;
4498 EXEC SQL CONNECT TO testdb AS con1 USER testuser;
4499 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
4501 EXEC SQL PREPARE stmt1 FROM :query;
4502 EXEC SQL DECLARE cur1 CURSOR FOR stmt1;
4507 Next, put some values in the input SQLDA for the input
4508 parameters. Allocate memory for the input SQLDA, and set the
4509 number of input parameters to
<literal>sqln
</literal>. Store
4510 type, value, and value length into
<literal>sqltype
</literal>,
4511 <literal>sqldata
</literal>, and
<literal>sqllen
</literal> in the
4512 <literal>sqlvar
</literal> structure.
4515 /* Create SQLDA structure for input parameters. */
4516 sqlda2 = (sqlda_t *) malloc(sizeof(sqlda_t) + sizeof(sqlvar_t));
4517 memset(sqlda2,
0, sizeof(sqlda_t) + sizeof(sqlvar_t));
4518 sqlda2-
>sqln =
2; /* number of input variables */
4520 sqlda2-
>sqlvar[
0].sqltype = ECPGt_char;
4521 sqlda2-
>sqlvar[
0].sqldata =
"postgres";
4522 sqlda2-
>sqlvar[
0].sqllen =
8;
4525 sqlda2-
>sqlvar[
1].sqltype = ECPGt_int;
4526 sqlda2-
>sqlvar[
1].sqldata = (char *)
&intval;
4527 sqlda2-
>sqlvar[
1].sqllen = sizeof(intval);
4532 After setting up the input SQLDA, open a cursor with the input
4536 /* Open a cursor with input parameters. */
4537 EXEC SQL OPEN cur1 USING DESCRIPTOR sqlda2;
4542 Fetch rows into the output SQLDA from the opened cursor.
4543 (Generally, you have to call
<command>FETCH
</command> repeatedly
4544 in the loop, to fetch all rows in the result set.)
4550 /* Assign descriptor to the cursor */
4551 EXEC SQL FETCH NEXT FROM cur1 INTO DESCRIPTOR sqlda1;
4556 Next, retrieve the fetched records from the SQLDA, by following
4557 the linked list of the
<type>sqlda_t
</type> structure.
4559 for (cur_sqlda = sqlda1 ;
4561 cur_sqlda = cur_sqlda-
>desc_next)
4568 Read each columns in the first record. The number of columns is
4569 stored in
<structfield>sqld
</structfield>, the actual data of the first
4570 column is stored in
<literal>sqlvar[
0]
</literal>, both members of
4571 the
<type>sqlda_t
</type> structure.
4574 /* Print every column in a row. */
4575 for (i =
0; i
< sqlda1-
>sqld; i++)
4577 sqlvar_t v = sqlda1-
>sqlvar[i];
4578 char *sqldata = v.sqldata;
4579 short sqllen = v.sqllen;
4581 strncpy(name_buf, v.sqlname.data, v.sqlname.length);
4582 name_buf[v.sqlname.length] = '\
0';
4587 Now, the column data is stored in the variable
<varname>v
</varname>.
4588 Copy every datum into host variables, looking
4589 at
<literal>v.sqltype
</literal> for the type of the column.
4591 switch (v.sqltype) {
4594 unsigned long long int longlongval;
4597 memset(
&var_buf,
0, sizeof(var_buf));
4598 memcpy(
&var_buf, sqldata, (sizeof(var_buf)
<= sqllen ? sizeof(var_buf)-
1 : sqllen));
4601 case ECPGt_int: /* integer */
4602 memcpy(
&intval, sqldata, sqllen);
4603 snprintf(var_buf, sizeof(var_buf),
"%d", intval);
4612 printf(
"%s = %s (type: %d)\n", name_buf, var_buf, v.sqltype);
4618 Close the cursor after processing all of records, and disconnect
4621 EXEC SQL CLOSE cur1;
4624 EXEC SQL DISCONNECT ALL;
4629 The whole program is shown
4630 in
<xref linkend=
"ecpg-sqlda-example-example"/>.
4633 <example id=
"ecpg-sqlda-example-example">
4634 <title>Example SQLDA Program
</title>
4636 #include
<stdlib.h
>
4637 #include
<string.h
>
4638 #include
<stdlib.h
>
4639 #include
<stdio.h
>
4640 #include
<unistd.h
>
4642 EXEC SQL include sqlda.h;
4644 sqlda_t *sqlda1; /* descriptor for output */
4645 sqlda_t *sqlda2; /* descriptor for input */
4647 EXEC SQL WHENEVER NOT FOUND DO BREAK;
4648 EXEC SQL WHENEVER SQLERROR STOP;
4653 EXEC SQL BEGIN DECLARE SECTION;
4654 char query[
1024] =
"SELECT d.oid,* FROM pg_database d, pg_stat_database s WHERE d.oid=s.datid AND ( d.datname=? OR d.oid=? )";
4657 unsigned long long int longlongval;
4658 EXEC SQL END DECLARE SECTION;
4660 EXEC SQL CONNECT TO uptimedb AS con1 USER uptime;
4661 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
4663 EXEC SQL PREPARE stmt1 FROM :query;
4664 EXEC SQL DECLARE cur1 CURSOR FOR stmt1;
4666 /* Create an SQLDA structure for an input parameter */
4667 sqlda2 = (sqlda_t *)malloc(sizeof(sqlda_t) + sizeof(sqlvar_t));
4668 memset(sqlda2,
0, sizeof(sqlda_t) + sizeof(sqlvar_t));
4669 sqlda2-
>sqln =
2; /* a number of input variables */
4671 sqlda2-
>sqlvar[
0].sqltype = ECPGt_char;
4672 sqlda2-
>sqlvar[
0].sqldata =
"postgres";
4673 sqlda2-
>sqlvar[
0].sqllen =
8;
4676 sqlda2-
>sqlvar[
1].sqltype = ECPGt_int;
4677 sqlda2-
>sqlvar[
1].sqldata = (char *)
&intval;
4678 sqlda2-
>sqlvar[
1].sqllen = sizeof(intval);
4680 /* Open a cursor with input parameters. */
4681 EXEC SQL OPEN cur1 USING DESCRIPTOR sqlda2;
4687 /* Assign descriptor to the cursor */
4688 EXEC SQL FETCH NEXT FROM cur1 INTO DESCRIPTOR sqlda1;
4690 for (cur_sqlda = sqlda1 ;
4692 cur_sqlda = cur_sqlda-
>desc_next)
4695 char name_buf[
1024];
4698 /* Print every column in a row. */
4699 for (i=
0 ; i
<cur_sqlda-
>sqld ; i++)
4701 sqlvar_t v = cur_sqlda-
>sqlvar[i];
4702 char *sqldata = v.sqldata;
4703 short sqllen = v.sqllen;
4705 strncpy(name_buf, v.sqlname.data, v.sqlname.length);
4706 name_buf[v.sqlname.length] = '\
0';
4711 memset(
&var_buf,
0, sizeof(var_buf));
4712 memcpy(
&var_buf, sqldata, (sizeof(var_buf)
<=sqllen ? sizeof(var_buf)-
1 : sqllen) );
4715 case ECPGt_int: /* integer */
4716 memcpy(
&intval, sqldata, sqllen);
4717 snprintf(var_buf, sizeof(var_buf),
"%d", intval);
4720 case ECPGt_long_long: /* bigint */
4721 memcpy(
&longlongval, sqldata, sqllen);
4722 snprintf(var_buf, sizeof(var_buf),
"%lld", longlongval);
4728 memset(var_buf,
0, sizeof(var_buf));
4729 for (i =
0; i
< sqllen; i++)
4732 snprintf(tmpbuf, sizeof(tmpbuf),
"%02x ", (unsigned char) sqldata[i]);
4733 strncat(var_buf, tmpbuf, sizeof(var_buf));
4739 printf(
"%s = %s (type: %d)\n", name_buf, var_buf, v.sqltype);
4746 EXEC SQL CLOSE cur1;
4749 EXEC SQL DISCONNECT ALL;
4756 The output of this example should look something like the
4757 following (some numbers will vary).
4762 datname = template1 (type:
1)
4763 datdba =
10 (type:
1)
4764 encoding =
0 (type:
5)
4765 datistemplate = t (type:
1)
4766 datallowconn = t (type:
1)
4767 dathasloginevt = f (type:
1)
4768 datconnlimit = -
1 (type:
5)
4769 datfrozenxid =
379 (type:
1)
4770 dattablespace =
1663 (type:
1)
4771 datconfig = (type:
1)
4772 datacl = {=c/uptime,uptime=CTc/uptime} (type:
1)
4774 datname = template1 (type:
1)
4775 numbackends =
0 (type:
5)
4776 xact_commit =
113606 (type:
9)
4777 xact_rollback =
0 (type:
9)
4778 blks_read =
130 (type:
9)
4779 blks_hit =
7341714 (type:
9)
4780 tup_returned =
38262679 (type:
9)
4781 tup_fetched =
1836281 (type:
9)
4782 tup_inserted =
0 (type:
9)
4783 tup_updated =
0 (type:
9)
4784 tup_deleted =
0 (type:
9)
4786 oid =
11511 (type:
1)
4787 datname = postgres (type:
1)
4788 datdba =
10 (type:
1)
4789 encoding =
0 (type:
5)
4790 datistemplate = f (type:
1)
4791 datallowconn = t (type:
1)
4792 dathasloginevt = f (type:
1)
4793 datconnlimit = -
1 (type:
5)
4794 datfrozenxid =
379 (type:
1)
4795 dattablespace =
1663 (type:
1)
4796 datconfig = (type:
1)
4798 datid =
11511 (type:
1)
4799 datname = postgres (type:
1)
4800 numbackends =
0 (type:
5)
4801 xact_commit =
221069 (type:
9)
4802 xact_rollback =
18 (type:
9)
4803 blks_read =
1176 (type:
9)
4804 blks_hit =
13943750 (type:
9)
4805 tup_returned =
77410091 (type:
9)
4806 tup_fetched =
3253694 (type:
9)
4807 tup_inserted =
0 (type:
9)
4808 tup_updated =
0 (type:
9)
4809 tup_deleted =
0 (type:
9)
4816 <sect1 id=
"ecpg-errors">
4817 <title>Error Handling
</title>
4820 This section describes how you can handle exceptional conditions
4821 and warnings in an embedded SQL program. There are two
4822 nonexclusive facilities for this.
4827 Callbacks can be configured to handle warning and error
4828 conditions using the
<literal>WHENEVER
</literal> command.
4834 Detailed information about the error or warning can be obtained
4835 from the
<varname>sqlca
</varname> variable.
4841 <sect2 id=
"ecpg-whenever">
4842 <title>Setting Callbacks
</title>
4845 One simple method to catch errors and warnings is to set a
4846 specific action to be executed whenever a particular condition
4849 EXEC SQL WHENEVER
<replaceable>condition
</replaceable> <replaceable>action
</replaceable>;
4854 <replaceable>condition
</replaceable> can be one of the following:
4857 <varlistentry id=
"ecpg-whenever-sqlerror">
4858 <term><literal>SQLERROR
</literal></term>
4861 The specified action is called whenever an error occurs during
4862 the execution of an SQL statement.
4867 <varlistentry id=
"ecpg-whenever-sqlwarning">
4868 <term><literal>SQLWARNING
</literal></term>
4871 The specified action is called whenever a warning occurs
4872 during the execution of an SQL statement.
4877 <varlistentry id=
"ecpg-whenever-not-found">
4878 <term><literal>NOT FOUND
</literal></term>
4881 The specified action is called whenever an SQL statement
4882 retrieves or affects zero rows. (This condition is not an
4883 error, but you might be interested in handling it specially.)
4891 <replaceable>action
</replaceable> can be one of the following:
4894 <varlistentry id=
"ecpg-whenever-continue">
4895 <term><literal>CONTINUE
</literal></term>
4898 This effectively means that the condition is ignored. This is
4904 <varlistentry id=
"ecpg-whenever-goto">
4905 <term><literal>GOTO
<replaceable>label
</replaceable></literal></term>
4906 <term><literal>GO TO
<replaceable>label
</replaceable></literal></term>
4909 Jump to the specified label (using a C
<literal>goto
</literal>
4915 <varlistentry id=
"ecpg-whenever-sqlprint">
4916 <term><literal>SQLPRINT
</literal></term>
4919 Print a message to standard error. This is useful for simple
4920 programs or during prototyping. The details of the message
4921 cannot be configured.
4926 <varlistentry id=
"ecpg-whenever-stop">
4927 <term><literal>STOP
</literal></term>
4930 Call
<literal>exit(
1)
</literal>, which will terminate the
4936 <varlistentry id=
"ecpg-whenever-do-break">
4937 <term><literal>DO BREAK
</literal></term>
4940 Execute the C statement
<literal>break
</literal>. This should
4941 only be used in loops or
<literal>switch
</literal> statements.
4946 <varlistentry id=
"ecpg-whenever-do-continue">
4947 <term><literal>DO CONTINUE
</literal></term>
4950 Execute the C statement
<literal>continue
</literal>. This should
4951 only be used in loops statements. if executed, will cause the flow
4952 of control to return to the top of the loop.
4957 <varlistentry id=
"ecpg-whenever-call">
4958 <term><literal>CALL
<replaceable>name
</replaceable> (
<replaceable>args
</replaceable>)
</literal></term>
4959 <term><literal>DO
<replaceable>name
</replaceable> (
<replaceable>args
</replaceable>)
</literal></term>
4962 Call the specified C functions with the specified arguments. (This
4963 use is different from the meaning of
<literal>CALL
</literal>
4964 and
<literal>DO
</literal> in the normal PostgreSQL grammar.)
4970 The SQL standard only provides for the actions
4971 <literal>CONTINUE
</literal> and
<literal>GOTO
</literal> (and
4972 <literal>GO TO
</literal>).
4976 Here is an example that you might want to use in a simple program.
4977 It prints a simple message when a warning occurs and aborts the
4978 program when an error happens:
4980 EXEC SQL WHENEVER SQLWARNING SQLPRINT;
4981 EXEC SQL WHENEVER SQLERROR STOP;
4986 The statement
<literal>EXEC SQL WHENEVER
</literal> is a directive
4987 of the SQL preprocessor, not a C statement. The error or warning
4988 actions that it sets apply to all embedded SQL statements that
4989 appear below the point where the handler is set, unless a
4990 different action was set for the same condition between the first
4991 <literal>EXEC SQL WHENEVER
</literal> and the SQL statement causing
4992 the condition, regardless of the flow of control in the C program.
4993 So neither of the two following C program excerpts will have the
4999 int main(int argc, char *argv[])
5003 EXEC SQL WHENEVER SQLWARNING SQLPRINT;
5006 EXEC SQL SELECT ...;
5015 int main(int argc, char *argv[])
5018 set_error_handler();
5020 EXEC SQL SELECT ...;
5024 static void set_error_handler(void)
5026 EXEC SQL WHENEVER SQLERROR STOP;
5032 <sect2 id=
"ecpg-sqlca">
5033 <title>sqlca
</title>
5036 For more powerful error handling, the embedded SQL interface
5037 provides a global variable with the name
<varname>sqlca
</varname>
5038 (SQL communication area)
5039 that has the following structure:
5049 char sqlerrmc[SQLERRMC_LEN];
5057 (In a multithreaded program, every thread automatically gets its
5058 own copy of
<varname>sqlca
</varname>. This works similarly to the
5059 handling of the standard C global variable
5060 <varname>errno
</varname>.)
5064 <varname>sqlca
</varname> covers both warnings and errors. If
5065 multiple warnings or errors occur during the execution of a
5066 statement, then
<varname>sqlca
</varname> will only contain
5067 information about the last one.
5071 If no error occurred in the last
<acronym>SQL
</acronym> statement,
5072 <literal>sqlca.sqlcode
</literal> will be
0 and
5073 <literal>sqlca.sqlstate
</literal> will be
5074 <literal>"00000"</literal>. If a warning or error occurred, then
5075 <literal>sqlca.sqlcode
</literal> will be negative and
5076 <literal>sqlca.sqlstate
</literal> will be different from
5077 <literal>"00000"</literal>. A positive
5078 <literal>sqlca.sqlcode
</literal> indicates a harmless condition,
5079 such as that the last query returned zero rows.
5080 <literal>sqlcode
</literal> and
<literal>sqlstate
</literal> are two
5081 different error code schemes; details appear below.
5085 If the last SQL statement was successful, then
5086 <literal>sqlca.sqlerrd[
1]
</literal> contains the OID of the
5087 processed row, if applicable, and
5088 <literal>sqlca.sqlerrd[
2]
</literal> contains the number of
5089 processed or returned rows, if applicable to the command.
5093 In case of an error or warning,
5094 <literal>sqlca.sqlerrm.sqlerrmc
</literal> will contain a string
5095 that describes the error. The field
5096 <literal>sqlca.sqlerrm.sqlerrml
</literal> contains the length of
5097 the error message that is stored in
5098 <literal>sqlca.sqlerrm.sqlerrmc
</literal> (the result of
5099 <function>strlen()
</function>, not really interesting for a C
5100 programmer). Note that some messages are too long to fit in the
5101 fixed-size
<literal>sqlerrmc
</literal> array; they will be truncated.
5105 In case of a warning,
<literal>sqlca.sqlwarn[
2]
</literal> is set
5106 to
<literal>W
</literal>. (In all other cases, it is set to
5107 something different from
<literal>W
</literal>.) If
5108 <literal>sqlca.sqlwarn[
1]
</literal> is set to
5109 <literal>W
</literal>, then a value was truncated when it was
5110 stored in a host variable.
<literal>sqlca.sqlwarn[
0]
</literal> is
5111 set to
<literal>W
</literal> if any of the other elements are set
5112 to indicate a warning.
5116 The fields
<structfield>sqlcaid
</structfield>,
5117 <structfield>sqlabc
</structfield>,
5118 <structfield>sqlerrp
</structfield>, and the remaining elements of
5119 <structfield>sqlerrd
</structfield> and
5120 <structfield>sqlwarn
</structfield> currently contain no useful
5125 The structure
<varname>sqlca
</varname> is not defined in the SQL
5126 standard, but is implemented in several other SQL database
5127 systems. The definitions are similar at the core, but if you want
5128 to write portable applications, then you should investigate the
5129 different implementations carefully.
5133 Here is one example that combines the use of
<literal>WHENEVER
</literal>
5134 and
<varname>sqlca
</varname>, printing out the contents
5135 of
<varname>sqlca
</varname> when an error occurs. This is perhaps
5136 useful for debugging or prototyping applications, before
5137 installing a more
<quote>user-friendly
</quote> error handler.
5140 EXEC SQL WHENEVER SQLERROR CALL print_sqlca();
5145 fprintf(stderr,
"==== sqlca ====\n");
5146 fprintf(stderr,
"sqlcode: %ld\n", sqlca.sqlcode);
5147 fprintf(stderr,
"sqlerrm.sqlerrml: %d\n", sqlca.sqlerrm.sqlerrml);
5148 fprintf(stderr,
"sqlerrm.sqlerrmc: %s\n", sqlca.sqlerrm.sqlerrmc);
5149 fprintf(stderr,
"sqlerrd: %ld %ld %ld %ld %ld %ld\n", sqlca.sqlerrd[
0],sqlca.sqlerrd[
1],sqlca.sqlerrd[
2],
5150 sqlca.sqlerrd[
3],sqlca.sqlerrd[
4],sqlca.sqlerrd[
5]);
5151 fprintf(stderr,
"sqlwarn: %d %d %d %d %d %d %d %d\n", sqlca.sqlwarn[
0], sqlca.sqlwarn[
1], sqlca.sqlwarn[
2],
5152 sqlca.sqlwarn[
3], sqlca.sqlwarn[
4], sqlca.sqlwarn[
5],
5153 sqlca.sqlwarn[
6], sqlca.sqlwarn[
7]);
5154 fprintf(stderr,
"sqlstate: %5s\n", sqlca.sqlstate);
5155 fprintf(stderr,
"===============\n");
5159 The result could look as follows (here an error due to a
5160 misspelled table name):
5165 sqlerrm.sqlerrml:
49
5166 sqlerrm.sqlerrmc: relation
"pg_databasep" does not exist on line
38
5167 sqlerrd:
0 0 0 0 0 0
5168 sqlwarn:
0 0 0 0 0 0 0 0
5175 <sect2 id=
"ecpg-sqlstate-sqlcode">
5176 <title><literal>SQLSTATE
</literal> vs.
<literal>SQLCODE
</literal></title>
5179 The fields
<literal>sqlca.sqlstate
</literal> and
5180 <literal>sqlca.sqlcode
</literal> are two different schemes that
5181 provide error codes. Both are derived from the SQL standard, but
5182 <literal>SQLCODE
</literal> has been marked deprecated in the SQL-
92
5183 edition of the standard and has been dropped in later editions.
5184 Therefore, new applications are strongly encouraged to use
5185 <literal>SQLSTATE
</literal>.
5189 <literal>SQLSTATE
</literal> is a five-character array. The five
5190 characters contain digits or upper-case letters that represent
5191 codes of various error and warning conditions.
5192 <literal>SQLSTATE
</literal> has a hierarchical scheme: the first
5193 two characters indicate the general class of the condition, the
5194 last three characters indicate a subclass of the general
5195 condition. A successful state is indicated by the code
5196 <literal>00000</literal>. The
<literal>SQLSTATE
</literal> codes are for
5197 the most part defined in the SQL standard. The
5198 <productname>PostgreSQL
</productname> server natively supports
5199 <literal>SQLSTATE
</literal> error codes; therefore a high degree
5200 of consistency can be achieved by using this error code scheme
5201 throughout all applications. For further information see
5202 <xref linkend=
"errcodes-appendix"/>.
5206 <literal>SQLCODE
</literal>, the deprecated error code scheme, is a
5207 simple integer. A value of
0 indicates success, a positive value
5208 indicates success with additional information, a negative value
5209 indicates an error. The SQL standard only defines the positive
5210 value +
100, which indicates that the last command returned or
5211 affected zero rows, and no specific negative values. Therefore,
5212 this scheme can only achieve poor portability and does not have a
5213 hierarchical code assignment. Historically, the embedded SQL
5214 processor for
<productname>PostgreSQL
</productname> has assigned
5215 some specific
<literal>SQLCODE
</literal> values for its use, which
5216 are listed below with their numeric value and their symbolic name.
5217 Remember that these are not portable to other SQL implementations.
5218 To simplify the porting of applications to the
5219 <literal>SQLSTATE
</literal> scheme, the corresponding
5220 <literal>SQLSTATE
</literal> is also listed. There is, however, no
5221 one-to-one or one-to-many mapping between the two schemes (indeed
5222 it is many-to-many), so you should consult the global
5223 <literal>SQLSTATE
</literal> listing in
<xref linkend=
"errcodes-appendix"/>
5228 These are the assigned
<literal>SQLCODE
</literal> values:
5231 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-no-error">
5232 <term>0 (
<symbol>ECPG_NO_ERROR
</symbol>)
</term>
5235 Indicates no error. (SQLSTATE
00000)
5240 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-not-found">
5241 <term>100 (
<symbol>ECPG_NOT_FOUND
</symbol>)
</term>
5244 This is a harmless condition indicating that the last command
5245 retrieved or processed zero rows, or that you are at the end of
5246 the cursor. (SQLSTATE
02000)
5250 When processing a cursor in a loop, you could use this code as
5251 a way to detect when to abort the loop, like this:
5255 EXEC SQL FETCH ... ;
5256 if (sqlca.sqlcode == ECPG_NOT_FOUND)
5260 But
<literal>WHENEVER NOT FOUND DO BREAK
</literal> effectively
5261 does this internally, so there is usually no advantage in
5262 writing this out explicitly.
5267 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-out-of-memory">
5268 <term>-
12 (
<symbol>ECPG_OUT_OF_MEMORY
</symbol>)
</term>
5271 Indicates that your virtual memory is exhausted. The numeric
5272 value is defined as
<literal>-ENOMEM
</literal>. (SQLSTATE
5278 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-unsupported">
5279 <term>-
200 (
<symbol>ECPG_UNSUPPORTED
</symbol>)
</term>
5282 Indicates the preprocessor has generated something that the
5283 library does not know about. Perhaps you are running
5284 incompatible versions of the preprocessor and the
5285 library. (SQLSTATE YE002)
5290 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-too-many-arguments">
5291 <term>-
201 (
<symbol>ECPG_TOO_MANY_ARGUMENTS
</symbol>)
</term>
5294 This means that the command specified more host variables than
5295 the command expected. (SQLSTATE
07001 or
07002)
5300 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-too-few-arguments">
5301 <term>-
202 (
<symbol>ECPG_TOO_FEW_ARGUMENTS
</symbol>)
</term>
5304 This means that the command specified fewer host variables than
5305 the command expected. (SQLSTATE
07001 or
07002)
5310 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-too-many-matches">
5311 <term>-
203 (
<symbol>ECPG_TOO_MANY_MATCHES
</symbol>)
</term>
5314 This means a query has returned multiple rows but the statement
5315 was only prepared to store one result row (for example, because
5316 the specified variables are not arrays). (SQLSTATE
21000)
5321 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-int-format">
5322 <term>-
204 (
<symbol>ECPG_INT_FORMAT
</symbol>)
</term>
5325 The host variable is of type
<type>int
</type> and the datum in
5326 the database is of a different type and contains a value that
5327 cannot be interpreted as an
<type>int
</type>. The library uses
5328 <function>strtol()
</function> for this conversion. (SQLSTATE
5334 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-uint-format">
5335 <term>-
205 (
<symbol>ECPG_UINT_FORMAT
</symbol>)
</term>
5338 The host variable is of type
<type>unsigned int
</type> and the
5339 datum in the database is of a different type and contains a
5340 value that cannot be interpreted as an
<type>unsigned
5341 int
</type>. The library uses
<function>strtoul()
</function>
5342 for this conversion. (SQLSTATE
42804)
5347 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-float-format">
5348 <term>-
206 (
<symbol>ECPG_FLOAT_FORMAT
</symbol>)
</term>
5351 The host variable is of type
<type>float
</type> and the datum
5352 in the database is of another type and contains a value that
5353 cannot be interpreted as a
<type>float
</type>. The library
5354 uses
<function>strtod()
</function> for this conversion.
5360 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-numeric-format">
5361 <term>-
207 (
<symbol>ECPG_NUMERIC_FORMAT
</symbol>)
</term>
5364 The host variable is of type
<type>numeric
</type> and the datum
5365 in the database is of another type and contains a value that
5366 cannot be interpreted as a
<type>numeric
</type> value.
5372 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-interval-format">
5373 <term>-
208 (
<symbol>ECPG_INTERVAL_FORMAT
</symbol>)
</term>
5376 The host variable is of type
<type>interval
</type> and the datum
5377 in the database is of another type and contains a value that
5378 cannot be interpreted as an
<type>interval
</type> value.
5384 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-date-format">
5385 <term>-
209 (
<symbol>ECPG_DATE_FORMAT
</symbol>)
</term>
5388 The host variable is of type
<type>date
</type> and the datum in
5389 the database is of another type and contains a value that
5390 cannot be interpreted as a
<type>date
</type> value.
5396 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-timestamp-format">
5397 <term>-
210 (
<symbol>ECPG_TIMESTAMP_FORMAT
</symbol>)
</term>
5400 The host variable is of type
<type>timestamp
</type> and the
5401 datum in the database is of another type and contains a value
5402 that cannot be interpreted as a
<type>timestamp
</type> value.
5408 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-convert-bool">
5409 <term>-
211 (
<symbol>ECPG_CONVERT_BOOL
</symbol>)
</term>
5412 This means the host variable is of type
<type>bool
</type> and
5413 the datum in the database is neither
<literal>'t'
</literal> nor
5414 <literal>'f'
</literal>. (SQLSTATE
42804)
5419 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-empty">
5420 <term>-
212 (
<symbol>ECPG_EMPTY
</symbol>)
</term>
5423 The statement sent to the
<productname>PostgreSQL
</productname>
5424 server was empty. (This cannot normally happen in an embedded
5425 SQL program, so it might point to an internal error.) (SQLSTATE
5431 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-missing-indicator">
5432 <term>-
213 (
<symbol>ECPG_MISSING_INDICATOR
</symbol>)
</term>
5435 A null value was returned and no null indicator variable was
5436 supplied. (SQLSTATE
22002)
5441 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-no-array">
5442 <term>-
214 (
<symbol>ECPG_NO_ARRAY
</symbol>)
</term>
5445 An ordinary variable was used in a place that requires an
5446 array. (SQLSTATE
42804)
5451 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-data-not-array">
5452 <term>-
215 (
<symbol>ECPG_DATA_NOT_ARRAY
</symbol>)
</term>
5455 The database returned an ordinary variable in a place that
5456 requires array value. (SQLSTATE
42804)
5461 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-array-insert">
5462 <term>-
216 (
<symbol>ECPG_ARRAY_INSERT
</symbol>)
</term>
5465 The value could not be inserted into the array. (SQLSTATE
5471 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-no-conn">
5472 <term>-
220 (
<symbol>ECPG_NO_CONN
</symbol>)
</term>
5475 The program tried to access a connection that does not exist.
5481 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-not-conn">
5482 <term>-
221 (
<symbol>ECPG_NOT_CONN
</symbol>)
</term>
5485 The program tried to access a connection that does exist but is
5486 not open. (This is an internal error.) (SQLSTATE YE002)
5491 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-invalid-stmt">
5492 <term>-
230 (
<symbol>ECPG_INVALID_STMT
</symbol>)
</term>
5495 The statement you are trying to use has not been prepared.
5501 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-informix-duplicate-key">
5502 <term>-
239 (
<symbol>ECPG_INFORMIX_DUPLICATE_KEY
</symbol>)
</term>
5505 Duplicate key error, violation of unique constraint (Informix
5506 compatibility mode). (SQLSTATE
23505)
5511 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-unknown-descriptor">
5512 <term>-
240 (
<symbol>ECPG_UNKNOWN_DESCRIPTOR
</symbol>)
</term>
5515 The descriptor specified was not found. The statement you are
5516 trying to use has not been prepared. (SQLSTATE
33000)
5521 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-invalid-descriptor-index">
5522 <term>-
241 (
<symbol>ECPG_INVALID_DESCRIPTOR_INDEX
</symbol>)
</term>
5525 The descriptor index specified was out of range. (SQLSTATE
5531 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-unknown-descriptor-item">
5532 <term>-
242 (
<symbol>ECPG_UNKNOWN_DESCRIPTOR_ITEM
</symbol>)
</term>
5535 An invalid descriptor item was requested. (This is an internal
5536 error.) (SQLSTATE YE002)
5541 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-var-not-numeric">
5542 <term>-
243 (
<symbol>ECPG_VAR_NOT_NUMERIC
</symbol>)
</term>
5545 During the execution of a dynamic statement, the database
5546 returned a numeric value and the host variable was not numeric.
5552 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-var-not-char">
5553 <term>-
244 (
<symbol>ECPG_VAR_NOT_CHAR
</symbol>)
</term>
5556 During the execution of a dynamic statement, the database
5557 returned a non-numeric value and the host variable was numeric.
5563 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-informix-subselect-not-one">
5564 <term>-
284 (
<symbol>ECPG_INFORMIX_SUBSELECT_NOT_ONE
</symbol>)
</term>
5567 A result of the subquery is not single row (Informix
5568 compatibility mode). (SQLSTATE
21000)
5573 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-pgsql">
5574 <term>-
400 (
<symbol>ECPG_PGSQL
</symbol>)
</term>
5577 Some error caused by the
<productname>PostgreSQL
</productname>
5578 server. The message contains the error message from the
5579 <productname>PostgreSQL
</productname> server.
5584 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-trans">
5585 <term>-
401 (
<symbol>ECPG_TRANS
</symbol>)
</term>
5588 The
<productname>PostgreSQL
</productname> server signaled that
5589 we cannot start, commit, or rollback the transaction.
5595 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-connect">
5596 <term>-
402 (
<symbol>ECPG_CONNECT
</symbol>)
</term>
5599 The connection attempt to the database did not succeed.
5605 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-duplicate-key">
5606 <term>-
403 (
<symbol>ECPG_DUPLICATE_KEY
</symbol>)
</term>
5609 Duplicate key error, violation of unique constraint. (SQLSTATE
5615 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-subselect-not-one">
5616 <term>-
404 (
<symbol>ECPG_SUBSELECT_NOT_ONE
</symbol>)
</term>
5619 A result for the subquery is not single row. (SQLSTATE
21000)
5624 <!-- currently not used by the code -->
5626 <varlistentry id="ecpg-sqlstate-sqlcode-ecpg-warning-unrecognized">
5627 <term>-600 (<symbol>ECPG_WARNING_UNRECOGNIZED</symbol>)</term>
5630 An unrecognized warning was received from the server.
5635 <varlistentry id="ecpg-sqlstate-sqlcode-ecpg-warning-query-ignored">
5636 <term>-601 (<symbol>ECPG_WARNING_QUERY_IGNORED</symbol>)</term>
5639 Current transaction is aborted. Queries are ignored until the
5640 end of the transaction block.
5646 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-warning-unknown-portal">
5647 <term>-
602 (
<symbol>ECPG_WARNING_UNKNOWN_PORTAL
</symbol>)
</term>
5650 An invalid cursor name was specified. (SQLSTATE
34000)
5655 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-warning-in-transaction">
5656 <term>-
603 (
<symbol>ECPG_WARNING_IN_TRANSACTION
</symbol>)
</term>
5659 Transaction is in progress. (SQLSTATE
25001)
5664 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-warning-no-transaction">
5665 <term>-
604 (
<symbol>ECPG_WARNING_NO_TRANSACTION
</symbol>)
</term>
5668 There is no active (in-progress) transaction. (SQLSTATE
25P01)
5673 <varlistentry id=
"ecpg-sqlstate-sqlcode-ecpg-warning-portal-exists">
5674 <term>-
605 (
<symbol>ECPG_WARNING_PORTAL_EXISTS
</symbol>)
</term>
5677 An existing cursor name was specified. (SQLSTATE
42P03)
5687 <sect1 id=
"ecpg-preproc">
5688 <title>Preprocessor Directives
</title>
5691 Several preprocessor directives are available that modify how
5692 the
<command>ecpg
</command> preprocessor parses and processes a
5696 <sect2 id=
"ecpg-include">
5697 <title>Including Files
</title>
5700 To include an external file into your embedded SQL program, use:
5702 EXEC SQL INCLUDE
<replaceable>filename
</replaceable>;
5703 EXEC SQL INCLUDE
<<replaceable>filename
</replaceable>>;
5704 EXEC SQL INCLUDE
"<replaceable>filename</replaceable>";
5706 The embedded SQL preprocessor will look for a file named
5707 <literal><replaceable>filename
</replaceable>.h
</literal>,
5708 preprocess it, and include it in the resulting C output. Thus,
5709 embedded SQL statements in the included file are handled correctly.
5713 The
<command>ecpg
</command> preprocessor will search a file at
5714 several directories in following order:
5717 <listitem><simpara>current directory
</simpara></listitem>
5718 <listitem><simpara><filename>/usr/local/include
</filename></simpara></listitem>
5719 <listitem><simpara>PostgreSQL include directory, defined at build time (e.g.,
<filename>/usr/local/pgsql/include
</filename>)
</simpara></listitem>
5720 <listitem><simpara><filename>/usr/include
</filename></simpara></listitem>
5723 But when
<literal>EXEC SQL INCLUDE
5724 "<replaceable>filename</replaceable>"</literal> is used, only the
5725 current directory is searched.
5729 In each directory, the preprocessor will first look for the file
5730 name as given, and if not found will append
<literal>.h
</literal>
5731 to the file name and try again (unless the specified file name
5732 already has that suffix).
5736 Note that
<command>EXEC SQL INCLUDE
</command> is
<emphasis>not
</emphasis> the same as:
5738 #include
<<replaceable>filename
</replaceable>.h
>
5740 because this file would not be subject to SQL command preprocessing.
5741 Naturally, you can continue to use the C
5742 <literal>#include
</literal> directive to include other header
5748 The include file name is case-sensitive, even though the rest of
5749 the
<literal>EXEC SQL INCLUDE
</literal> command follows the normal
5750 SQL case-sensitivity rules.
5755 <sect2 id=
"ecpg-define">
5756 <title>The define and undef Directives
</title>
5758 Similar to the directive
<literal>#define
</literal> that is known from C,
5759 embedded SQL has a similar concept:
5761 EXEC SQL DEFINE
<replaceable>name
</replaceable>;
5762 EXEC SQL DEFINE
<replaceable>name
</replaceable> <replaceable>value
</replaceable>;
5764 So you can define a name:
5766 EXEC SQL DEFINE HAVE_FEATURE;
5768 And you can also define constants:
5770 EXEC SQL DEFINE MYNUMBER
12;
5771 EXEC SQL DEFINE MYSTRING 'abc';
5773 Use
<literal>undef
</literal> to remove a previous definition:
5775 EXEC SQL UNDEF MYNUMBER;
5780 Of course you can continue to use the C versions
<literal>#define
</literal>
5781 and
<literal>#undef
</literal> in your embedded SQL program. The difference
5782 is where your defined values get evaluated. If you use
<literal>EXEC SQL
5783 DEFINE
</literal> then the
<command>ecpg
</command> preprocessor evaluates the defines and substitutes
5784 the values. For example if you write:
5786 EXEC SQL DEFINE MYNUMBER
12;
5788 EXEC SQL UPDATE Tbl SET col = MYNUMBER;
5790 then
<command>ecpg
</command> will already do the substitution and your C compiler will never
5791 see any name or identifier
<literal>MYNUMBER
</literal>. Note that you cannot use
5792 <literal>#define
</literal> for a constant that you are going to use in an
5793 embedded SQL query because in this case the embedded SQL precompiler is not
5794 able to see this declaration.
5798 If multiple input files are named on the
<command>ecpg
</command>
5799 preprocessor's command line, the effects of
<literal>EXEC SQL
5800 DEFINE
</literal> and
<literal>EXEC SQL UNDEF
</literal> do not carry
5801 across files: each file starts with only the symbols defined
5802 by
<option>-D
</option> switches on the command line.
5806 <sect2 id=
"ecpg-ifdef">
5807 <title>ifdef, ifndef, elif, else, and endif Directives
</title>
5809 You can use the following directives to compile code sections conditionally:
5812 <varlistentry id=
"ecpg-ifdef-ifdef">
5813 <term><literal>EXEC SQL ifdef
<replaceable>name
</replaceable>;
</literal></term>
5816 Checks a
<replaceable>name
</replaceable> and processes subsequent lines if
5817 <replaceable>name
</replaceable> has been defined via
<literal>EXEC SQL define
5818 <replaceable>name
</replaceable></literal>.
5823 <varlistentry id=
"ecpg-ifdef-ifndef">
5824 <term><literal>EXEC SQL ifndef
<replaceable>name
</replaceable>;
</literal></term>
5827 Checks a
<replaceable>name
</replaceable> and processes subsequent lines if
5828 <replaceable>name
</replaceable> has
<emphasis>not
</emphasis> been defined via
5829 <literal>EXEC SQL define
<replaceable>name
</replaceable></literal>.
5834 <varlistentry id=
"ecpg-ifdef-elif">
5835 <term><literal>EXEC SQL elif
<replaceable>name
</replaceable>;
</literal></term>
5838 Begins an optional alternative section after an
5839 <literal>EXEC SQL ifdef
<replaceable>name
</replaceable></literal> or
5840 <literal>EXEC SQL ifndef
<replaceable>name
</replaceable></literal>
5841 directive. Any number of
<literal>elif
</literal> sections can appear.
5842 Lines following an
<literal>elif
</literal> will be processed
5843 if
<replaceable>name
</replaceable> has been
5844 defined
<emphasis>and
</emphasis> no previous section of the same
5845 <literal>ifdef
</literal>/
<literal>ifndef
</literal>...
<literal>endif
</literal>
5846 construct has been processed.
5851 <varlistentry id=
"ecpg-ifdef-else">
5852 <term><literal>EXEC SQL else;
</literal></term>
5855 Begins an optional, final alternative section after an
5856 <literal>EXEC SQL ifdef
<replaceable>name
</replaceable></literal> or
5857 <literal>EXEC SQL ifndef
<replaceable>name
</replaceable></literal>
5858 directive. Subsequent lines will be processed if no previous section
5860 <literal>ifdef
</literal>/
<literal>ifndef
</literal>...
<literal>endif
</literal>
5861 construct has been processed.
5866 <varlistentry id=
"ecpg-ifdef-endif">
5867 <term><literal>EXEC SQL endif;
</literal></term>
5871 <literal>ifdef
</literal>/
<literal>ifndef
</literal>...
<literal>endif
</literal>
5872 construct. Subsequent lines are processed normally.
5880 <literal>ifdef
</literal>/
<literal>ifndef
</literal>...
<literal>endif
</literal>
5881 constructs can be nested, up to
127 levels deep.
5885 This example will compile exactly one of the three
<literal>SET
5886 TIMEZONE
</literal> commands:
5888 EXEC SQL ifdef TZVAR;
5889 EXEC SQL SET TIMEZONE TO TZVAR;
5890 EXEC SQL elif TZNAME;
5891 EXEC SQL SET TIMEZONE TO TZNAME;
5893 EXEC SQL SET TIMEZONE TO 'GMT';
5901 <sect1 id=
"ecpg-process">
5902 <title>Processing Embedded SQL Programs
</title>
5905 Now that you have an idea how to form embedded SQL C programs, you
5906 probably want to know how to compile them. Before compiling you
5907 run the file through the embedded
<acronym>SQL
</acronym>
5908 <acronym>C
</acronym> preprocessor, which converts the
5909 <acronym>SQL
</acronym> statements you used to special function
5910 calls. After compiling, you must link with a special library that
5911 contains the needed functions. These functions fetch information
5912 from the arguments, perform the
<acronym>SQL
</acronym> command using
5913 the
<application>libpq
</application> interface, and put the result
5914 in the arguments specified for output.
5918 The preprocessor program is called
<filename>ecpg
</filename> and is
5919 included in a normal
<productname>PostgreSQL
</productname> installation.
5920 Embedded SQL programs are typically named with an extension
5921 <filename>.pgc
</filename>. If you have a program file called
5922 <filename>prog1.pgc
</filename>, you can preprocess it by simply
5927 This will create a file called
<filename>prog1.c
</filename>. If
5928 your input files do not follow the suggested naming pattern, you
5929 can specify the output file explicitly using the
5930 <option>-o
</option> option.
5934 The preprocessed file can be compiled normally, for example:
5938 The generated C source files include header files from the
5939 <productname>PostgreSQL
</productname> installation, so if you installed
5940 <productname>PostgreSQL
</productname> in a location that is not searched by
5941 default, you have to add an option such as
5942 <literal>-I/usr/local/pgsql/include
</literal> to the compilation
5947 To link an embedded SQL program, you need to include the
5948 <filename>libecpg
</filename> library, like so:
5950 cc -o myprog prog1.o prog2.o ... -lecpg
5952 Again, you might have to add an option like
5953 <literal>-L/usr/local/pgsql/lib
</literal> to that command line.
5958 use
<command>pg_config
</command><indexterm><primary>pg_config
</primary><secondary sortas=
"ecpg">with
5959 ecpg
</secondary></indexterm>
5960 or
<command>pkg-config
</command><indexterm><primary>pkg-config
</primary><secondary sortas=
"ecpg">with
5961 ecpg
</secondary></indexterm> with package name
<literal>libecpg
</literal> to
5962 get the paths for your installation.
5966 If you manage the build process of a larger project using
5967 <application>make
</application>, it might be convenient to include
5968 the following implicit rule to your makefiles:
5978 The complete syntax of the
<command>ecpg
</command> command is
5979 detailed in
<xref linkend=
"app-ecpg"/>.
5983 The
<application>ecpg
</application> library is thread-safe by
5984 default. However, you might need to use some threading
5985 command-line options to compile your client code.
5989 <sect1 id=
"ecpg-library">
5990 <title>Library Functions
</title>
5993 The
<filename>libecpg
</filename> library primarily contains
5994 <quote>hidden
</quote> functions that are used to implement the
5995 functionality expressed by the embedded SQL commands. But there
5996 are some functions that can usefully be called directly. Note that
5997 this makes your code unportable.
6003 <function>ECPGdebug(int
<replaceable>on
</replaceable>, FILE
6004 *
<replaceable>stream
</replaceable>)
</function> turns on debug
6005 logging if called with the first argument non-zero. Debug logging
6006 is done on
<replaceable>stream
</replaceable>. The log contains
6007 all
<acronym>SQL
</acronym> statements with all the input
6008 variables inserted, and the results from the
6009 <productname>PostgreSQL
</productname> server. This can be very
6010 useful when searching for errors in your
<acronym>SQL
</acronym>
6015 On Windows, if the
<application>ecpg
</application> libraries and an application are
6016 compiled with different flags, this function call will crash the
6017 application because the internal representation of the
6018 <literal>FILE
</literal> pointers differ. Specifically,
6019 multithreaded/single-threaded, release/debug, and static/dynamic
6020 flags should be the same for the library and all applications using
6028 <function>ECPGget_PGconn(const char *
<replaceable>connection_name
</replaceable>)
6029 </function> returns the library database connection handle identified by the given name.
6030 If
<replaceable>connection_name
</replaceable> is set to
<literal>NULL
</literal>, the current
6031 connection handle is returned. If no connection handle can be identified, the function returns
6032 <literal>NULL
</literal>. The returned connection handle can be used to call any other functions
6033 from
<application>libpq
</application>, if necessary.
6037 It is a bad idea to manipulate database connection handles made from
<application>ecpg
</application> directly
6038 with
<application>libpq
</application> routines.
6045 <function>ECPGtransactionStatus(const char *
<replaceable>connection_name
</replaceable>)
</function>
6046 returns the current transaction status of the given connection identified by
<replaceable>connection_name
</replaceable>.
6047 See
<xref linkend=
"libpq-status"/> and libpq's
<xref linkend=
"libpq-PQtransactionStatus"/> for details about the returned status codes.
6053 <function>ECPGstatus(int
<replaceable>lineno
</replaceable>,
6054 const char*
<replaceable>connection_name
</replaceable>)
</function>
6055 returns true if you are connected to a database and false if not.
6056 <replaceable>connection_name
</replaceable> can be
<literal>NULL
</literal>
6057 if a single connection is being used.
6063 <sect1 id=
"ecpg-lo">
6064 <title>Large Objects
</title>
6067 Large objects are not directly supported by ECPG, but ECPG
6068 application can manipulate large objects through the libpq large
6069 object functions, obtaining the necessary
<type>PGconn
</type>
6070 object by calling the
<function>ECPGget_PGconn()
</function>
6071 function. (However, use of
6072 the
<function>ECPGget_PGconn()
</function> function and touching
6073 <type>PGconn
</type> objects directly should be done very carefully
6074 and ideally not mixed with other ECPG database access calls.)
6078 For more details about the
<function>ECPGget_PGconn()
</function>, see
6079 <xref linkend=
"ecpg-library"/>. For information about the large
6080 object function interface, see
<xref linkend=
"largeobjects"/>.
6084 Large object functions have to be called in a transaction block, so
6085 when autocommit is off,
<command>BEGIN
</command> commands have to
6086 be issued explicitly.
6090 <xref linkend=
"ecpg-lo-example"/> shows an example program that
6091 illustrates how to create, write, and read a large object in an
6095 <example id=
"ecpg-lo-example">
6096 <title>ECPG Program Accessing Large Objects
</title>
6097 <programlisting><![CDATA[
6100 #include
<libpq-fe.h
>
6101 #include
<libpq/libpq-fs.h
>
6103 EXEC SQL WHENEVER SQLERROR STOP;
6116 memset(buf,
1, buflen);
6118 EXEC SQL CONNECT TO testdb AS con1;
6119 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
6121 conn = ECPGget_PGconn(
"con1");
6122 printf(
"conn = %p\n", conn);
6125 loid = lo_create(conn,
0);
6127 printf(
"lo_create() failed: %s", PQerrorMessage(conn));
6129 printf(
"loid = %d\n", loid);
6132 fd = lo_open(conn, loid, INV_READ|INV_WRITE);
6134 printf(
"lo_open() failed: %s", PQerrorMessage(conn));
6136 printf(
"fd = %d\n", fd);
6138 rc = lo_write(conn, fd, buf, buflen);
6140 printf(
"lo_write() failed\n");
6142 rc = lo_close(conn, fd);
6144 printf(
"lo_close() failed: %s", PQerrorMessage(conn));
6147 fd = lo_open(conn, loid, INV_READ);
6149 printf(
"lo_open() failed: %s", PQerrorMessage(conn));
6151 printf(
"fd = %d\n", fd);
6153 rc = lo_read(conn, fd, buf2, buflen);
6155 printf(
"lo_read() failed\n");
6157 rc = lo_close(conn, fd);
6159 printf(
"lo_close() failed: %s", PQerrorMessage(conn));
6162 rc = memcmp(buf, buf2, buflen);
6163 printf(
"memcmp() = %d\n", rc);
6166 rc = lo_unlink(conn, loid);
6168 printf(
"lo_unlink() failed: %s", PQerrorMessage(conn));
6171 EXEC SQL DISCONNECT ALL;
6174 ]]
></programlisting>
6178 <sect1 id=
"ecpg-cpp">
6179 <title><acronym>C++
</acronym> Applications
</title>
6182 ECPG has some limited support for C++ applications. This section
6183 describes some caveats.
6187 The
<command>ecpg
</command> preprocessor takes an input file
6188 written in C (or something like C) and embedded SQL commands,
6189 converts the embedded SQL commands into C language chunks, and
6190 finally generates a
<filename>.c
</filename> file. The header file
6191 declarations of the library functions used by the C language chunks
6192 that
<command>ecpg
</command> generates are wrapped
6193 in
<literal>extern
"C" { ... }
</literal> blocks when used under
6194 C++, so they should work seamlessly in C++.
6198 In general, however, the
<command>ecpg
</command> preprocessor only
6199 understands C; it does not handle the special syntax and reserved
6200 words of the C++ language. So, some embedded SQL code written in
6201 C++ application code that uses complicated features specific to C++
6202 might fail to be preprocessed correctly or might not work as
6207 A safe way to use the embedded SQL code in a C++ application is
6208 hiding the ECPG calls in a C module, which the C++ application code
6209 calls into to access the database, and linking that together with
6210 the rest of the C++ code. See
<xref linkend=
"ecpg-cpp-and-c"/>
6214 <sect2 id=
"ecpg-cpp-scope">
6215 <title>Scope for Host Variables
</title>
6218 The
<command>ecpg
</command> preprocessor understands the scope of
6219 variables in C. In the C language, this is rather simple because
6220 the scopes of variables is based on their code blocks. In C++,
6221 however, the class member variables are referenced in a different
6222 code block from the declared position, so
6223 the
<command>ecpg
</command> preprocessor will not understand the
6224 scope of the class member variables.
6228 For example, in the following case, the
<command>ecpg
</command>
6229 preprocessor cannot find any declaration for the
6230 variable
<literal>dbname
</literal> in the
<literal>test
</literal>
6231 method, so an error will occur.
6236 EXEC SQL BEGIN DECLARE SECTION;
6238 EXEC SQL END DECLARE SECTION;
6248 EXEC SQL CONNECT TO testdb1;
6249 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
6254 EXEC SQL SELECT current_database() INTO :dbname;
6255 printf(
"current_database = %s\n", dbname);
6260 EXEC SQL DISCONNECT ALL;
6264 This code will result in an error like this:
6266 <userinput>ecpg test_cpp.pgc
</userinput>
6267 test_cpp.pgc:
28: ERROR: variable
"dbname" is not declared
6272 To avoid this scope issue, the
<literal>test
</literal> method
6273 could be modified to use a local variable as intermediate storage.
6274 But this approach is only a poor workaround, because it uglifies
6275 the code and reduces performance.
6278 void TestCpp::test()
6280 EXEC SQL BEGIN DECLARE SECTION;
6282 EXEC SQL END DECLARE SECTION;
6284 EXEC SQL SELECT current_database() INTO :tmp;
6285 strlcpy(dbname, tmp, sizeof(tmp));
6287 printf(
"current_database = %s\n", dbname);
6293 <sect2 id=
"ecpg-cpp-and-c">
6294 <title>C++ Application Development with External C Module
</title>
6297 If you understand these technical limitations of
6298 the
<command>ecpg
</command> preprocessor in C++, you might come to
6299 the conclusion that linking C objects and C++ objects at the link
6300 stage to enable C++ applications to use ECPG features could be
6301 better than writing some embedded SQL commands in C++ code
6302 directly. This section describes a way to separate some embedded
6303 SQL commands from C++ application code with a simple example. In
6304 this example, the application is implemented in C++, while C and
6305 ECPG is used to connect to the PostgreSQL server.
6309 Three kinds of files have to be created: a C file
6310 (
<filename>*.pgc
</filename>), a header file, and a C++ file:
6313 <varlistentry id=
"ecpg-cpp-and-c-test-mod-pgc">
6314 <term><filename>test_mod.pgc
</filename></term>
6317 A sub-routine module to execute SQL commands embedded in C.
6318 It is going to be converted
6319 into
<filename>test_mod.c
</filename> by the preprocessor.
6322 #include
"test_mod.h"
6323 #include
<stdio.h
>
6328 EXEC SQL CONNECT TO testdb1;
6329 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
6335 EXEC SQL BEGIN DECLARE SECTION;
6337 EXEC SQL END DECLARE SECTION;
6339 EXEC SQL SELECT current_database() INTO :dbname;
6340 printf(
"current_database = %s\n", dbname);
6346 EXEC SQL DISCONNECT ALL;
6353 <varlistentry id=
"ecpg-cpp-and-c-test-mod-h">
6354 <term><filename>test_mod.h
</filename></term>
6357 A header file with declarations of the functions in the C
6358 module (
<filename>test_mod.pgc
</filename>). It is included by
6359 <filename>test_cpp.cpp
</filename>. This file has to have an
6360 <literal>extern
"C"</literal> block around the declarations,
6361 because it will be linked from the C++ module.
6370 void db_disconnect();
6380 <varlistentry id=
"ecpg-cpp-and-c-test-cpp-cpp">
6381 <term><filename>test_cpp.cpp
</filename></term>
6384 The main code for the application, including
6385 the
<function>main
</function> routine, and in this example a
6389 #include
"test_mod.h"
6418 TestCpp *t = new TestCpp();
6431 To build the application, proceed as follows. Convert
6432 <filename>test_mod.pgc
</filename> into
<filename>test_mod.c
</filename> by
6433 running
<command>ecpg
</command>, and generate
6434 <filename>test_mod.o
</filename> by compiling
6435 <filename>test_mod.c
</filename> with the C compiler:
6437 ecpg -o test_mod.c test_mod.pgc
6438 cc -c test_mod.c -o test_mod.o
6443 Next, generate
<filename>test_cpp.o
</filename> by compiling
6444 <filename>test_cpp.cpp
</filename> with the C++ compiler:
6446 c++ -c test_cpp.cpp -o test_cpp.o
6451 Finally, link these object files,
<filename>test_cpp.o
</filename>
6452 and
<filename>test_mod.o
</filename>, into one executable, using the C++
6455 c++ test_cpp.o test_mod.o -lecpg -o test_cpp
6461 <sect1 id=
"ecpg-sql-commands">
6462 <title>Embedded SQL Commands
</title>
6465 This section describes all SQL commands that are specific to
6466 embedded SQL. Also refer to the SQL commands listed
6467 in
<xref linkend=
"sql-commands"/>, which can also be used in
6468 embedded SQL, unless stated otherwise.
6471 <refentry id=
"ecpg-sql-allocate-descriptor">
6473 <refname>ALLOCATE DESCRIPTOR
</refname>
6474 <refpurpose>allocate an SQL descriptor area
</refpurpose>
6479 ALLOCATE DESCRIPTOR
<replaceable class=
"parameter">name
</replaceable>
6484 <title>Description
</title>
6487 <command>ALLOCATE DESCRIPTOR
</command> allocates a new named SQL
6488 descriptor area, which can be used to exchange data between the
6489 PostgreSQL server and the host program.
6493 Descriptor areas should be freed after use using
6494 the
<command>DEALLOCATE DESCRIPTOR
</command> command.
6499 <title>Parameters
</title>
6502 <varlistentry id=
"ecpg-sql-allocate-descriptor-name">
6503 <term><replaceable class=
"parameter">name
</replaceable></term>
6506 A name of SQL descriptor, case sensitive. This can be an SQL
6507 identifier or a host variable.
6515 <title>Examples
</title>
6518 EXEC SQL ALLOCATE DESCRIPTOR mydesc;
6523 <title>Compatibility
</title>
6526 <command>ALLOCATE DESCRIPTOR
</command> is specified in the SQL
6532 <title>See Also
</title>
6534 <simplelist type=
"inline">
6535 <member><xref linkend=
"ecpg-sql-deallocate-descriptor"/></member>
6536 <member><xref linkend=
"ecpg-sql-get-descriptor"/></member>
6537 <member><xref linkend=
"ecpg-sql-set-descriptor"/></member>
6542 <refentry id=
"ecpg-sql-connect">
6544 <refname>CONNECT
</refname>
6545 <refpurpose>establish a database connection
</refpurpose>
6550 CONNECT TO
<replaceable>connection_target
</replaceable> [ AS
<replaceable>connection_name
</replaceable> ] [ USER
<replaceable>connection_user
</replaceable> ]
6552 CONNECT
<replaceable>connection_user
</replaceable>
6553 DATABASE
<replaceable>connection_target
</replaceable>
6558 <title>Description
</title>
6561 The
<command>CONNECT
</command> command establishes a connection
6562 between the client and the PostgreSQL server.
6567 <title>Parameters
</title>
6570 <varlistentry id=
"ecpg-sql-connect-connection-target">
6571 <term><replaceable class=
"parameter">connection_target
</replaceable></term>
6574 <replaceable class=
"parameter">connection_target
</replaceable>
6575 specifies the target server of the connection on one of
6579 <varlistentry id=
"ecpg-sql-connect-connection-target-database-name">
6580 <term>[
<replaceable>database_name
</replaceable> ] [
<literal>@
</literal><replaceable>host
</replaceable> ] [
<literal>:
</literal><replaceable>port
</replaceable> ]
</term>
6588 <varlistentry id=
"ecpg-sql-connect-connection-target-unix-domain-sockets">
6589 <term><literal>unix:postgresql://
</literal><replaceable>host
</replaceable> [
<literal>:
</literal><replaceable>port
</replaceable> ]
<literal>/
</literal> [
<replaceable>database_name
</replaceable> ] [
<literal>?
</literal><replaceable>connection_option
</replaceable> ]
</term>
6592 Connect over Unix-domain sockets
6597 <varlistentry id=
"ecpg-sql-connect-connection-target-tcp-ip">
6598 <term><literal>tcp:postgresql://
</literal><replaceable>host
</replaceable> [
<literal>:
</literal><replaceable>port
</replaceable> ]
<literal>/
</literal> [
<replaceable>database_name
</replaceable> ] [
<literal>?
</literal><replaceable>connection_option
</replaceable> ]
</term>
6606 <varlistentry id=
"ecpg-sql-connect-connection-target-constant">
6607 <term>SQL string constant
</term>
6610 containing a value in one of the above forms
6615 <varlistentry id=
"ecpg-sql-connect-connection-target-host-variable">
6616 <term>host variable
</term>
6619 host variable of type
<type>char[]
</type>
6620 or
<type>VARCHAR[]
</type> containing a value in one of the
6630 <varlistentry id=
"ecpg-sql-connect-connection-name">
6631 <term><replaceable class=
"parameter">connection_name
</replaceable></term>
6634 An optional identifier for the connection, so that it can be
6635 referred to in other commands. This can be an SQL identifier
6641 <varlistentry id=
"ecpg-sql-connect-connection-user">
6642 <term><replaceable class=
"parameter">connection_user
</replaceable></term>
6645 The user name for the database connection.
6649 This parameter can also specify user name and password, using one the forms
6650 <literal><replaceable>user_name
</replaceable>/
<replaceable>password
</replaceable></literal>,
6651 <literal><replaceable>user_name
</replaceable> IDENTIFIED BY
<replaceable>password
</replaceable></literal>, or
6652 <literal><replaceable>user_name
</replaceable> USING
<replaceable>password
</replaceable></literal>.
6656 User name and password can be SQL identifiers, string
6657 constants, or host variables.
6662 <varlistentry id=
"ecpg-sql-connect-default">
6663 <term><literal>DEFAULT
</literal></term>
6666 Use all default connection parameters, as defined by libpq.
6674 <title>Examples
</title>
6677 Here a several variants for specifying connection parameters:
6679 EXEC SQL CONNECT TO
"connectdb" AS main;
6680 EXEC SQL CONNECT TO
"connectdb" AS second;
6681 EXEC SQL CONNECT TO
"unix:postgresql://200.46.204.71/connectdb" AS main USER connectuser;
6682 EXEC SQL CONNECT TO
"unix:postgresql://localhost/connectdb" AS main USER connectuser;
6683 EXEC SQL CONNECT TO 'connectdb' AS main;
6684 EXEC SQL CONNECT TO 'unix:postgresql://localhost/connectdb' AS main USER :user;
6685 EXEC SQL CONNECT TO :db AS :id;
6686 EXEC SQL CONNECT TO :db USER connectuser USING :pw;
6687 EXEC SQL CONNECT TO @localhost AS main USER connectdb;
6688 EXEC SQL CONNECT TO REGRESSDB1 as main;
6689 EXEC SQL CONNECT TO AS main USER connectdb;
6690 EXEC SQL CONNECT TO connectdb AS :id;
6691 EXEC SQL CONNECT TO connectdb AS main USER connectuser/connectdb;
6692 EXEC SQL CONNECT TO connectdb AS main;
6693 EXEC SQL CONNECT TO connectdb@localhost AS main;
6694 EXEC SQL CONNECT TO tcp:postgresql://localhost/ USER connectdb;
6695 EXEC SQL CONNECT TO tcp:postgresql://localhost/connectdb USER connectuser IDENTIFIED BY connectpw;
6696 EXEC SQL CONNECT TO tcp:postgresql://localhost:
20/connectdb USER connectuser IDENTIFIED BY connectpw;
6697 EXEC SQL CONNECT TO unix:postgresql://localhost/ AS main USER connectdb;
6698 EXEC SQL CONNECT TO unix:postgresql://localhost/connectdb AS main USER connectuser;
6699 EXEC SQL CONNECT TO unix:postgresql://localhost/connectdb USER connectuser IDENTIFIED BY
"connectpw";
6700 EXEC SQL CONNECT TO unix:postgresql://localhost/connectdb USER connectuser USING
"connectpw";
6701 EXEC SQL CONNECT TO unix:postgresql://localhost/connectdb?connect_timeout=
14 USER connectuser;
6706 Here is an example program that illustrates the use of host
6707 variables to specify connection parameters:
6712 EXEC SQL BEGIN DECLARE SECTION;
6713 char *dbname =
"testdb"; /* database name */
6714 char *user =
"testuser"; /* connection user name */
6715 char *connection =
"tcp:postgresql://localhost:5432/testdb";
6716 /* connection string */
6717 char ver[
256]; /* buffer to store the version string */
6718 EXEC SQL END DECLARE SECTION;
6720 ECPGdebug(
1, stderr);
6722 EXEC SQL CONNECT TO :dbname USER :user;
6723 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
6724 EXEC SQL SELECT version() INTO :ver;
6725 EXEC SQL DISCONNECT;
6727 printf(
"version: %s\n", ver);
6729 EXEC SQL CONNECT TO :connection USER :user;
6730 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
6731 EXEC SQL SELECT version() INTO :ver;
6732 EXEC SQL DISCONNECT;
6734 printf(
"version: %s\n", ver);
6743 <title>Compatibility
</title>
6746 <command>CONNECT
</command> is specified in the SQL standard, but
6747 the format of the connection parameters is
6748 implementation-specific.
6753 <title>See Also
</title>
6755 <simplelist type=
"inline">
6756 <member><xref linkend=
"ecpg-sql-disconnect"/></member>
6757 <member><xref linkend=
"ecpg-sql-set-connection"/></member>
6762 <refentry id=
"ecpg-sql-deallocate-descriptor">
6764 <refname>DEALLOCATE DESCRIPTOR
</refname>
6765 <refpurpose>deallocate an SQL descriptor area
</refpurpose>
6770 DEALLOCATE DESCRIPTOR
<replaceable class=
"parameter">name
</replaceable>
6775 <title>Description
</title>
6778 <command>DEALLOCATE DESCRIPTOR
</command> deallocates a named SQL
6784 <title>Parameters
</title>
6787 <varlistentry id=
"ecpg-sql-deallocate-descriptor-name">
6788 <term><replaceable class=
"parameter">name
</replaceable></term>
6791 The name of the descriptor which is going to be deallocated.
6792 It is case sensitive. This can be an SQL identifier or a host
6801 <title>Examples
</title>
6804 EXEC SQL DEALLOCATE DESCRIPTOR mydesc;
6809 <title>Compatibility
</title>
6812 <command>DEALLOCATE DESCRIPTOR
</command> is specified in the SQL
6818 <title>See Also
</title>
6820 <simplelist type=
"inline">
6821 <member><xref linkend=
"ecpg-sql-allocate-descriptor"/></member>
6822 <member><xref linkend=
"ecpg-sql-get-descriptor"/></member>
6823 <member><xref linkend=
"ecpg-sql-set-descriptor"/></member>
6828 <refentry id=
"ecpg-sql-declare">
6830 <refname>DECLARE
</refname>
6831 <refpurpose>define a cursor
</refpurpose>
6836 DECLARE
<replaceable class=
"parameter">cursor_name
</replaceable> [ BINARY ] [ ASENSITIVE | INSENSITIVE ] [ [ NO ] SCROLL ] CURSOR [ { WITH | WITHOUT } HOLD ] FOR
<replaceable class=
"parameter">prepared_name
</replaceable>
6837 DECLARE
<replaceable class=
"parameter">cursor_name
</replaceable> [ BINARY ] [ ASENSITIVE | INSENSITIVE ] [ [ NO ] SCROLL ] CURSOR [ { WITH | WITHOUT } HOLD ] FOR
<replaceable class=
"parameter">query
</replaceable>
6842 <title>Description
</title>
6845 <command>DECLARE
</command> declares a cursor for iterating over
6846 the result set of a prepared statement. This command has
6847 slightly different semantics from the direct SQL
6848 command
<command>DECLARE
</command>: Whereas the latter executes a
6849 query and prepares the result set for retrieval, this embedded
6850 SQL command merely declares a name as a
<quote>loop
6851 variable
</quote> for iterating over the result set of a query;
6852 the actual execution happens when the cursor is opened with
6853 the
<command>OPEN
</command> command.
6858 <title>Parameters
</title>
6861 <varlistentry id=
"ecpg-sql-declare-cursor-name">
6862 <term><replaceable class=
"parameter">cursor_name
</replaceable></term>
6865 A cursor name, case sensitive. This can be an SQL identifier
6871 <varlistentry id=
"ecpg-sql-declare-prepared-name">
6872 <term><replaceable class=
"parameter">prepared_name
</replaceable></term>
6875 The name of a prepared query, either as an SQL identifier or a
6881 <varlistentry id=
"ecpg-sql-declare-query">
6882 <term><replaceable class=
"parameter">query
</replaceable></term>
6885 A
<xref linkend=
"sql-select"/> or
6886 <xref linkend=
"sql-values"/> command which will provide the
6887 rows to be returned by the cursor.
6894 For the meaning of the cursor options,
6895 see
<xref linkend=
"sql-declare"/>.
6900 <title>Examples
</title>
6903 Examples declaring a cursor for a query:
6905 EXEC SQL DECLARE C CURSOR FOR SELECT * FROM My_Table;
6906 EXEC SQL DECLARE C CURSOR FOR SELECT Item1 FROM T;
6907 EXEC SQL DECLARE cur1 CURSOR FOR SELECT version();
6912 An example declaring a cursor for a prepared statement:
6914 EXEC SQL PREPARE stmt1 AS SELECT version();
6915 EXEC SQL DECLARE cur1 CURSOR FOR stmt1;
6921 <title>Compatibility
</title>
6924 <command>DECLARE
</command> is specified in the SQL standard.
6929 <title>See Also
</title>
6931 <simplelist type=
"inline">
6932 <member><xref linkend=
"ecpg-sql-open"/></member>
6933 <member><xref linkend=
"sql-close"/></member>
6934 <member><xref linkend=
"sql-declare"/></member>
6939 <refentry id=
"ecpg-sql-declare-statement">
6941 <refname>DECLARE STATEMENT
</refname>
6942 <refpurpose>declare SQL statement identifier
</refpurpose>
6947 EXEC SQL [ AT
<replaceable class=
"parameter">connection_name
</replaceable> ] DECLARE
<replaceable class=
"parameter">statement_name
</replaceable> STATEMENT
6952 <title>Description
</title>
6955 <command>DECLARE STATEMENT
</command> declares an SQL statement identifier.
6956 SQL statement identifier can be associated with the connection.
6957 When the identifier is used by dynamic SQL statements, the statements
6958 are executed using the associated connection.
6959 The namespace of the declaration is the precompile unit, and multiple
6960 declarations to the same SQL statement identifier are not allowed.
6961 Note that if the precompiler runs in Informix compatibility mode and
6962 some SQL statement is declared,
"database" can not be used as a cursor
6968 <title>Parameters
</title>
6971 <varlistentry id=
"ecpg-sql-declare-statement-connection-name">
6972 <term><replaceable class=
"parameter">connection_name
</replaceable></term>
6975 A database connection name established by the
<command>CONNECT
</command> command.
6978 AT clause can be omitted, but such statement has no meaning.
6985 <varlistentry id=
"ecpg-sql-declare-statement-statement-name">
6986 <term><replaceable class=
"parameter">statement_name
</replaceable></term>
6989 The name of an SQL statement identifier, either as an SQL identifier or a host variable.
6997 <title>Notes
</title>
6999 This association is valid only if the declaration is physically placed on top of a dynamic statement.
7004 <title>Examples
</title>
7007 EXEC SQL CONNECT TO postgres AS con1;
7008 EXEC SQL AT con1 DECLARE sql_stmt STATEMENT;
7009 EXEC SQL DECLARE cursor_name CURSOR FOR sql_stmt;
7010 EXEC SQL PREPARE sql_stmt FROM :dyn_string;
7011 EXEC SQL OPEN cursor_name;
7012 EXEC SQL FETCH cursor_name INTO :column1;
7013 EXEC SQL CLOSE cursor_name;
7018 <title>Compatibility
</title>
7021 <command>DECLARE STATEMENT
</command> is an extension of the SQL standard,
7022 but can be used in famous DBMSs.
7027 <title>See Also
</title>
7029 <simplelist type=
"inline">
7030 <member><xref linkend=
"ecpg-sql-connect"/></member>
7031 <member><xref linkend=
"ecpg-sql-declare"/></member>
7032 <member><xref linkend=
"ecpg-sql-open"/></member>
7037 <refentry id=
"ecpg-sql-describe">
7039 <refname>DESCRIBE
</refname>
7040 <refpurpose>obtain information about a prepared statement or result set
</refpurpose>
7045 DESCRIBE [ OUTPUT ]
<replaceable class=
"parameter">prepared_name
</replaceable> USING [ SQL ] DESCRIPTOR
<replaceable class=
"parameter">descriptor_name
</replaceable>
7046 DESCRIBE [ OUTPUT ]
<replaceable class=
"parameter">prepared_name
</replaceable> INTO [ SQL ] DESCRIPTOR
<replaceable class=
"parameter">descriptor_name
</replaceable>
7047 DESCRIBE [ OUTPUT ]
<replaceable class=
"parameter">prepared_name
</replaceable> INTO
<replaceable class=
"parameter">sqlda_name
</replaceable>
7052 <title>Description
</title>
7055 <command>DESCRIBE
</command> retrieves metadata information about
7056 the result columns contained in a prepared statement, without
7057 actually fetching a row.
7062 <title>Parameters
</title>
7065 <varlistentry id=
"ecpg-sql-describe-prepared-name">
7066 <term><replaceable class=
"parameter">prepared_name
</replaceable></term>
7069 The name of a prepared statement. This can be an SQL
7070 identifier or a host variable.
7075 <varlistentry id=
"ecpg-sql-describe-descriptor-name">
7076 <term><replaceable class=
"parameter">descriptor_name
</replaceable></term>
7079 A descriptor name. It is case sensitive. It can be an SQL
7080 identifier or a host variable.
7085 <varlistentry id=
"ecpg-sql-describe-sqlda-name">
7086 <term><replaceable class=
"parameter">sqlda_name
</replaceable></term>
7089 The name of an SQLDA variable.
7097 <title>Examples
</title>
7100 EXEC SQL ALLOCATE DESCRIPTOR mydesc;
7101 EXEC SQL PREPARE stmt1 FROM :sql_stmt;
7102 EXEC SQL DESCRIBE stmt1 INTO SQL DESCRIPTOR mydesc;
7103 EXEC SQL GET DESCRIPTOR mydesc VALUE
1 :charvar = NAME;
7104 EXEC SQL DEALLOCATE DESCRIPTOR mydesc;
7109 <title>Compatibility
</title>
7112 <command>DESCRIBE
</command> is specified in the SQL standard.
7117 <title>See Also
</title>
7119 <simplelist type=
"inline">
7120 <member><xref linkend=
"ecpg-sql-allocate-descriptor"/></member>
7121 <member><xref linkend=
"ecpg-sql-get-descriptor"/></member>
7126 <refentry id=
"ecpg-sql-disconnect">
7128 <refname>DISCONNECT
</refname>
7129 <refpurpose>terminate a database connection
</refpurpose>
7134 DISCONNECT
<replaceable class=
"parameter">connection_name
</replaceable>
7135 DISCONNECT [ CURRENT ]
7141 <title>Description
</title>
7144 <command>DISCONNECT
</command> closes a connection (or all
7145 connections) to the database.
7150 <title>Parameters
</title>
7153 <varlistentry id=
"ecpg-sql-disconnect-connection-name">
7154 <term><replaceable class=
"parameter">connection_name
</replaceable></term>
7157 A database connection name established by
7158 the
<command>CONNECT
</command> command.
7163 <varlistentry id=
"ecpg-sql-disconnect-current">
7164 <term><literal>CURRENT
</literal></term>
7167 Close the
<quote>current
</quote> connection, which is either
7168 the most recently opened connection, or the connection set by
7169 the
<command>SET CONNECTION
</command> command. This is also
7170 the default if no argument is given to
7171 the
<command>DISCONNECT
</command> command.
7176 <varlistentry id=
"ecpg-sql-disconnect-all">
7177 <term><literal>ALL
</literal></term>
7180 Close all open connections.
7188 <title>Examples
</title>
7194 EXEC SQL CONNECT TO testdb AS con1 USER testuser;
7195 EXEC SQL CONNECT TO testdb AS con2 USER testuser;
7196 EXEC SQL CONNECT TO testdb AS con3 USER testuser;
7198 EXEC SQL DISCONNECT CURRENT; /* close con3 */
7199 EXEC SQL DISCONNECT ALL; /* close con2 and con1 */
7207 <title>Compatibility
</title>
7210 <command>DISCONNECT
</command> is specified in the SQL standard.
7215 <title>See Also
</title>
7217 <simplelist type=
"inline">
7218 <member><xref linkend=
"ecpg-sql-connect"/></member>
7219 <member><xref linkend=
"ecpg-sql-set-connection"/></member>
7224 <refentry id=
"ecpg-sql-execute-immediate">
7226 <refname>EXECUTE IMMEDIATE
</refname>
7227 <refpurpose>dynamically prepare and execute a statement
</refpurpose>
7232 EXECUTE IMMEDIATE
<replaceable class=
"parameter">string
</replaceable>
7237 <title>Description
</title>
7240 <command>EXECUTE IMMEDIATE
</command> immediately prepares and
7241 executes a dynamically specified SQL statement, without
7242 retrieving result rows.
7247 <title>Parameters
</title>
7250 <varlistentry id=
"ecpg-sql-execute-immediate-string">
7251 <term><replaceable class=
"parameter">string
</replaceable></term>
7254 A literal string or a host variable containing the SQL
7255 statement to be executed.
7263 <title>Notes
</title>
7266 In typical usage, the
<replaceable>string
</replaceable> is a host
7267 variable reference to a string containing a dynamically-constructed
7268 SQL statement. The case of a literal string is not very useful;
7269 you might as well just write the SQL statement directly, without
7270 the extra typing of
<command>EXECUTE IMMEDIATE
</command>.
7274 If you do use a literal string, keep in mind that any double quotes
7275 you might wish to include in the SQL statement must be written as
7276 octal escapes (
<literal>\
042</literal>) not the usual C
7277 idiom
<literal>\
"</literal>. This is because the string is inside
7278 an <literal>EXEC SQL</literal> section, so the ECPG lexer parses it
7279 according to SQL rules not C rules. Any embedded backslashes will
7280 later be handled according to C rules; but <literal>\"</literal>
7281 causes an immediate syntax error because it is seen as ending the
7287 <title>Examples
</title>
7290 Here is an example that executes an
<command>INSERT
</command>
7291 statement using
<command>EXECUTE IMMEDIATE
</command> and a host
7292 variable named
<varname>command
</varname>:
7294 sprintf(command,
"INSERT INTO test (name, amount, letter) VALUES ('db: ''r1''', 1, 'f')");
7295 EXEC SQL EXECUTE IMMEDIATE :command;
7301 <title>Compatibility
</title>
7304 <command>EXECUTE IMMEDIATE
</command> is specified in the SQL standard.
7309 <refentry id=
"ecpg-sql-get-descriptor">
7311 <refname>GET DESCRIPTOR
</refname>
7312 <refpurpose>get information from an SQL descriptor area
</refpurpose>
7317 GET DESCRIPTOR
<replaceable class=
"parameter">descriptor_name
</replaceable> <replaceable class=
"parameter">:cvariable
</replaceable> =
<replaceable class=
"parameter">descriptor_header_item
</replaceable> [, ... ]
7318 GET DESCRIPTOR
<replaceable class=
"parameter">descriptor_name
</replaceable> VALUE
<replaceable class=
"parameter">column_number
</replaceable> <replaceable class=
"parameter">:cvariable
</replaceable> =
<replaceable class=
"parameter">descriptor_item
</replaceable> [, ... ]
7323 <title>Description
</title>
7326 <command>GET DESCRIPTOR
</command> retrieves information about a
7327 query result set from an SQL descriptor area and stores it into
7328 host variables. A descriptor area is typically populated
7329 using
<command>FETCH
</command> or
<command>SELECT
</command>
7330 before using this command to transfer the information into host
7335 This command has two forms: The first form retrieves
7336 descriptor
<quote>header
</quote> items, which apply to the result
7337 set in its entirety. One example is the row count. The second
7338 form, which requires the column number as additional parameter,
7339 retrieves information about a particular column. Examples are
7340 the column name and the actual column value.
7345 <title>Parameters
</title>
7348 <varlistentry id=
"ecpg-sql-get-descriptor-descriptor-name">
7349 <term><replaceable class=
"parameter">descriptor_name
</replaceable></term>
7357 <varlistentry id=
"ecpg-sql-get-descriptor-descriptor-header-item">
7358 <term><replaceable class=
"parameter">descriptor_header_item
</replaceable></term>
7361 A token identifying which header information item to retrieve.
7362 Only
<literal>COUNT
</literal>, to get the number of columns in the
7363 result set, is currently supported.
7368 <varlistentry id=
"ecpg-sql-get-descriptor-column-number">
7369 <term><replaceable class=
"parameter">column_number
</replaceable></term>
7372 The number of the column about which information is to be
7373 retrieved. The count starts at
1.
7378 <varlistentry id=
"ecpg-sql-get-descriptor-descriptor-item">
7379 <term><replaceable class=
"parameter">descriptor_item
</replaceable></term>
7382 A token identifying which item of information about a column
7383 to retrieve. See
<xref linkend=
"ecpg-named-descriptors"/> for
7384 a list of supported items.
7389 <varlistentry id=
"ecpg-sql-get-descriptor-cvariable">
7390 <term><replaceable class=
"parameter">cvariable
</replaceable></term>
7393 A host variable that will receive the data retrieved from the
7402 <title>Examples
</title>
7405 An example to retrieve the number of columns in a result set:
7407 EXEC SQL GET DESCRIPTOR d :d_count = COUNT;
7412 An example to retrieve a data length in the first column:
7414 EXEC SQL GET DESCRIPTOR d VALUE
1 :d_returned_octet_length = RETURNED_OCTET_LENGTH;
7419 An example to retrieve the data body of the second column as a
7422 EXEC SQL GET DESCRIPTOR d VALUE
2 :d_data = DATA;
7427 Here is an example for a whole procedure of
7428 executing
<literal>SELECT current_database();
</literal> and showing the number of
7429 columns, the column data length, and the column data:
7434 EXEC SQL BEGIN DECLARE SECTION;
7437 int d_returned_octet_length;
7438 EXEC SQL END DECLARE SECTION;
7440 EXEC SQL CONNECT TO testdb AS con1 USER testuser;
7441 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
7442 EXEC SQL ALLOCATE DESCRIPTOR d;
7444 /* Declare, open a cursor, and assign a descriptor to the cursor */
7445 EXEC SQL DECLARE cur CURSOR FOR SELECT current_database();
7447 EXEC SQL FETCH NEXT FROM cur INTO SQL DESCRIPTOR d;
7449 /* Get a number of total columns */
7450 EXEC SQL GET DESCRIPTOR d :d_count = COUNT;
7451 printf(
"d_count = %d\n", d_count);
7453 /* Get length of a returned column */
7454 EXEC SQL GET DESCRIPTOR d VALUE
1 :d_returned_octet_length = RETURNED_OCTET_LENGTH;
7455 printf(
"d_returned_octet_length = %d\n", d_returned_octet_length);
7457 /* Fetch the returned column as a string */
7458 EXEC SQL GET DESCRIPTOR d VALUE
1 :d_data = DATA;
7459 printf(
"d_data = %s\n", d_data);
7465 EXEC SQL DEALLOCATE DESCRIPTOR d;
7466 EXEC SQL DISCONNECT ALL;
7471 When the example is executed, the result will look like this:
7474 d_returned_octet_length =
6
7481 <title>Compatibility
</title>
7484 <command>GET DESCRIPTOR
</command> is specified in the SQL standard.
7489 <title>See Also
</title>
7491 <simplelist type=
"inline">
7492 <member><xref linkend=
"ecpg-sql-allocate-descriptor"/></member>
7493 <member><xref linkend=
"ecpg-sql-set-descriptor"/></member>
7498 <refentry id=
"ecpg-sql-open">
7500 <refname>OPEN
</refname>
7501 <refpurpose>open a dynamic cursor
</refpurpose>
7506 OPEN
<replaceable class=
"parameter">cursor_name
</replaceable>
7507 OPEN
<replaceable class=
"parameter">cursor_name
</replaceable> USING
<replaceable class=
"parameter">value
</replaceable> [, ... ]
7508 OPEN
<replaceable class=
"parameter">cursor_name
</replaceable> USING SQL DESCRIPTOR
<replaceable class=
"parameter">descriptor_name
</replaceable>
7513 <title>Description
</title>
7516 <command>OPEN
</command> opens a cursor and optionally binds
7517 actual values to the placeholders in the cursor's declaration.
7518 The cursor must previously have been declared with
7519 the
<command>DECLARE
</command> command. The execution
7520 of
<command>OPEN
</command> causes the query to start executing on
7526 <title>Parameters
</title>
7529 <varlistentry id=
"ecpg-sql-open-cursor-name">
7530 <term><replaceable class=
"parameter">cursor_name
</replaceable></term>
7533 The name of the cursor to be opened. This can be an SQL
7534 identifier or a host variable.
7539 <varlistentry id=
"ecpg-sql-open-value">
7540 <term><replaceable class=
"parameter">value
</replaceable></term>
7543 A value to be bound to a placeholder in the cursor. This can
7544 be an SQL constant, a host variable, or a host variable with
7550 <varlistentry id=
"ecpg-sql-open-descriptor-name">
7551 <term><replaceable class=
"parameter">descriptor_name
</replaceable></term>
7554 The name of a descriptor containing values to be bound to the
7555 placeholders in the cursor. This can be an SQL identifier or
7564 <title>Examples
</title>
7568 EXEC SQL OPEN d USING
1, 'test';
7569 EXEC SQL OPEN c1 USING SQL DESCRIPTOR mydesc;
7570 EXEC SQL OPEN :curname1;
7575 <title>Compatibility
</title>
7578 <command>OPEN
</command> is specified in the SQL standard.
7583 <title>See Also
</title>
7585 <simplelist type=
"inline">
7586 <member><xref linkend=
"ecpg-sql-declare"/></member>
7587 <member><xref linkend=
"sql-close"/></member>
7592 <refentry id=
"ecpg-sql-prepare">
7594 <refname>PREPARE
</refname>
7595 <refpurpose>prepare a statement for execution
</refpurpose>
7600 PREPARE
<replaceable class=
"parameter">prepared_name
</replaceable> FROM
<replaceable class=
"parameter">string
</replaceable>
7605 <title>Description
</title>
7608 <command>PREPARE
</command> prepares a statement dynamically
7609 specified as a string for execution. This is different from the
7610 direct SQL statement
<xref linkend=
"sql-prepare"/>, which can also
7611 be used in embedded programs. The
<xref linkend=
"sql-execute"/>
7612 command is used to execute either kind of prepared statement.
7617 <title>Parameters
</title>
7620 <varlistentry id=
"ecpg-sql-prepare-prepared-name">
7621 <term><replaceable class=
"parameter">prepared_name
</replaceable></term>
7624 An identifier for the prepared query.
7629 <varlistentry id=
"ecpg-sql-prepare-string">
7630 <term><replaceable class=
"parameter">string
</replaceable></term>
7633 A literal string or a host variable containing a preparable
7634 SQL statement, one of SELECT, INSERT, UPDATE, or DELETE.
7635 Use question marks (
<literal>?
</literal>) for parameter values
7636 to be supplied at execution.
7644 <title>Notes
</title>
7647 In typical usage, the
<replaceable>string
</replaceable> is a host
7648 variable reference to a string containing a dynamically-constructed
7649 SQL statement. The case of a literal string is not very useful;
7650 you might as well just write a direct SQL
<command>PREPARE
</command>
7655 If you do use a literal string, keep in mind that any double quotes
7656 you might wish to include in the SQL statement must be written as
7657 octal escapes (
<literal>\
042</literal>) not the usual C
7658 idiom
<literal>\
"</literal>. This is because the string is inside
7659 an <literal>EXEC SQL</literal> section, so the ECPG lexer parses it
7660 according to SQL rules not C rules. Any embedded backslashes will
7661 later be handled according to C rules; but <literal>\"</literal>
7662 causes an immediate syntax error because it is seen as ending the
7668 <title>Examples
</title>
7670 char *stmt =
"SELECT * FROM test1 WHERE a = ? AND b = ?";
7672 EXEC SQL ALLOCATE DESCRIPTOR outdesc;
7673 EXEC SQL PREPARE foo FROM :stmt;
7675 EXEC SQL EXECUTE foo USING SQL DESCRIPTOR indesc INTO SQL DESCRIPTOR outdesc;
7680 <title>Compatibility
</title>
7683 <command>PREPARE
</command> is specified in the SQL standard.
7688 <title>See Also
</title>
7690 <simplelist type=
"inline">
7691 <member><xref linkend=
"sql-execute"/></member>
7696 <refentry id=
"ecpg-sql-set-autocommit">
7698 <refname>SET AUTOCOMMIT
</refname>
7699 <refpurpose>set the autocommit behavior of the current session
</refpurpose>
7704 SET AUTOCOMMIT { = | TO } { ON | OFF }
7709 <title>Description
</title>
7712 <command>SET AUTOCOMMIT
</command> sets the autocommit behavior of
7713 the current database session. By default, embedded SQL programs
7714 are
<emphasis>not
</emphasis> in autocommit mode,
7715 so
<command>COMMIT
</command> needs to be issued explicitly when
7716 desired. This command can change the session to autocommit mode,
7717 where each individual statement is committed implicitly.
7722 <title>Compatibility
</title>
7725 <command>SET AUTOCOMMIT
</command> is an extension of PostgreSQL ECPG.
7730 <refentry id=
"ecpg-sql-set-connection">
7732 <refname>SET CONNECTION
</refname>
7733 <refpurpose>select a database connection
</refpurpose>
7738 SET CONNECTION [ TO | = ]
<replaceable class=
"parameter">connection_name
</replaceable>
7743 <title>Description
</title>
7746 <command>SET CONNECTION
</command> sets the
<quote>current
</quote>
7747 database connection, which is the one that all commands use
7753 <title>Parameters
</title>
7756 <varlistentry id=
"ecpg-sql-set-connection-connection-name">
7757 <term><replaceable class=
"parameter">connection_name
</replaceable></term>
7760 A database connection name established by
7761 the
<command>CONNECT
</command> command.
7766 <varlistentry id=
"ecpg-sql-set-connection-current">
7767 <term><literal>CURRENT
</literal></term>
7770 Set the connection to the current connection (thus, nothing happens).
7778 <title>Examples
</title>
7781 EXEC SQL SET CONNECTION TO con2;
7782 EXEC SQL SET CONNECTION = con1;
7787 <title>Compatibility
</title>
7790 <command>SET CONNECTION
</command> is specified in the SQL standard.
7795 <title>See Also
</title>
7797 <simplelist type=
"inline">
7798 <member><xref linkend=
"ecpg-sql-connect"/></member>
7799 <member><xref linkend=
"ecpg-sql-disconnect"/></member>
7804 <refentry id=
"ecpg-sql-set-descriptor">
7806 <refname>SET DESCRIPTOR
</refname>
7807 <refpurpose>set information in an SQL descriptor area
</refpurpose>
7812 SET DESCRIPTOR
<replaceable class=
"parameter">descriptor_name
</replaceable> <replaceable class=
"parameter">descriptor_header_item
</replaceable> =
<replaceable>value
</replaceable> [, ... ]
7813 SET DESCRIPTOR
<replaceable class=
"parameter">descriptor_name
</replaceable> VALUE
<replaceable class=
"parameter">number
</replaceable> <replaceable class=
"parameter">descriptor_item
</replaceable> =
<replaceable>value
</replaceable> [, ...]
7818 <title>Description
</title>
7821 <command>SET DESCRIPTOR
</command> populates an SQL descriptor
7822 area with values. The descriptor area is then typically used to
7823 bind parameters in a prepared query execution.
7827 This command has two forms: The first form applies to the
7828 descriptor
<quote>header
</quote>, which is independent of a
7829 particular datum. The second form assigns values to particular
7830 datums, identified by number.
7835 <title>Parameters
</title>
7838 <varlistentry id=
"ecpg-sql-set-descriptor-descriptor-name">
7839 <term><replaceable class=
"parameter">descriptor_name
</replaceable></term>
7847 <varlistentry id=
"ecpg-sql-set-descriptor-descriptor-header-item">
7848 <term><replaceable class=
"parameter">descriptor_header_item
</replaceable></term>
7851 A token identifying which header information item to set.
7852 Only
<literal>COUNT
</literal>, to set the number of descriptor
7853 items, is currently supported.
7858 <varlistentry id=
"ecpg-sql-set-descriptor-number">
7859 <term><replaceable class=
"parameter">number
</replaceable></term>
7862 The number of the descriptor item to set. The count starts at
7868 <varlistentry id=
"ecpg-sql-set-descriptor-descriptor-item">
7869 <term><replaceable class=
"parameter">descriptor_item
</replaceable></term>
7872 A token identifying which item of information to set in the
7873 descriptor. See
<xref linkend=
"ecpg-named-descriptors"/> for a
7874 list of supported items.
7879 <varlistentry id=
"ecpg-sql-set-descriptor-value">
7880 <term><replaceable class=
"parameter">value
</replaceable></term>
7883 A value to store into the descriptor item. This can be an SQL
7884 constant or a host variable.
7892 <title>Examples
</title>
7894 EXEC SQL SET DESCRIPTOR indesc COUNT =
1;
7895 EXEC SQL SET DESCRIPTOR indesc VALUE
1 DATA =
2;
7896 EXEC SQL SET DESCRIPTOR indesc VALUE
1 DATA = :val1;
7897 EXEC SQL SET DESCRIPTOR indesc VALUE
2 INDICATOR = :val1, DATA = 'some string';
7898 EXEC SQL SET DESCRIPTOR indesc VALUE
2 INDICATOR = :val2null, DATA = :val2;
7903 <title>Compatibility
</title>
7906 <command>SET DESCRIPTOR
</command> is specified in the SQL standard.
7911 <title>See Also
</title>
7913 <simplelist type=
"inline">
7914 <member><xref linkend=
"ecpg-sql-allocate-descriptor"/></member>
7915 <member><xref linkend=
"ecpg-sql-get-descriptor"/></member>
7920 <refentry id=
"ecpg-sql-type">
7922 <refname>TYPE
</refname>
7923 <refpurpose>define a new data type
</refpurpose>
7928 TYPE
<replaceable class=
"parameter">type_name
</replaceable> IS
<replaceable class=
"parameter">ctype
</replaceable>
7933 <title>Description
</title>
7936 The
<command>TYPE
</command> command defines a new C type. It is
7937 equivalent to putting a
<literal>typedef
</literal> into a declare
7942 This command is only recognized when
<command>ecpg
</command> is
7943 run with the
<option>-c
</option> option.
7948 <title>Parameters
</title>
7951 <varlistentry id=
"ecpg-sql-type-type-name">
7952 <term><replaceable class=
"parameter">type_name
</replaceable></term>
7955 The name for the new type. It must be a valid C type name.
7960 <varlistentry id=
"ecpg-sql-type-ctype">
7961 <term><replaceable class=
"parameter">ctype
</replaceable></term>
7964 A C type specification.
7972 <title>Examples
</title>
7975 EXEC SQL TYPE customer IS
7982 EXEC SQL TYPE cust_ind IS
7989 EXEC SQL TYPE c IS char reference;
7990 EXEC SQL TYPE ind IS union { int integer; short smallint; };
7991 EXEC SQL TYPE intarray IS int[AMOUNT];
7992 EXEC SQL TYPE str IS varchar[BUFFERSIZ];
7993 EXEC SQL TYPE string IS char[
11];
7997 Here is an example program that uses
<command>EXEC SQL
8000 EXEC SQL WHENEVER SQLERROR SQLPRINT;
8009 EXEC SQL TYPE tt_ind IS
8018 EXEC SQL BEGIN DECLARE SECTION;
8021 EXEC SQL END DECLARE SECTION;
8023 EXEC SQL CONNECT TO testdb AS con1;
8024 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
8026 EXEC SQL SELECT current_database(),
256 INTO :t:t_ind LIMIT
1;
8028 printf(
"t.v = %s\n", t.v.arr);
8029 printf(
"t.i = %d\n", t.i);
8031 printf(
"t_ind.v_ind = %d\n", t_ind.v_ind);
8032 printf(
"t_ind.i_ind = %d\n", t_ind.i_ind);
8034 EXEC SQL DISCONNECT con1;
8040 The output from this program looks like this:
8051 <title>Compatibility
</title>
8054 The
<command>TYPE
</command> command is a PostgreSQL extension.
8059 <refentry id=
"ecpg-sql-var">
8061 <refname>VAR
</refname>
8062 <refpurpose>define a variable
</refpurpose>
8067 VAR
<replaceable>varname
</replaceable> IS
<replaceable>ctype
</replaceable>
8072 <title>Description
</title>
8075 The
<command>VAR
</command> command assigns a new C data type
8076 to a host variable. The host variable must be previously
8077 declared in a declare section.
8082 <title>Parameters
</title>
8085 <varlistentry id=
"ecpg-sql-var-varname">
8086 <term><replaceable class=
"parameter">varname
</replaceable></term>
8094 <varlistentry id=
"ecpg-sql-var-ctype">
8095 <term><replaceable class=
"parameter">ctype
</replaceable></term>
8098 A C type specification.
8106 <title>Examples
</title>
8109 Exec sql begin declare section;
8111 exec sql end declare section;
8112 EXEC SQL VAR a IS int;
8117 <title>Compatibility
</title>
8120 The
<command>VAR
</command> command is a PostgreSQL extension.
8125 <refentry id=
"ecpg-sql-whenever">
8127 <refname>WHENEVER
</refname>
8128 <refpurpose>specify the action to be taken when an SQL statement causes a specific class condition to be raised
</refpurpose>
8133 WHENEVER { NOT FOUND | SQLERROR | SQLWARNING }
<replaceable class=
"parameter">action
</replaceable>
8138 <title>Description
</title>
8141 Define a behavior which is called on the special cases (Rows not
8142 found, SQL warnings or errors) in the result of SQL execution.
8147 <title>Parameters
</title>
8150 See
<xref linkend=
"ecpg-whenever"/> for a description of the
8156 <title>Examples
</title>
8159 EXEC SQL WHENEVER NOT FOUND CONTINUE;
8160 EXEC SQL WHENEVER NOT FOUND DO BREAK;
8161 EXEC SQL WHENEVER NOT FOUND DO CONTINUE;
8162 EXEC SQL WHENEVER SQLWARNING SQLPRINT;
8163 EXEC SQL WHENEVER SQLWARNING DO warn();
8164 EXEC SQL WHENEVER SQLERROR sqlprint;
8165 EXEC SQL WHENEVER SQLERROR CALL print2();
8166 EXEC SQL WHENEVER SQLERROR DO handle_error(
"select");
8167 EXEC SQL WHENEVER SQLERROR DO sqlnotice(NULL, NONO);
8168 EXEC SQL WHENEVER SQLERROR DO sqlprint();
8169 EXEC SQL WHENEVER SQLERROR GOTO error_label;
8170 EXEC SQL WHENEVER SQLERROR STOP;
8174 A typical application is the use of
<literal>WHENEVER NOT FOUND
8175 BREAK
</literal> to handle looping through result sets:
8180 EXEC SQL CONNECT TO testdb AS con1;
8181 EXEC SQL SELECT pg_catalog.set_config('search_path', '', false); EXEC SQL COMMIT;
8182 EXEC SQL ALLOCATE DESCRIPTOR d;
8183 EXEC SQL DECLARE cur CURSOR FOR SELECT current_database(), 'hoge',
256;
8186 /* when end of result set reached, break out of while loop */
8187 EXEC SQL WHENEVER NOT FOUND DO BREAK;
8191 EXEC SQL FETCH NEXT FROM cur INTO SQL DESCRIPTOR d;
8198 EXEC SQL DEALLOCATE DESCRIPTOR d;
8199 EXEC SQL DISCONNECT ALL;
8208 <title>Compatibility
</title>
8211 <command>WHENEVER
</command> is specified in the SQL standard, but
8212 most of the actions are PostgreSQL extensions.
8218 <sect1 id=
"ecpg-informix-compat">
8219 <title><productname>Informix
</productname> Compatibility Mode
</title>
8221 <command>ecpg
</command> can be run in a so-called
<firstterm>Informix compatibility mode
</firstterm>. If
8222 this mode is active, it tries to behave as if it were the
<productname>Informix
</productname>
8223 precompiler for
<productname>Informix
</productname> E/SQL. Generally spoken this will allow you to use
8224 the dollar sign instead of the
<literal>EXEC SQL
</literal> primitive to introduce
8225 embedded SQL commands:
8228 $CONNECT TO :dbname;
8229 $CREATE TABLE test(i INT PRIMARY KEY, j INT);
8230 $INSERT INTO test(i, j) VALUES (
7, :j);
8237 There must not be any white space between the
<literal>$
</literal>
8238 and a following preprocessor directive, that is,
8239 <literal>include
</literal>,
<literal>define
</literal>,
<literal>ifdef
</literal>,
8240 etc. Otherwise, the preprocessor will parse the token as a host
8246 There are two compatibility modes:
<literal>INFORMIX
</literal>,
<literal>INFORMIX_SE
</literal>
8249 When linking programs that use this compatibility mode, remember to link
8250 against
<literal>libcompat
</literal> that is shipped with ECPG.
8253 Besides the previously explained syntactic sugar, the
<productname>Informix
</productname> compatibility
8254 mode ports some functions for input, output and transformation of data as
8255 well as embedded SQL statements known from E/SQL to ECPG.
8258 <productname>Informix
</productname> compatibility mode is closely connected to the pgtypeslib library
8259 of ECPG. pgtypeslib maps SQL data types to data types within the C host
8260 program and most of the additional functions of the
<productname>Informix
</productname> compatibility
8261 mode allow you to operate on those C host program types. Note however that
8262 the extent of the compatibility is limited. It does not try to copy
<productname>Informix
</productname>
8263 behavior; it allows you to do more or less the same operations and gives
8264 you functions that have the same name and the same basic behavior but it is
8265 no drop-in replacement if you are using
<productname>Informix
</productname> at the moment. Moreover,
8266 some of the data types are different. For example,
8267 <productname>PostgreSQL
</productname>'s datetime and interval types do not
8268 know about ranges like for example
<literal>YEAR TO MINUTE
</literal> so you won't
8269 find support in ECPG for that either.
8272 <sect2 id=
"ecpg-informix-types">
8273 <title>Additional Types
</title>
8275 The Informix-special
"string" pseudo-type for storing right-trimmed character string data is now
8276 supported in Informix-mode without using
<literal>typedef
</literal>. In fact, in Informix-mode,
8277 ECPG refuses to process source files that contain
<literal>typedef sometype string;
</literal>
8279 EXEC SQL BEGIN DECLARE SECTION;
8280 string userid; /* this variable will contain trimmed data */
8281 EXEC SQL END DECLARE SECTION;
8283 EXEC SQL FETCH MYCUR INTO :userid;
8288 <sect2 id=
"ecpg-informix-statements">
8289 <title>Additional/Missing Embedded SQL Statements
</title>
8292 <varlistentry id=
"ecpg-informix-statements-close-database">
8293 <term><literal>CLOSE DATABASE
</literal></term>
8296 This statement closes the current connection. In fact, this is a
8297 synonym for ECPG's
<literal>DISCONNECT CURRENT
</literal>:
8299 $CLOSE DATABASE; /* close the current connection */
8300 EXEC SQL CLOSE DATABASE;
8305 <varlistentry id=
"ecpg-informix-statements-free-cursor-name">
8306 <term><literal>FREE cursor_name
</literal></term>
8309 Due to differences in how ECPG works compared to Informix's ESQL/C (namely, which steps
8310 are purely grammar transformations and which steps rely on the underlying run-time library)
8311 there is no
<literal>FREE cursor_name
</literal> statement in ECPG. This is because in ECPG,
8312 <literal>DECLARE CURSOR
</literal> doesn't translate to a function call into
8313 the run-time library that uses to the cursor name. This means that there's no run-time
8314 bookkeeping of SQL cursors in the ECPG run-time library, only in the PostgreSQL server.
8318 <varlistentry id=
"ecpg-informix-statements-free-statement-name">
8319 <term><literal>FREE statement_name
</literal></term>
8322 <literal>FREE statement_name
</literal> is a synonym for
<literal>DEALLOCATE PREPARE statement_name
</literal>.
8330 <sect2 id=
"ecpg-informix-sqlda">
8331 <title>Informix-compatible SQLDA Descriptor Areas
</title>
8333 Informix-compatible mode supports a different structure than the one described in
8334 <xref linkend=
"ecpg-sqlda-descriptors"/>. See below:
8336 struct sqlvar_compat
8351 short sqlsourcetype;
8362 struct sqlvar_compat *sqlvar;
8365 struct sqlda_compat *desc_next;
8369 typedef struct sqlvar_compat sqlvar_t;
8370 typedef struct sqlda_compat sqlda_t;
8375 The global properties are:
8378 <varlistentry id=
"ecpg-informix-sqlda-sqld">
8379 <term><literal>sqld
</literal></term>
8382 The number of fields in the
<literal>SQLDA
</literal> descriptor.
8387 <varlistentry id=
"ecpg-informix-sqlda-sqlvar">
8388 <term><literal>sqlvar
</literal></term>
8391 Pointer to the per-field properties.
8396 <varlistentry id=
"ecpg-informix-sqlda-desc-name">
8397 <term><literal>desc_name
</literal></term>
8400 Unused, filled with zero-bytes.
8405 <varlistentry id=
"ecpg-informix-sqlda-desc-occ">
8406 <term><literal>desc_occ
</literal></term>
8409 Size of the allocated structure.
8414 <varlistentry id=
"ecpg-informix-sqlda-desc-next">
8415 <term><literal>desc_next
</literal></term>
8418 Pointer to the next SQLDA structure if the result set contains more than one record.
8423 <varlistentry id=
"ecpg-informix-sqlda-reserved">
8424 <term><literal>reserved
</literal></term>
8427 Unused pointer, contains NULL. Kept for Informix-compatibility.
8434 The per-field properties are below, they are stored in the
<literal>sqlvar
</literal> array:
8438 <varlistentry id=
"ecpg-informix-sqlda-sqltype">
8439 <term><literal>sqltype
</literal></term>
8442 Type of the field. Constants are in
<literal>sqltypes.h
</literal>
8447 <varlistentry id=
"ecpg-informix-sqlda-sqllen">
8448 <term><literal>sqllen
</literal></term>
8451 Length of the field data.
8456 <varlistentry id=
"ecpg-informix-sqlda-sqldata">
8457 <term><literal>sqldata
</literal></term>
8460 Pointer to the field data. The pointer is of
<literal>char *
</literal> type,
8461 the data pointed by it is in a binary format. Example:
8465 switch (sqldata-
>sqlvar[i].sqltype)
8468 intval = *(int *)sqldata-
>sqlvar[i].sqldata;
8477 <varlistentry id=
"ecpg-informix-sqlda-sqlind">
8478 <term><literal>sqlind
</literal></term>
8481 Pointer to the NULL indicator. If returned by DESCRIBE or FETCH then it's always a valid pointer.
8482 If used as input for
<literal>EXECUTE ... USING sqlda;
</literal> then NULL-pointer value means
8483 that the value for this field is non-NULL. Otherwise a valid pointer and
<literal>sqlitype
</literal>
8484 has to be properly set. Example:
8486 if (*(int2 *)sqldata-
>sqlvar[i].sqlind !=
0)
8487 printf(
"value is NULL\n");
8493 <varlistentry id=
"ecpg-informix-sqlda-sqlname">
8494 <term><literal>sqlname
</literal></term>
8497 Name of the field.
0-terminated string.
8502 <varlistentry id=
"ecpg-informix-sqlda-sqlformat">
8503 <term><literal>sqlformat
</literal></term>
8506 Reserved in Informix, value of
<xref linkend=
"libpq-PQfformat"/> for the field.
8511 <varlistentry id=
"ecpg-informix-sqlda-sqlitype">
8512 <term><literal>sqlitype
</literal></term>
8515 Type of the NULL indicator data. It's always SQLSMINT when returning data from the server.
8516 When the
<literal>SQLDA
</literal> is used for a parameterized query, the data is treated
8517 according to the set type.
8522 <varlistentry id=
"ecpg-informix-sqlda-sqlilen">
8523 <term><literal>sqlilen
</literal></term>
8526 Length of the NULL indicator data.
8531 <varlistentry id=
"ecpg-informix-sqlda-sqlxid">
8532 <term><literal>sqlxid
</literal></term>
8535 Extended type of the field, result of
<xref linkend=
"libpq-PQftype"/>.
8540 <varlistentry id=
"ecpg-informix-sqlda-sqltypename">
8541 <term><literal>sqltypename
</literal></term>
8542 <term><literal>sqltypelen
</literal></term>
8543 <term><literal>sqlownerlen
</literal></term>
8544 <term><literal>sqlsourcetype
</literal></term>
8545 <term><literal>sqlownername
</literal></term>
8546 <term><literal>sqlsourceid
</literal></term>
8547 <term><literal>sqlflags
</literal></term>
8548 <term><literal>sqlreserved
</literal></term>
8556 <varlistentry id=
"ecpg-informix-sqlda-sqlilongdata">
8557 <term><literal>sqlilongdata
</literal></term>
8560 It equals to
<literal>sqldata
</literal> if
<literal>sqllen
</literal> is larger than
32kB.
8569 EXEC SQL INCLUDE sqlda.h;
8571 sqlda_t *sqlda; /* This doesn't need to be under embedded DECLARE SECTION */
8573 EXEC SQL BEGIN DECLARE SECTION;
8574 char *prep_stmt =
"select * from table1";
8576 EXEC SQL END DECLARE SECTION;
8580 EXEC SQL PREPARE mystmt FROM :prep_stmt;
8582 EXEC SQL DESCRIBE mystmt INTO sqlda;
8584 printf(
"# of fields: %d\n", sqlda-
>sqld);
8585 for (i =
0; i
< sqlda-
>sqld; i++)
8586 printf(
"field %d: \"%s\
"\n", sqlda-
>sqlvar[i]-
>sqlname);
8588 EXEC SQL DECLARE mycursor CURSOR FOR mystmt;
8589 EXEC SQL OPEN mycursor;
8590 EXEC SQL WHENEVER NOT FOUND GOTO out;
8594 EXEC SQL FETCH mycursor USING sqlda;
8597 EXEC SQL CLOSE mycursor;
8599 free(sqlda); /* The main structure is all to be free(),
8600 * sqlda and sqlda-
>sqlvar is in one allocated area */
8602 For more information, see the
<literal>sqlda.h
</literal> header and the
8603 <literal>src/interfaces/ecpg/test/compat_informix/sqlda.pgc
</literal> regression test.
8607 <sect2 id=
"ecpg-informix-functions">
8608 <title>Additional Functions
</title>
8611 <varlistentry id=
"ecpg-informix-functions-decadd">
8612 <term><function>decadd
</function></term>
8615 Add two decimal type values.
8617 int decadd(decimal *arg1, decimal *arg2, decimal *sum);
8619 The function receives a pointer to the first operand of type decimal
8620 (
<literal>arg1
</literal>), a pointer to the second operand of type decimal
8621 (
<literal>arg2
</literal>) and a pointer to a value of type decimal that will
8622 contain the sum (
<literal>sum
</literal>). On success, the function returns
0.
8623 <symbol>ECPG_INFORMIX_NUM_OVERFLOW
</symbol> is returned in case of overflow and
8624 <symbol>ECPG_INFORMIX_NUM_UNDERFLOW
</symbol> in case of underflow. -
1 is returned for
8625 other failures and
<varname>errno
</varname> is set to the respective
<varname>errno
</varname> number of the
8631 <varlistentry id=
"ecpg-informix-functions-deccmp">
8632 <term><function>deccmp
</function></term>
8635 Compare two variables of type decimal.
8637 int deccmp(decimal *arg1, decimal *arg2);
8639 The function receives a pointer to the first decimal value
8640 (
<literal>arg1
</literal>), a pointer to the second decimal value
8641 (
<literal>arg2
</literal>) and returns an integer value that indicates which is
8646 1, if the value that
<literal>arg1
</literal> points to is bigger than the
8647 value that
<literal>var2
</literal> points to
8652 -
1, if the value that
<literal>arg1
</literal> points to is smaller than the
8653 value that
<literal>arg2
</literal> points to
</para>
8657 0, if the value that
<literal>arg1
</literal> points to and the value that
8658 <literal>arg2
</literal> points to are equal
8666 <varlistentry id=
"ecpg-informix-functions-deccopy">
8667 <term><function>deccopy
</function></term>
8670 Copy a decimal value.
8672 void deccopy(decimal *src, decimal *target);
8674 The function receives a pointer to the decimal value that should be
8675 copied as the first argument (
<literal>src
</literal>) and a pointer to the
8676 target structure of type decimal (
<literal>target
</literal>) as the second
8682 <varlistentry id=
"ecpg-informix-functions-deccvasc">
8683 <term><function>deccvasc
</function></term>
8686 Convert a value from its ASCII representation into a decimal type.
8688 int deccvasc(char *cp, int len, decimal *np);
8690 The function receives a pointer to string that contains the string
8691 representation of the number to be converted (
<literal>cp
</literal>) as well
8692 as its length
<literal>len
</literal>.
<literal>np
</literal> is a pointer to the
8693 decimal value that saves the result of the operation.
8696 Valid formats are for example:
8697 <literal>-
2</literal>,
8698 <literal>.794</literal>,
8699 <literal>+
3.44</literal>,
8700 <literal>592.49E07
</literal> or
8701 <literal>-
32.84e-4</literal>.
8704 The function returns
0 on success. If overflow or underflow occurred,
8705 <literal>ECPG_INFORMIX_NUM_OVERFLOW
</literal> or
8706 <literal>ECPG_INFORMIX_NUM_UNDERFLOW
</literal> is returned. If the ASCII
8707 representation could not be parsed,
8708 <literal>ECPG_INFORMIX_BAD_NUMERIC
</literal> is returned or
8709 <literal>ECPG_INFORMIX_BAD_EXPONENT
</literal> if this problem occurred while
8710 parsing the exponent.
8715 <varlistentry id=
"ecpg-informix-functions-deccvdbl">
8716 <term><function>deccvdbl
</function></term>
8719 Convert a value of type double to a value of type decimal.
8721 int deccvdbl(double dbl, decimal *np);
8723 The function receives the variable of type double that should be
8724 converted as its first argument (
<literal>dbl
</literal>). As the second
8725 argument (
<literal>np
</literal>), the function receives a pointer to the
8726 decimal variable that should hold the result of the operation.
8729 The function returns
0 on success and a negative value if the
8735 <varlistentry id=
"ecpg-informix-functions-deccvint">
8736 <term><function>deccvint
</function></term>
8739 Convert a value of type int to a value of type decimal.
8741 int deccvint(int in, decimal *np);
8743 The function receives the variable of type int that should be
8744 converted as its first argument (
<literal>in
</literal>). As the second
8745 argument (
<literal>np
</literal>), the function receives a pointer to the
8746 decimal variable that should hold the result of the operation.
8749 The function returns
0 on success and a negative value if the
8755 <varlistentry id=
"ecpg-informix-functions-deccvlong">
8756 <term><function>deccvlong
</function></term>
8759 Convert a value of type long to a value of type decimal.
8761 int deccvlong(long lng, decimal *np);
8763 The function receives the variable of type long that should be
8764 converted as its first argument (
<literal>lng
</literal>). As the second
8765 argument (
<literal>np
</literal>), the function receives a pointer to the
8766 decimal variable that should hold the result of the operation.
8769 The function returns
0 on success and a negative value if the
8775 <varlistentry id=
"ecpg-informix-functions-decdiv">
8776 <term><function>decdiv
</function></term>
8779 Divide two variables of type decimal.
8781 int decdiv(decimal *n1, decimal *n2, decimal *result);
8783 The function receives pointers to the variables that are the first
8784 (
<literal>n1
</literal>) and the second (
<literal>n2
</literal>) operands and
8785 calculates
<literal>n1
</literal>/
<literal>n2
</literal>.
<literal>result
</literal> is a
8786 pointer to the variable that should hold the result of the operation.
8789 On success,
0 is returned and a negative value if the division fails.
8790 If overflow or underflow occurred, the function returns
8791 <literal>ECPG_INFORMIX_NUM_OVERFLOW
</literal> or
8792 <literal>ECPG_INFORMIX_NUM_UNDERFLOW
</literal> respectively. If an attempt to
8793 divide by zero is observed, the function returns
8794 <literal>ECPG_INFORMIX_DIVIDE_ZERO
</literal>.
8799 <varlistentry id=
"ecpg-informix-functions-decmul">
8800 <term><function>decmul
</function></term>
8803 Multiply two decimal values.
8805 int decmul(decimal *n1, decimal *n2, decimal *result);
8807 The function receives pointers to the variables that are the first
8808 (
<literal>n1
</literal>) and the second (
<literal>n2
</literal>) operands and
8809 calculates
<literal>n1
</literal>*
<literal>n2
</literal>.
<literal>result
</literal> is a
8810 pointer to the variable that should hold the result of the operation.
8813 On success,
0 is returned and a negative value if the multiplication
8814 fails. If overflow or underflow occurred, the function returns
8815 <literal>ECPG_INFORMIX_NUM_OVERFLOW
</literal> or
8816 <literal>ECPG_INFORMIX_NUM_UNDERFLOW
</literal> respectively.
8821 <varlistentry id=
"ecpg-informix-functions-decsub">
8822 <term><function>decsub
</function></term>
8825 Subtract one decimal value from another.
8827 int decsub(decimal *n1, decimal *n2, decimal *result);
8829 The function receives pointers to the variables that are the first
8830 (
<literal>n1
</literal>) and the second (
<literal>n2
</literal>) operands and
8831 calculates
<literal>n1
</literal>-
<literal>n2
</literal>.
<literal>result
</literal> is a
8832 pointer to the variable that should hold the result of the operation.
8835 On success,
0 is returned and a negative value if the subtraction
8836 fails. If overflow or underflow occurred, the function returns
8837 <literal>ECPG_INFORMIX_NUM_OVERFLOW
</literal> or
8838 <literal>ECPG_INFORMIX_NUM_UNDERFLOW
</literal> respectively.
8843 <varlistentry id=
"ecpg-informix-functions-dectoasc">
8844 <term><function>dectoasc
</function></term>
8847 Convert a variable of type decimal to its ASCII representation in a C
8850 int dectoasc(decimal *np, char *cp, int len, int right)
8852 The function receives a pointer to a variable of type decimal
8853 (
<literal>np
</literal>) that it converts to its textual representation.
8854 <literal>cp
</literal> is the buffer that should hold the result of the
8855 operation. The parameter
<literal>right
</literal> specifies, how many digits
8856 right of the decimal point should be included in the output. The result
8857 will be rounded to this number of decimal digits. Setting
8858 <literal>right
</literal> to -
1 indicates that all available decimal digits
8859 should be included in the output. If the length of the output buffer,
8860 which is indicated by
<literal>len
</literal> is not sufficient to hold the
8861 textual representation including the trailing zero byte, only a
8862 single
<literal>*
</literal> character is stored in the result and -
1 is
8866 The function returns either -
1 if the buffer
<literal>cp
</literal> was too
8867 small or
<literal>ECPG_INFORMIX_OUT_OF_MEMORY
</literal> if memory was
8873 <varlistentry id=
"ecpg-informix-functions-dectodbl">
8874 <term><function>dectodbl
</function></term>
8877 Convert a variable of type decimal to a double.
8879 int dectodbl(decimal *np, double *dblp);
8881 The function receives a pointer to the decimal value to convert
8882 (
<literal>np
</literal>) and a pointer to the double variable that
8883 should hold the result of the operation (
<literal>dblp
</literal>).
8886 On success,
0 is returned and a negative value if the conversion
8892 <varlistentry id=
"ecpg-informix-functions-dectoint">
8893 <term><function>dectoint
</function></term>
8896 Convert a variable of type decimal to an integer.
8898 int dectoint(decimal *np, int *ip);
8900 The function receives a pointer to the decimal value to convert
8901 (
<literal>np
</literal>) and a pointer to the integer variable that
8902 should hold the result of the operation (
<literal>ip
</literal>).
8905 On success,
0 is returned and a negative value if the conversion
8906 failed. If an overflow occurred,
<literal>ECPG_INFORMIX_NUM_OVERFLOW
</literal>
8910 Note that the ECPG implementation differs from the
<productname>Informix
</productname>
8911 implementation.
<productname>Informix
</productname> limits an integer to the range from -
32767 to
8912 32767, while the limits in the ECPG implementation depend on the
8913 architecture (
<literal>INT_MIN .. INT_MAX
</literal>).
8918 <varlistentry id=
"ecpg-informix-functions-dectolong">
8919 <term><function>dectolong
</function></term>
8922 Convert a variable of type decimal to a long integer.
8924 int dectolong(decimal *np, long *lngp);
8926 The function receives a pointer to the decimal value to convert
8927 (
<literal>np
</literal>) and a pointer to the long variable that
8928 should hold the result of the operation (
<literal>lngp
</literal>).
8931 On success,
0 is returned and a negative value if the conversion
8932 failed. If an overflow occurred,
<literal>ECPG_INFORMIX_NUM_OVERFLOW
</literal>
8936 Note that the ECPG implementation differs from the
<productname>Informix
</productname>
8937 implementation.
<productname>Informix
</productname> limits a long integer to the range from
8938 -
2,
147,
483,
647 to
2,
147,
483,
647, while the limits in the ECPG
8939 implementation depend on the architecture (
<literal>-LONG_MAX ..
8940 LONG_MAX
</literal>).
8945 <varlistentry id=
"ecpg-informix-functions-rdatestr">
8946 <term><function>rdatestr
</function></term>
8949 Converts a date to a C char* string.
8951 int rdatestr(date d, char *str);
8953 The function receives two arguments, the first one is the date to
8954 convert (
<literal>d
</literal>) and the second one is a pointer to the target
8955 string. The output format is always
<literal>yyyy-mm-dd
</literal>, so you need
8956 to allocate at least
11 bytes (including the zero-byte terminator) for the
8960 The function returns
0 on success and a negative value in case of
8964 Note that ECPG's implementation differs from the
<productname>Informix
</productname>
8965 implementation. In
<productname>Informix
</productname> the format can be influenced by setting
8966 environment variables. In ECPG however, you cannot change the output
8972 <varlistentry id=
"ecpg-informix-functions-rstrdate">
8973 <term><function>rstrdate
</function></term>
8976 Parse the textual representation of a date.
8978 int rstrdate(char *str, date *d);
8980 The function receives the textual representation of the date to convert
8981 (
<literal>str
</literal>) and a pointer to a variable of type date
8982 (
<literal>d
</literal>). This function does not allow you to specify a format
8983 mask. It uses the default format mask of
<productname>Informix
</productname> which is
8984 <literal>mm/dd/yyyy
</literal>. Internally, this function is implemented by
8985 means of
<function>rdefmtdate
</function>. Therefore,
<function>rstrdate
</function> is
8986 not faster and if you have the choice you should opt for
8987 <function>rdefmtdate
</function> which allows you to specify the format mask
8991 The function returns the same values as
<function>rdefmtdate
</function>.
8996 <varlistentry id=
"ecpg-informix-functions-rtoday">
8997 <term><function>rtoday
</function></term>
9000 Get the current date.
9002 void rtoday(date *d);
9004 The function receives a pointer to a date variable (
<literal>d
</literal>)
9005 that it sets to the current date.
9008 Internally this function uses the
<xref linkend=
"pgtypesdatetoday"/>
9014 <varlistentry id=
"ecpg-informix-functions-rjulmdy">
9015 <term><function>rjulmdy
</function></term>
9018 Extract the values for the day, the month and the year from a variable
9021 int rjulmdy(date d, short mdy[
3]);
9023 The function receives the date
<literal>d
</literal> and a pointer to an array
9024 of
3 short integer values
<literal>mdy
</literal>. The variable name indicates
9025 the sequential order:
<literal>mdy[
0]
</literal> will be set to contain the
9026 number of the month,
<literal>mdy[
1]
</literal> will be set to the value of the
9027 day and
<literal>mdy[
2]
</literal> will contain the year.
9030 The function always returns
0 at the moment.
9033 Internally the function uses the
<xref linkend=
"pgtypesdatejulmdy"/>
9039 <varlistentry id=
"ecpg-informix-functions-rdefmtdate">
9040 <term><function>rdefmtdate
</function></term>
9043 Use a format mask to convert a character string to a value of type
9046 int rdefmtdate(date *d, char *fmt, char *str);
9048 The function receives a pointer to the date value that should hold the
9049 result of the operation (
<literal>d
</literal>), the format mask to use for
9050 parsing the date (
<literal>fmt
</literal>) and the C char* string containing
9051 the textual representation of the date (
<literal>str
</literal>). The textual
9052 representation is expected to match the format mask. However you do not
9053 need to have a
1:
1 mapping of the string to the format mask. The
9054 function only analyzes the sequential order and looks for the literals
9055 <literal>yy
</literal> or
<literal>yyyy
</literal> that indicate the
9056 position of the year,
<literal>mm
</literal> to indicate the position of
9057 the month and
<literal>dd
</literal> to indicate the position of the
9061 The function returns the following values:
9065 0 - The function terminated successfully.
9070 <literal>ECPG_INFORMIX_ENOSHORTDATE
</literal> - The date does not contain
9071 delimiters between day, month and year. In this case the input
9072 string must be exactly
6 or
8 bytes long but isn't.
9077 <literal>ECPG_INFORMIX_ENOTDMY
</literal> - The format string did not
9078 correctly indicate the sequential order of year, month and day.
9083 <literal>ECPG_INFORMIX_BAD_DAY
</literal> - The input string does not
9084 contain a valid day.
9089 <literal>ECPG_INFORMIX_BAD_MONTH
</literal> - The input string does not
9090 contain a valid month.
9095 <literal>ECPG_INFORMIX_BAD_YEAR
</literal> - The input string does not
9096 contain a valid year.
9102 Internally this function is implemented to use the
<xref
9103 linkend=
"pgtypesdatedefmtasc"/> function. See the reference there for a
9104 table of example input.
9109 <varlistentry id=
"ecpg-informix-functions-rfmtdate">
9110 <term><function>rfmtdate
</function></term>
9113 Convert a variable of type date to its textual representation using a
9116 int rfmtdate(date d, char *fmt, char *str);
9118 The function receives the date to convert (
<literal>d
</literal>), the format
9119 mask (
<literal>fmt
</literal>) and the string that will hold the textual
9120 representation of the date (
<literal>str
</literal>).
9123 On success,
0 is returned and a negative value if an error occurred.
9126 Internally this function uses the
<xref linkend=
"pgtypesdatefmtasc"/>
9127 function, see the reference there for examples.
9132 <varlistentry id=
"ecpg-informix-functions-rmdyjul">
9133 <term><function>rmdyjul
</function></term>
9136 Create a date value from an array of
3 short integers that specify the
9137 day, the month and the year of the date.
9139 int rmdyjul(short mdy[
3], date *d);
9141 The function receives the array of the
3 short integers
9142 (
<literal>mdy
</literal>) and a pointer to a variable of type date that should
9143 hold the result of the operation.
9146 Currently the function returns always
0.
9149 Internally the function is implemented to use the function
<xref
9150 linkend=
"pgtypesdatemdyjul"/>.
9155 <varlistentry id=
"ecpg-informix-functions-rdayofweek">
9156 <term><function>rdayofweek
</function></term>
9159 Return a number representing the day of the week for a date value.
9161 int rdayofweek(date d);
9163 The function receives the date variable
<literal>d
</literal> as its only
9164 argument and returns an integer that indicates the day of the week for
9205 Internally the function is implemented to use the function
<xref
9206 linkend=
"pgtypesdatedayofweek"/>.
9211 <varlistentry id=
"ecpg-informix-functions-dtcurrent">
9212 <term><function>dtcurrent
</function></term>
9215 Retrieve the current timestamp.
9217 void dtcurrent(timestamp *ts);
9219 The function retrieves the current timestamp and saves it into the
9220 timestamp variable that
<literal>ts
</literal> points to.
9225 <varlistentry id=
"ecpg-informix-functions-dtcvasc">
9226 <term><function>dtcvasc
</function></term>
9229 Parses a timestamp from its textual representation
9230 into a timestamp variable.
9232 int dtcvasc(char *str, timestamp *ts);
9234 The function receives the string to parse (
<literal>str
</literal>) and a
9235 pointer to the timestamp variable that should hold the result of the
9236 operation (
<literal>ts
</literal>).
9239 The function returns
0 on success and a negative value in case of
9243 Internally this function uses the
<xref
9244 linkend=
"pgtypestimestampfromasc"/> function. See the reference there
9245 for a table with example inputs.
9250 <varlistentry id=
"ecpg-informix-functions-dtcvfmtasc">
9251 <term><function>dtcvfmtasc
</function></term>
9254 Parses a timestamp from its textual representation
9255 using a format mask into a timestamp variable.
9257 dtcvfmtasc(char *inbuf, char *fmtstr, timestamp *dtvalue)
9259 The function receives the string to parse (
<literal>inbuf
</literal>), the
9260 format mask to use (
<literal>fmtstr
</literal>) and a pointer to the timestamp
9261 variable that should hold the result of the operation
9262 (
<literal>dtvalue
</literal>).
9265 This function is implemented by means of the
<xref
9266 linkend=
"pgtypestimestampdefmtasc"/> function. See the documentation
9267 there for a list of format specifiers that can be used.
9270 The function returns
0 on success and a negative value in case of
9276 <varlistentry id=
"ecpg-informix-functions-dtsub">
9277 <term><function>dtsub
</function></term>
9280 Subtract one timestamp from another and return a variable of type
9283 int dtsub(timestamp *ts1, timestamp *ts2, interval *iv);
9285 The function will subtract the timestamp variable that
<literal>ts2
</literal>
9286 points to from the timestamp variable that
<literal>ts1
</literal> points to
9287 and will store the result in the interval variable that
<literal>iv
</literal>
9291 Upon success, the function returns
0 and a negative value if an
9297 <varlistentry id=
"ecpg-informix-functions-dttoasc">
9298 <term><function>dttoasc
</function></term>
9301 Convert a timestamp variable to a C char* string.
9303 int dttoasc(timestamp *ts, char *output);
9305 The function receives a pointer to the timestamp variable to convert
9306 (
<literal>ts
</literal>) and the string that should hold the result of the
9307 operation (
<literal>output
</literal>). It converts
<literal>ts
</literal> to its
9308 textual representation according to the SQL standard, which is
9309 be
<literal>YYYY-MM-DD HH:MM:SS
</literal>.
9312 Upon success, the function returns
0 and a negative value if an
9318 <varlistentry id=
"ecpg-informix-functions-dttofmtasc">
9319 <term><function>dttofmtasc
</function></term>
9322 Convert a timestamp variable to a C char* using a format mask.
9324 int dttofmtasc(timestamp *ts, char *output, int str_len, char *fmtstr);
9326 The function receives a pointer to the timestamp to convert as its
9327 first argument (
<literal>ts
</literal>), a pointer to the output buffer
9328 (
<literal>output
</literal>), the maximal length that has been allocated for
9329 the output buffer (
<literal>str_len
</literal>) and the format mask to
9330 use for the conversion (
<literal>fmtstr
</literal>).
9333 Upon success, the function returns
0 and a negative value if an
9337 Internally, this function uses the
<xref
9338 linkend=
"pgtypestimestampfmtasc"/> function. See the reference there for
9339 information on what format mask specifiers can be used.
9344 <varlistentry id=
"ecpg-informix-functions-intoasc">
9345 <term><function>intoasc
</function></term>
9348 Convert an interval variable to a C char* string.
9350 int intoasc(interval *i, char *str);
9352 The function receives a pointer to the interval variable to convert
9353 (
<literal>i
</literal>) and the string that should hold the result of the
9354 operation (
<literal>str
</literal>). It converts
<literal>i
</literal> to its
9355 textual representation according to the SQL standard, which is
9356 be
<literal>YYYY-MM-DD HH:MM:SS
</literal>.
9359 Upon success, the function returns
0 and a negative value if an
9365 <varlistentry id=
"ecpg-informix-functions-rfmtlong">
9366 <term><function>rfmtlong
</function></term>
9369 Convert a long integer value to its textual representation using a
9372 int rfmtlong(long lng_val, char *fmt, char *outbuf);
9374 The function receives the long value
<literal>lng_val
</literal>, the format
9375 mask
<literal>fmt
</literal> and a pointer to the output buffer
9376 <literal>outbuf
</literal>. It converts the long value according to the format
9377 mask to its textual representation.
9380 The format mask can be composed of the following format specifying
9385 <literal>*
</literal> (asterisk) - if this position would be blank
9386 otherwise, fill it with an asterisk.
9391 <literal>&</literal> (ampersand) - if this position would be
9392 blank otherwise, fill it with a zero.
9397 <literal>#
</literal> - turn leading zeroes into blanks.
9402 <literal><</literal> - left-justify the number in the string.
9407 <literal>,
</literal> (comma) - group numbers of four or more digits
9408 into groups of three digits separated by a comma.
9413 <literal>.
</literal> (period) - this character separates the
9414 whole-number part of the number from the fractional part.
9419 <literal>-
</literal> (minus) - the minus sign appears if the number
9420 is a negative value.
9425 <literal>+
</literal> (plus) - the plus sign appears if the number is
9431 <literal>(
</literal> - this replaces the minus sign in front of the
9432 negative number. The minus sign will not appear.
9437 <literal>)
</literal> - this character replaces the minus and is
9438 printed behind the negative value.
9443 <literal>$
</literal> - the currency symbol.
9451 <varlistentry id=
"ecpg-informix-functions-rupshift">
9452 <term><function>rupshift
</function></term>
9455 Convert a string to upper case.
9457 void rupshift(char *str);
9459 The function receives a pointer to the string and transforms every
9460 lower case character to upper case.
9465 <varlistentry id=
"ecpg-informix-functions-byleng">
9466 <term><function>byleng
</function></term>
9469 Return the number of characters in a string without counting trailing
9472 int byleng(char *str, int len);
9474 The function expects a fixed-length string as its first argument
9475 (
<literal>str
</literal>) and its length as its second argument
9476 (
<literal>len
</literal>). It returns the number of significant characters,
9477 that is the length of the string without trailing blanks.
9482 <varlistentry id=
"ecpg-informix-functions-ldchar">
9483 <term><function>ldchar
</function></term>
9486 Copy a fixed-length string into a null-terminated string.
9488 void ldchar(char *src, int len, char *dest);
9490 The function receives the fixed-length string to copy
9491 (
<literal>src
</literal>), its length (
<literal>len
</literal>) and a pointer to the
9492 destination memory (
<literal>dest
</literal>). Note that you need to reserve at
9493 least
<literal>len+
1</literal> bytes for the string that
<literal>dest
</literal>
9494 points to. The function copies at most
<literal>len
</literal> bytes to the new
9495 location (less if the source string has trailing blanks) and adds the
9501 <varlistentry id=
"ecpg-informix-functions-rgetmsg">
9502 <term><function>rgetmsg
</function></term>
9506 int rgetmsg(int msgnum, char *s, int maxsize);
9508 This function exists but is not implemented at the moment!
9513 <varlistentry id=
"ecpg-informix-functions-rtypalign">
9514 <term><function>rtypalign
</function></term>
9518 int rtypalign(int offset, int type);
9520 This function exists but is not implemented at the moment!
9525 <varlistentry id=
"ecpg-informix-functions-rtypmsize">
9526 <term><function>rtypmsize
</function></term>
9530 int rtypmsize(int type, int len);
9532 This function exists but is not implemented at the moment!
9537 <varlistentry id=
"ecpg-informix-functions-rtypwidth">
9538 <term><function>rtypwidth
</function></term>
9542 int rtypwidth(int sqltype, int sqllen);
9544 This function exists but is not implemented at the moment!
9549 <varlistentry id=
"rsetnull">
9550 <term><function>rsetnull
</function></term>
9553 Set a variable to NULL.
9555 int rsetnull(int t, char *ptr);
9557 The function receives an integer that indicates the type of the
9558 variable and a pointer to the variable itself that is cast to a C
9562 The following types exist:
9566 <literal>CCHARTYPE
</literal> - For a variable of type
<type>char
</type> or
<type>char*
</type>
9571 <literal>CSHORTTYPE
</literal> - For a variable of type
<type>short int
</type>
9576 <literal>CINTTYPE
</literal> - For a variable of type
<type>int
</type>
9581 <literal>CBOOLTYPE
</literal> - For a variable of type
<type>boolean
</type>
9586 <literal>CFLOATTYPE
</literal> - For a variable of type
<type>float
</type>
9591 <literal>CLONGTYPE
</literal> - For a variable of type
<type>long
</type>
9596 <literal>CDOUBLETYPE
</literal> - For a variable of type
<type>double
</type>
9601 <literal>CDECIMALTYPE
</literal> - For a variable of type
<type>decimal
</type>
9606 <literal>CDATETYPE
</literal> - For a variable of type
<type>date
</type>
9611 <literal>CDTIMETYPE
</literal> - For a variable of type
<type>timestamp
</type>
9618 Here is an example of a call to this function:
9619 <programlisting><![CDATA[
9624 rsetnull(CCHARTYPE, (char *) c);
9625 rsetnull(CSHORTTYPE, (char *) &s);
9626 rsetnull(CINTTYPE, (char *) &i);
9633 <varlistentry id=
"ecpg-informix-functions-risnull">
9634 <term><function>risnull
</function></term>
9637 Test if a variable is NULL.
9639 int risnull(int t, char *ptr);
9641 The function receives the type of the variable to test (
<literal>t
</literal>)
9642 as well a pointer to this variable (
<literal>ptr
</literal>). Note that the
9643 latter needs to be cast to a char*. See the function
<xref
9644 linkend=
"rsetnull"/> for a list of possible variable types.
9647 Here is an example of how to use this function:
9648 <programlisting><![CDATA[
9653 risnull(CCHARTYPE, (char *) c);
9654 risnull(CSHORTTYPE, (char *) &s);
9655 risnull(CINTTYPE, (char *) &i);
9665 <sect2 id=
"ecpg-informix-constants">
9666 <title>Additional Constants
</title>
9668 Note that all constants here describe errors and all of them are defined
9669 to represent negative values. In the descriptions of the different
9670 constants you can also find the value that the constants represent in the
9671 current implementation. However you should not rely on this number. You can
9672 however rely on the fact all of them are defined to represent negative
9675 <varlistentry id=
"ecpg-informix-constants-ecpg-informix-num-overflow">
9676 <term><literal>ECPG_INFORMIX_NUM_OVERFLOW
</literal></term>
9679 Functions return this value if an overflow occurred in a
9680 calculation. Internally it is defined as -
1200 (the
<productname>Informix
</productname>
9686 <varlistentry id=
"ecpg-informix-constants-ecpg-informix-num-underflow">
9687 <term><literal>ECPG_INFORMIX_NUM_UNDERFLOW
</literal></term>
9690 Functions return this value if an underflow occurred in a calculation.
9691 Internally it is defined as -
1201 (the
<productname>Informix
</productname> definition).
9696 <varlistentry id=
"ecpg-informix-constants-ecpg-informix-divide-zero">
9697 <term><literal>ECPG_INFORMIX_DIVIDE_ZERO
</literal></term>
9700 Functions return this value if an attempt to divide by zero is
9701 observed. Internally it is defined as -
1202 (the
<productname>Informix
</productname> definition).
9706 <varlistentry id=
"ecpg-informix-constants-ecpg-informix-bad-year">
9707 <term><literal>ECPG_INFORMIX_BAD_YEAR
</literal></term>
9710 Functions return this value if a bad value for a year was found while
9711 parsing a date. Internally it is defined as -
1204 (the
<productname>Informix
</productname>
9717 <varlistentry id=
"ecpg-informix-constants-ecpg-informix-bad-month">
9718 <term><literal>ECPG_INFORMIX_BAD_MONTH
</literal></term>
9721 Functions return this value if a bad value for a month was found while
9722 parsing a date. Internally it is defined as -
1205 (the
<productname>Informix
</productname>
9728 <varlistentry id=
"ecpg-informix-constants-ecpg-informix-bad-day">
9729 <term><literal>ECPG_INFORMIX_BAD_DAY
</literal></term>
9732 Functions return this value if a bad value for a day was found while
9733 parsing a date. Internally it is defined as -
1206 (the
<productname>Informix
</productname>
9739 <varlistentry id=
"ecpg-informix-constants-ecpg-informix-enoshortdate">
9740 <term><literal>ECPG_INFORMIX_ENOSHORTDATE
</literal></term>
9743 Functions return this value if a parsing routine needs a short date
9744 representation but did not get the date string in the right length.
9745 Internally it is defined as -
1209 (the
<productname>Informix
</productname> definition).
9750 <varlistentry id=
"ecpg-informix-constants-ecpg-informix-date-convert">
9751 <term><literal>ECPG_INFORMIX_DATE_CONVERT
</literal></term>
9754 Functions return this value if an error occurred during date
9755 formatting. Internally it is defined as -
1210 (the
9756 <productname>Informix
</productname> definition).
9761 <varlistentry id=
"ecpg-informix-constants-ecpg-informix-out-of-memory">
9762 <term><literal>ECPG_INFORMIX_OUT_OF_MEMORY
</literal></term>
9765 Functions return this value if memory was exhausted during
9766 their operation. Internally it is defined as -
1211 (the
9767 <productname>Informix
</productname> definition).
9772 <varlistentry id=
"ecpg-informix-constants-ecpg-informix-enotdmy">
9773 <term><literal>ECPG_INFORMIX_ENOTDMY
</literal></term>
9776 Functions return this value if a parsing routine was supposed to get a
9777 format mask (like
<literal>mmddyy
</literal>) but not all fields were listed
9778 correctly. Internally it is defined as -
1212 (the
<productname>Informix
</productname> definition).
9783 <varlistentry id=
"ecpg-informix-constants-ecpg-informix-bad-numeric">
9784 <term><literal>ECPG_INFORMIX_BAD_NUMERIC
</literal></term>
9787 Functions return this value either if a parsing routine cannot parse
9788 the textual representation for a numeric value because it contains
9789 errors or if a routine cannot complete a calculation involving numeric
9790 variables because at least one of the numeric variables is invalid.
9791 Internally it is defined as -
1213 (the
<productname>Informix
</productname> definition).
9796 <varlistentry id=
"ecpg-informix-constants-ecpg-informix-bad-exponent">
9797 <term><literal>ECPG_INFORMIX_BAD_EXPONENT
</literal></term>
9800 Functions return this value if a parsing routine cannot parse
9801 an exponent. Internally it is defined as -
1216 (the
9802 <productname>Informix
</productname> definition).
9807 <varlistentry id=
"ecpg-informix-constants-ecpg-informix-bad-date">
9808 <term><literal>ECPG_INFORMIX_BAD_DATE
</literal></term>
9811 Functions return this value if a parsing routine cannot parse
9812 a date. Internally it is defined as -
1218 (the
9813 <productname>Informix
</productname> definition).
9818 <varlistentry id=
"ecpg-informix-constants-ecpg-informix-extra-chars">
9819 <term><literal>ECPG_INFORMIX_EXTRA_CHARS
</literal></term>
9822 Functions return this value if a parsing routine is passed extra
9823 characters it cannot parse. Internally it is defined as -
1264 (the
9824 <productname>Informix
</productname> definition).
9833 <sect1 id=
"ecpg-oracle-compat">
9834 <title><productname>Oracle
</productname> Compatibility Mode
</title>
9836 <command>ecpg
</command> can be run in a so-called
<firstterm>Oracle
9837 compatibility mode
</firstterm>. If this mode is active, it tries to
9838 behave as if it were Oracle
<productname>Pro*C
</productname>.
9842 Specifically, this mode changes
<command>ecpg
</command> in three ways:
9847 Pad character arrays receiving character string types with
9848 trailing spaces to the specified length
9854 Zero byte terminate these character arrays, and set the indicator
9855 variable if truncation occurs
9861 Set the null indicator to
<literal>-
1</literal> when character
9862 arrays receive empty character string types
9869 <sect1 id=
"ecpg-develop">
9870 <title>Internals
</title>
9873 This section explains how
<application>ECPG
</application> works
9874 internally. This information can occasionally be useful to help
9875 users understand how to use
<application>ECPG
</application>.
9879 The first four lines written by
<command>ecpg
</command> to the
9880 output are fixed lines. Two are comments and two are include
9881 lines necessary to interface to the library. Then the
9882 preprocessor reads through the file and writes output. Normally
9883 it just echoes everything to the output.
9887 When it sees an
<command>EXEC SQL
</command> statement, it
9888 intervenes and changes it. The command starts with
<command>EXEC
9889 SQL
</command> and ends with
<command>;
</command>. Everything in
9890 between is treated as an
<acronym>SQL
</acronym> statement and
9891 parsed for variable substitution.
9895 Variable substitution occurs when a symbol starts with a colon
9896 (
<literal>:
</literal>). The variable with that name is looked up
9897 among the variables that were previously declared within a
9898 <literal>EXEC SQL DECLARE
</literal> section.
9902 The most important function in the library is
9903 <function>ECPGdo
</function>, which takes care of executing most
9904 commands. It takes a variable number of arguments. This can easily
9905 add up to
50 or so arguments, and we hope this will not be a
9906 problem on any platform.
9913 <varlistentry id=
"ecpg-develop-line-number">
9914 <term>A line number
</term>
9917 This is the line number of the original line; used in error
9923 <varlistentry id=
"ecpg-develop-string">
9924 <term>A string
</term>
9927 This is the
<acronym>SQL
</acronym> command that is to be issued.
9928 It is modified by the input variables, i.e., the variables that
9929 where not known at compile time but are to be entered in the
9930 command. Where the variables should go the string contains
9931 <literal>?
</literal>.
9936 <varlistentry id=
"ecpg-develop-input-variables">
9937 <term>Input variables
</term>
9940 Every input variable causes ten arguments to be created. (See below.)
9945 <varlistentry id=
"ecpg-develop-ecpgt-eoit">
9946 <term><parameter>ECPGt_EOIT
</parameter></term>
9949 An
<type>enum
</type> telling that there are no more input
9955 <varlistentry id=
"ecpg-develop-output-variables">
9956 <term>Output variables
</term>
9959 Every output variable causes ten arguments to be created.
9960 (See below.) These variables are filled by the function.
9965 <varlistentry id=
"ecpg-develop-ecpgt-eort">
9966 <term><parameter>ECPGt_EORT
</parameter></term>
9969 An
<type>enum
</type> telling that there are no more variables.
9977 For every variable that is part of the
<acronym>SQL
</acronym>
9978 command, the function gets ten arguments:
9983 The type as a special symbol.
9989 A pointer to the value or a pointer to the pointer.
9995 The size of the variable if it is a
<type>char
</type> or
<type>varchar
</type>.
10001 The number of elements in the array (for array fetches).
10007 The offset to the next element in the array (for array fetches).
10013 The type of the indicator variable as a special symbol.
10019 A pointer to the indicator variable.
10031 The number of elements in the indicator array (for array fetches).
10037 The offset to the next element in the indicator array (for
10045 Note that not all SQL commands are treated in this way. For
10046 instance, an open cursor statement like:
10048 EXEC SQL OPEN
<replaceable>cursor
</replaceable>;
10050 is not copied to the output. Instead, the cursor's
10051 <command>DECLARE
</command> command is used at the position of the
<command>OPEN
</command> command
10052 because it indeed opens the cursor.
10056 Here is a complete example describing the output of the
10057 preprocessor of a file
<filename>foo.pgc
</filename> (details might
10058 change with each particular version of the preprocessor):
10060 EXEC SQL BEGIN DECLARE SECTION;
10063 EXEC SQL END DECLARE SECTION;
10065 EXEC SQL SELECT res INTO :result FROM mytable WHERE index = :index;
10067 is translated into:
10068 <programlisting><![CDATA[
10069 /* Processed by ecpg (
2.6.0) */
10070 /* These two include files are added by the preprocessor */
10071 #include
<ecpgtype.h
>;
10072 #include
<ecpglib.h
>;
10074 /* exec sql begin declare section */
10080 /* exec sql end declare section */
10082 ECPGdo(__LINE__, NULL,
"SELECT res FROM mytable WHERE index = ? ",
10083 ECPGt_int,&(index),
1L,
1L,sizeof(int),
10084 ECPGt_NO_INDICATOR, NULL ,
0L,
0L,
0L, ECPGt_EOIT,
10085 ECPGt_int,&(result),
1L,
1L,sizeof(int),
10086 ECPGt_NO_INDICATOR, NULL ,
0L,
0L,
0L, ECPGt_EORT);
10087 #line
147 "foo.pgc"
10090 (The indentation here is added for readability and not
10091 something the preprocessor does.)