Db/Adapter/Sqlsrv.php
Zend Framework
LICENSE
This source file is subject to the new BSD license that is bundled
with this package in the file LICENSE.txt.
It is also available through the world-wide-web at this URL:
http://framework.zend.com/license/new-bsd
If you did not receive a copy of the license and are unable to
obtain it through the world-wide-web, please send an email
to license@zend.com so we can send you a copy immediately.
- Category
- Zend
         
    
- Copyright
- Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)
         
    
- License
- New BSD License
         
    
- Package
- Zend_Db
         
    
- Subpackage
- Adapter
         
    
- Version
- $Id$
         
    
\Zend_Db_Adapter_Sqlsrv
Package: Zend_Db\AdapterClass for connecting to SQL databases and performing common operations.
- Parent(s)
- \Zend_Db_Adapter_Abstract
- Category
- Zend
         
    
- Copyright
- Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)
         
    
- License
- New BSD License
         
    
Properties



 array $_config = array('dbname' => null, 'username' => null, 'password' => null)
array $_config = array('dbname' => null, 'username' => null, 'password' => null)User-provided configuration.
Basic keys are:
username => (string) Connect to the database as this username.
password => (string) Password associated with the username.
dbname   => The name of the local SQL Server instance
Default valuearray('dbname' => null, 'username' => null, 'password' => null)Details- Type
- array



 string $_defaultStmtClass = 'Zend_Db_Statement_Sqlsrv'
string $_defaultStmtClass = 'Zend_Db_Statement_Sqlsrv'Default class name for a DB statement.
Default value'Zend_Db_Statement_Sqlsrv'Details- Type
- string
 


 string $_lastInsertSQL = 'SELECT SCOPE_IDENTITY() as Current_Identity'
string $_lastInsertSQL = 'SELECT SCOPE_IDENTITY() as Current_Identity'Query used to fetch last insert id
Default value'SELECT SCOPE_IDENTITY() as Current_Identity'Details- Type
- string
 


 array $_numericDataTypes = array(\Zend_Db::INT_TYPE => \Zend_Db::INT_TYPE, \Zend_Db::BIGINT_TYPE => \Zend_Db::BIGINT_TYPE, \Zend_Db::FLOAT_TYPE => \Zend_Db::FLOAT_TYPE, 'INT' => \Zend_Db::INT_TYPE, 'SMALLINT' => \Zend_Db::INT_TYPE, 'TINYINT' => \Zend_Db::INT_TYPE, 'BIGINT' => \Zend_Db::BIGINT_TYPE, 'DECIMAL' => \Zend_Db::FLOAT_TYPE, 'FLOAT' => \Zend_Db::FLOAT_TYPE, 'MONEY' => \Zend_Db::FLOAT_TYPE, 'NUMERIC' => \Zend_Db::FLOAT_TYPE, 'REAL' => \Zend_Db::FLOAT_TYPE, 'SMALLMONEY' => \Zend_Db::FLOAT_TYPE)
array $_numericDataTypes = array(\Zend_Db::INT_TYPE => \Zend_Db::INT_TYPE, \Zend_Db::BIGINT_TYPE => \Zend_Db::BIGINT_TYPE, \Zend_Db::FLOAT_TYPE => \Zend_Db::FLOAT_TYPE, 'INT' => \Zend_Db::INT_TYPE, 'SMALLINT' => \Zend_Db::INT_TYPE, 'TINYINT' => \Zend_Db::INT_TYPE, 'BIGINT' => \Zend_Db::BIGINT_TYPE, 'DECIMAL' => \Zend_Db::FLOAT_TYPE, 'FLOAT' => \Zend_Db::FLOAT_TYPE, 'MONEY' => \Zend_Db::FLOAT_TYPE, 'NUMERIC' => \Zend_Db::FLOAT_TYPE, 'REAL' => \Zend_Db::FLOAT_TYPE, 'SMALLMONEY' => \Zend_Db::FLOAT_TYPE)Keys are UPPERCASE SQL datatypes or the constants
Zend_Db::INT_TYPE, Zend_Db::BIGINT_TYPE, or Zend_Db::FLOAT_TYPE.
Values are:
0 = 32-bit integer
1 = 64-bit integer
2 = float or decimal
Default valuearray(\Zend_Db::INT_TYPE => \Zend_Db::INT_TYPE, \Zend_Db::BIGINT_TYPE => \Zend_Db::BIGINT_TYPE, \Zend_Db::FLOAT_TYPE => \Zend_Db::FLOAT_TYPE, 'INT' => \Zend_Db::INT_TYPE, 'SMALLINT' => \Zend_Db::INT_TYPE, 'TINYINT' => \Zend_Db::INT_TYPE, 'BIGINT' => \Zend_Db::BIGINT_TYPE, 'DECIMAL' => \Zend_Db::FLOAT_TYPE, 'FLOAT' => \Zend_Db::FLOAT_TYPE, 'MONEY' => \Zend_Db::FLOAT_TYPE, 'NUMERIC' => \Zend_Db::FLOAT_TYPE, 'REAL' => \Zend_Db::FLOAT_TYPE, 'SMALLMONEY' => \Zend_Db::FLOAT_TYPE)Details- Type
- array
Methods



 _checkRequiredOptions(array $config) : void
_checkRequiredOptions(array $config) : voidCheck for config options that are mandatory.
Throw exceptions if any are missing.
Parameters| Name | Type | Description | 
|---|
| $config | array |  | 
|---|
Throws


 _quote(string $value) : string
_quote(string $value) : stringParameters| Name | Type | Description | 
|---|
| $value | string | Raw string | 
|---|
Returns| Type | Description | 
|---|
| string | Quoted string | 
 


 describeTable(string $tableName, string $schemaName = null) : array
describeTable(string $tableName, string $schemaName = null) : arrayReturns the column descriptions for a table.
The return value is an associative array keyed by the column name,
as returned by the RDBMS.
The value of each array element is an associative array
with the following keys:
SCHEMA_NAME      => string; name of schema
TABLE_NAME       => string;
COLUMN_NAME      => string; column name
COLUMN_POSITION  => number; ordinal position of column in table
DATA_TYPE        => string; SQL datatype name of column
DEFAULT          => string; default expression of column, null if none
NULLABLE         => boolean; true if column can have nulls
LENGTH           => number; length of CHAR/VARCHAR
SCALE            => number; scale of NUMERIC/DECIMAL
PRECISION        => number; precision of NUMERIC/DECIMAL
UNSIGNED         => boolean; unsigned property of an integer type
PRIMARY          => boolean; true if column is part of the primary key
PRIMARY_POSITION => integer; position of column in primary key
IDENTITY         => integer; true if column is auto-generated with unique values
Parameters| Name | Type | Description | 
|---|
| $tableName | string |  | 
|---|
| $schemaName | string | OPTIONAL | 
|---|
ReturnsDetails- Todo
- Discover integer unsigned property.
         
    



 insert(mixed $table, array $bind) : int
insert(mixed $table, array $bind) : intInserts a table row with specified data.
Parameters| Name | Type | Description | 
|---|
| $table | mixed | The table to insert data into. | 
|---|
| $bind | array | Column-value pairs. | 
|---|
Returns| Type | Description | 
|---|
| int | The number of affected rows. | 
 


 lastInsertId(string $tableName = null, string $primaryKey = null) : string
lastInsertId(string $tableName = null, string $primaryKey = null) : stringGets the last ID generated automatically by an IDENTITY/AUTOINCREMENT column.
As a convention, on RDBMS brands that support sequences
(e.g. Oracle, PostgreSQL, DB2), this method forms the name of a sequence
from the arguments and returns the last id generated by that sequence.
On RDBMS brands that support IDENTITY/AUTOINCREMENT columns, this method
returns the last value generated for such a column, and the table name
argument is disregarded.
Parameters| Name | Type | Description | 
|---|
| $tableName | string | OPTIONAL Name of table. | 
|---|
| $primaryKey | string | OPTIONAL Name of primary key column. | 
|---|
Returns


 limit(string $sql, integer $count, integer $offset = 0) : string
limit(string $sql, integer $count, integer $offset = 0) : stringAdds an adapter-specific LIMIT clause to the SELECT statement.
Parameters| Name | Type | Description | 
|---|
| $sql | string |  | 
|---|
| $count | integer |  | 
|---|
| $offset | integer | OPTIONAL | 
|---|
ReturnsThrows 


 prepare(string $sql) : \Zend_Db_Statement_Sqlsrv
prepare(string $sql) : \Zend_Db_Statement_SqlsrvReturns an SQL statement for preparation.
Parameters| Name | Type | Description | 
|---|
| $sql | string | The SQL statement with placeholders. | 
|---|
Returns 


 setFetchMode(integer $mode) : void
setFetchMode(integer $mode) : voidParameters| Name | Type | Description | 
|---|
| $mode | integer | A fetch mode. | 
|---|
ThrowsDetails- Todo
- Support FETCH_CLASS and FETCH_INTO.
         
    
 


 setTransactionIsolationLevel(integer | null $level = null) : true
setTransactionIsolationLevel(integer | null $level = null) : trueSet the transaction isoltion level.
Parameters| Name | Type | Description | 
|---|
| $level | integer | null | A fetch mode from SQLSRV_TXN_*. | 
|---|
ReturnsThrows 


 supportsParameters(string $type) : bool
supportsParameters(string $type) : boolCheck if the adapter supports real SQL parameters.
Parameters| Name | Type | Description | 
|---|
| $type | string | 'positional' or 'named' | 
|---|
Returns