8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-22 18:03:03 +01:00
firebird-mirror/examples
2024-09-05 16:57:23 +03:00
..
api Be sure to attach via localhost so that the example actually works 2020-08-17 17:02:09 +02:00
build_unix Rework messages processing, simplifying the build and avoiding store generated files in git. (#6958) 2021-09-15 08:37:17 -03:00
build_win32 Make Windows build scripts reuse previous configuration. 2022-08-16 07:24:59 -03:00
dbcrypt Misc 2024-01-11 13:41:17 +03:00
dyn Clean the examples. 2005-01-27 03:10:30 +00:00
empbuild Rework messages processing, simplifying the build and avoiding store generated files in git. (#6958) 2021-09-15 08:37:17 -03:00
extauth Replace throw() by noexcept. 2023-09-18 20:27:13 -03:00
include FB_ALIGN is always defined in src/include/types_pub.h ((n+b-1)&~(b-1)) 2014-05-07 15:14:41 +00:00
interfaces Postfix for #8197: Add generated files for OO API for C language to distribution; Use macros instead functions, removed static library 2024-09-05 16:57:23 +03:00
object_pascal Fixed #7113: Wrong path in object pascal readme.md 2022-01-27 13:25:14 +03:00
package Changed package routines syntax to not need (nor accept) a semi-colon after "END". 2013-05-13 01:49:34 +00:00
replication Fix MacOS UDR and Legacy_UserManager plugins not working due to not exported entry point. (#7088) 2021-12-26 11:35:16 -03:00
stat Clean the examples. 2005-01-27 03:10:30 +00:00
udf Use right allocation method 2009-11-01 16:40:08 +00:00
udr Improve performance of external (UDR) functions (#7989) 2024-02-28 18:43:16 -03:00
CMakeLists.txt Rework messages processing, simplifying the build and avoiding store generated files in git. (#6958) 2021-09-15 08:37:17 -03:00
functions.c Further AMD64 fixes. Given this fixes you may start playing with databases using isql_static. 2004-01-21 07:18:30 +00:00
readme Update allowed C++ version (#7654) 2023-09-18 07:14:06 -03:00

/*
 * The contents of this file are subject to the Interbase Public
 * License Version 1.0 (the "License"); you may not use this file
 * except in compliance with the License. You may obtain a copy
 * of the License at http://www.Inprise.com/IPL.html
 *
 * Software distributed under the License is distributed on an
 * "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express
 * or implied. See the License for the specific language governing
 * rights and limitations under the License.
 *
 * The Original Code was created by Inprise Corporation
 * and its predecessors. Portions created by Inprise Corporation are
 * Copyright (C) Inprise Corporation.
 *
 * All Rights Reserved.
 * Contributor(s): ______________________________________.
 */
The following example programs demonstrate a number of useful features of
the Firebird programming interface.

Note that the following environment variables need to be set before running
the examples:

ISC_USER     - A valid username on the server.
ISC_PASSWORD - The password for the above user.
ISC_DATABASE - The path to the employee.gdb example database, including
	       server name.  For example, to connect to the NT server
	       named "NTserver" via NetBEUI:
		ISC_DATABASE=\\NTserver\c:\firebird\examples

	       This assumes that Firebird was installed to the
	       firebird directory on the c: drive.

In addition, a guest account should be created with the username "guest"
and password "guest" before running api15 and winevent.

Embedded Static SQL

Program     Description
---------   ------------------------------------------------------------------
stat1.e     Illustrates a simple update to an existing table, commit, rollback.

stat2.e     Illustrates singleton select.

stat3.e     Illustrates a simple cursor -- declare/open/close/fetch.

stat4.e     Show 'declare table' and 'create table'.

stat5.e     Demonstrate 'update where current of'.

stat6.e     Select an array.

stat7.e     Illustrate blob cursor for select.

stat8.e     Illustrate blob cursor for insert.

stat9.e     Execute and select from a stored procedure.

stat10.e    Demonstrate 'set database', 'connect' and 'set transaction'.

stat11.e    Demonstrate 'set transaction' with various isolation options.

stat12.e    Event wait and signaling.
stat12t.e

WHENEVER SQLERROR and BASED_ON clause are illustrated by many programs.



Embedded Dynamic SQL

Program     Description
---------   ------------------------------------------------------------------
dyn1.e      Execute 'create database' statement as a static string.

dyn2.e      'Execute immediate', and 'prepare' and 'execute'.

dyn3.e      Dynamic cursor for select with output SQLDA allocated.

dyn4.e      Execute an update query with parameter markers and input SQLDA.

dyn5.e      Demonstrate dynamic reallocation of SQLDA and 'describe' statement.

dynfull.e   A full_dsql program (process unknown statements).

VARY struct is used by dyn3.e, dynfull.e.



API Interface

Program     Description
---------   ------------------------------------------------------------------
api1.c      Execute 'create dabatabase' statement as a static string.
            Demonstrates zero database handle.

api2.c      'Execute immediate', and 'prepare' and 'execute'.

api3.c      Dynamic cursor for select with output SQLDA allocated.

api4.c      Execute an update query with parameter markers and input SQLDA.

api5.c      Demonstrate dynamic reallocation of SQLDA and 'describe' statement.

apifull.c   A full_dsql program (process unknown statements).
	    Demonstrates stmt_info calls and numeric scale.

api6.c      Assemble an update current of statement, based on a dynamic
            cursor name.  Free a statement handle and re-use it as the cursor.

api7.c      Demonstrate blob_open, get_segment.

api8.c      Demonstrate create_blob, put_segment.

api9.c      Demonstrate blob_open2 (using blob filter).
api9f.c     Filter for api9.c.

api10.c     Update an array using get_slice/put_slice.

api11.c     Execute and select from a stored procedure.

api12.c     A program with several active transactions.

api13.c     A multi-database transaction with 2-phase commit.

api14.e     Combine the three programming styles in one program.

api15.c	    Construct a database parameter buffer.  db_info calls.

api16.c	    Demonstrate asynchronous event trapping.            

winevent.c  Demonstrate asynchronous event trapping
            (Replacement for api16.c on Windows Client)

api16t.c    Identical to stat12t, this triggers the event for api16.

VARY struct is used by api3.c, apifull.c, and api14.e.

SQLCODE extraction from status is covered by several programs.

Zero transaction handle is covered in several programs, ex. api14.e.



Object-oriented API (interfaces)

Program               Description
---------             --------------------------------------------------------
01.create.cpp /       A sample of creating new database and new table in it.
01.create.pas         Has pascal (delphi) implementation.

02.update.cpp         UPDATE statement with parameters.

03.select.cpp         SELECT statement without input parameters.

04.print_table.cpp    Open cursor from attachment and access blob data.

05.user_metadata.cpp  Cursor with user-implemented interface of message format.

06.fb_message.cpp     Use of static messages and decfloat values.

07.blob.cpp           Loading data into blob and reading it.

08.events.cpp         Working with events.

09.service.cpp        Using services: prints server version and db statistics.

10.backup.cpp         Using services: backup database.

11.batch.cpp          Working with batch interface.

12.batch_isc.cpp      Working with batch interface from ISC API.



dbcrypt - a sample of XOR database encryption (do not use in production!!!)

extauth - authentication for cross-server connections based on having same secret key on all servers

replication - a sample or replication. Doesn't do anything useful just write log of calls from the engine.