C:\xampp\php\pear\adodb\drivers\adodb-sapdb.inc.php


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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
<?php
/* 
V5.18 3 Sep 2012  (c) 2000-2012 John Lim (jlim#natsoft.com). All rights reserved.
  Released under both BSD license and Lesser GPL library license. 
  Whenever there is any discrepancy between the two licenses, 
  the BSD license will take precedence. 
Set tabs to 4 for best viewing.
  
  Latest version is available at http://adodb.sourceforge.net
  
  SAPDB data driver. Requires ODBC.

*/

// security - hide paths
if (!defined('ADODB_DIR')) die();

if (!
defined('_ADODB_ODBC_LAYER')) {
    include(
ADODB_DIR."/drivers/adodb-odbc.inc.php");
}
if (!
defined('ADODB_SAPDB')){
define('ADODB_SAPDB',1);

class 
ADODB_SAPDB extends ADODB_odbc {
    var 
$databaseType "sapdb";    
    var 
$concat_operator '||';
    var 
$sysDate 'DATE';
    var 
$sysTimeStamp 'TIMESTAMP';
    var 
$fmtDate "'Y-m-d'";    /// used by DBDate() as the default date format used by the database
    
var $fmtTimeStamp "'Y-m-d H:i:s'"/// used by DBTimeStamp as the default timestamp fmt.
    
var $hasInsertId true;
    var 
$_bindInputArray true;
    
    function 
ADODB_SAPDB()
    {
        
//if (strncmp(PHP_OS,'WIN',3) === 0) $this->curmode = SQL_CUR_USE_ODBC;
        
$this->ADODB_odbc();
    }
    
    function 
ServerInfo()
    {
        
$info ADODB_odbc::ServerInfo();
        if (!
$info['version'] && preg_match('/([0-9.]+)/',$info['description'],$matches)) {
            
$info['version'] = $matches[1];
        }
        return 
$info;
    }

    function 
MetaPrimaryKeys($table)
    {
        
$table $this->Quote(strtoupper($table));

        return 
$this->GetCol("SELECT columnname FROM COLUMNS WHERE tablename=$table AND mode='KEY' ORDER BY pos");
    }
        
     function 
MetaIndexes ($table$primary FALSE$owner false)
    {
        
$table $this->Quote(strtoupper($table));

        
$sql "SELECT INDEXNAME,TYPE,COLUMNNAME FROM INDEXCOLUMNS ".
            
" WHERE TABLENAME=$table".
            
" ORDER BY INDEXNAME,COLUMNNO";

        global 
$ADODB_FETCH_MODE;
        
$save $ADODB_FETCH_MODE;
        
$ADODB_FETCH_MODE ADODB_FETCH_NUM;
        if (
$this->fetchMode !== FALSE) {
            
$savem $this->SetFetchMode(FALSE);
        }
        
        
$rs $this->Execute($sql);
        if (isset(
$savem)) {
            
$this->SetFetchMode($savem);
        }
        
$ADODB_FETCH_MODE $save;

        if (!
is_object($rs)) {
            return 
FALSE;
        }

        
$indexes = array();
        while (
$row $rs->FetchRow()) {
            
$indexes[$row[0]]['unique'] = $row[1] == 'UNIQUE';
            
$indexes[$row[0]]['columns'][] = $row[2];
        }
        if (
$primary) {
            
$indexes['SYSPRIMARYKEYINDEX'] = array(
                    
'unique' => True,    // by definition
                    
'columns' => $this->GetCol("SELECT columnname FROM COLUMNS WHERE tablename=$table AND mode='KEY' ORDER BY pos"),
                );
        }
        return 
$indexes;
    }
    
     function 
MetaColumns ($table)
    {
        global 
$ADODB_FETCH_MODE;
        
$save $ADODB_FETCH_MODE;
        
$ADODB_FETCH_MODE ADODB_FETCH_NUM;
        if (
$this->fetchMode !== FALSE) {
            
$savem $this->SetFetchMode(FALSE);
        }
        
$table $this->Quote(strtoupper($table));
        
        
$retarr = array();
        foreach(
$this->GetAll("SELECT COLUMNNAME,DATATYPE,LEN,DEC,NULLABLE,MODE,\"DEFAULT\",CASE WHEN \"DEFAULT\" IS NULL THEN 0 ELSE 1 END AS HAS_DEFAULT FROM COLUMNS WHERE tablename=$table ORDER BY pos") as $column)
        {
            
$fld = new ADOFieldObject();
            
$fld->name $column[0];
            
$fld->type $column[1];
            
$fld->max_length $fld->type == 'LONG' 2147483647 $column[2];
            
$fld->scale $column[3];
            
$fld->not_null $column[4] == 'NO';
            
$fld->primary_key $column[5] == 'KEY';
            if (
$fld->has_default $column[7]) {
                if (
$fld->primary_key && $column[6] == 'DEFAULT SERIAL (1)') {
                    
$fld->auto_increment true;
                    
$fld->has_default false;
                } else {
                    
$fld->default_value $column[6];
                    switch(
$fld->type) {
                        case 
'VARCHAR':
                        case 
'CHARACTER':
                        case 
'LONG':
                            
$fld->default_value $column[6];
                            break;
                        default:
                            
$fld->default_value trim($column[6]);
                            break;
                    }
                }
            }
            
$retarr[$fld->name] = $fld;    
        }
        if (isset(
$savem)) {
            
$this->SetFetchMode($savem);
        }
        
$ADODB_FETCH_MODE $save;

        return 
$retarr;
    }
    
    function 
MetaColumnNames($table)
    {
        
$table $this->Quote(strtoupper($table));

        return 
$this->GetCol("SELECT columnname FROM COLUMNS WHERE tablename=$table ORDER BY pos");
    }
    
    
// unlike it seems, this depends on the db-session and works in a multiuser environment
    
function _insertid($table,$column)
    {
        return empty(
$table) ? False $this->GetOne("SELECT $table.CURRVAL FROM DUAL");
    }

    
/*
        SelectLimit implementation problems:
    
         The following will return random 10 rows as order by performed after "WHERE rowno<10"
         which is not ideal...
        
              select * from table where rowno < 10 order by 1
      
          This means that we have to use the adoconnection base class SelectLimit when
          there is an "order by".
        
        See http://listserv.sap.com/pipermail/sapdb.general/2002-January/010405.html
     */
    
};
 

class  
ADORecordSet_sapdb extends ADORecordSet_odbc {    
    
    var 
$databaseType "sapdb";        
    
    function 
ADORecordSet_sapdb($id,$mode=false)
    {
        
$this->ADORecordSet_odbc($id,$mode);
    }
}

//define
?>
x

Windows NT KPTV 6.2 build 9200 (Windows Server 2012 Datacenter Edition) i586