db2_connect

(PECL ibm_db2 >= 1.0.0)
Returns a connection to a database
resource db2_connect ( string $database, string $username, string $password [, array $options ] )

Creates a new connection to an IBM DB2 Universal Database, IBM Cloudscape, or Apache Derby database.

Parameters:
database

For a cataloged connection to a database, database represents the database alias in the DB2 client catalog.

For an uncataloged connection to a database, database represents a complete connection string in the following format:

DATABASE=database;HOSTNAME=hostname;PORT=port;PROTOCOL=TCPIP;UID=username;PWD=password;
username

The username with which you are connecting to the database.

For uncataloged connections, you must pass a NULL value or empty string.

password

The password with which you are connecting to the database.

For uncataloged connections, you must pass a NULL value or empty string.

options

An associative array of connection options that affect the behavior of the connection, where valid array keys include:

Returns:

Returns a connection handle resource if the connection attempt is successful. If the connection attempt fails, db2_connect() returns FALSE.

Examples:
Creating a cataloged connection

Cataloged connections require you to have previously cataloged the target database through the DB2 Command Line Processor (CLP) or DB2 Configuration Assistant.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<?php
$database 'SAMPLE';
$user 'db2inst1';
$password 'ibmdb2';
 
$conn = db2_connect($database$user$password);
 
if ($conn) {
    echo "Connection succeeded.";
    db2_close($conn);
}
else {
    echo "Connection failed.";
}
?>

The above example will output:

Connection succeeded.
Creating an uncataloged connection

An uncataloged connection enables you to dynamically connect to a database.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<?php
$database 'SAMPLE';
$user 'db2inst1';
$password 'ibmdb2';
$hostname 'localhost';
$port = 50000;
 
$conn_string "DRIVER={IBM DB2 ODBC DRIVER};DATABASE=$database;" .
  "HOSTNAME=$hostname;PORT=$port;PROTOCOL=TCPIP;UID=$user;PWD=$password;";
$conn = db2_connect($conn_string'''');
 
if ($conn) {
    echo "Connection succeeded.";
    db2_close($conn);
}
else {
    echo "Connection failed.";
}
?>

The above example will output:

Connection succeeded.
Creating a connection with autocommit off by default

Passing an array of options to db2_connect() enables you to modify the default behavior of the connection handle.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<?php
$database 'SAMPLE';
$user 'db2inst1';
$password 'ibmdb2';
$options array('autocommit' => DB2_AUTOCOMMIT_OFF);
 
$conn = db2_connect($database$user$password$options);
 
if ($conn) {
    echo "Connection succeeded.\n";
    if (db2_autocommit($conn)) {
         echo "Autocommit is on.\n";
    }
    else {
         echo "Autocommit is off.\n";
    }
    db2_close($conn);
}
else {
    echo "Connection failed.";
}
?>

The above example will output:

Connection succeeded.
Autocommit is off.
i5/OS best performance

To achieve best performance for your i5/OS ibm_db2 1.5.1 PHP application use the default host, userid, and password for your db2_connect().

1
2
3
4
5
6
7
8
9
10
<?php
  $library "ADC";
  $i5 = db2_connect(""""""array("i5_lib"=>"qsys2"));
  $result = db2_exec($i5
       "select * from systables where table_schema = '$library'");
  while ($row = db2_fetch_both($result)) {               
     echo $row['TABLE_NAME']."</br>";                     
  }                                                      
  db2_close($i5);
?>

The above example will output:

ANIMALS
NAMES
PICTURES
Using trusted context

The following example shows how to enable trusted context, switch users, and get the current user ID.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
<?php
 
$database "SAMPLE";
$hostname "localhost";
$port = 50000;
$authID "db2inst1";
$auth_pass "ibmdb2";
 
$tc_user "tcuser";
$tc_pass "tcpassword";
 
$dsn = "DATABASE=$database;HOSTNAME=$hostname;PORT=$port;
  PROTOCOL=TCPIP;UID=$authID;PWD=$auth_pass;";
$options array ("trustedcontext" => DB2_TRUSTED_CONTEXT_ENABLE);
 
$tc_conn = db2_connect($dsn""""$options);
if($tc_conn) {
    echo "Explicit trusted connection succeeded.\n";
 
    if(db2_get_option($tc_conn"trustedcontext")) {
        $userBefore = db2_get_option($tc_conn"trusted_user");
         
        //Do some work as user 1.
 
        //Switching to trusted user.
        $parameters array("trusted_user" => $tc_user
          "trusted_password" => $tcuser_pass);
        $res = db2_set_option ($tc_conn$parameters, 1);
 
        $userAfter = db2_get_option($tc_conn"trusted_user");
        //Do more work as trusted user.
 
        if($userBefore != $userAfter) {
            echo "User has been switched." "\n";    
        }
    }
 
    db2_close($tc_conn);
}
else {
    echo "Explicit trusted connection failed.\n";
}
?>

The above example will output:

Explicit trusted connection succeeded.
User has been switched.
See also:

db2_close() -

db2_pconnect() -

doc_php
2025-01-10 15:47:30
Comments
Leave a Comment

Please login to continue.