2013-04-03 17:19:26 +13:00
|
|
|
<?php
|
|
|
|
|
2016-07-15 13:57:54 +12:00
|
|
|
namespace SilverStripe\MSSQL;
|
|
|
|
|
|
|
|
use DateTime;
|
2016-09-09 18:55:53 +12:00
|
|
|
use SilverStripe\ORM\Connect\Query;
|
2016-07-15 13:57:54 +12:00
|
|
|
|
2013-04-03 17:19:26 +13:00
|
|
|
/**
|
|
|
|
* A result-set from a MSSQL database.
|
|
|
|
*/
|
2016-09-09 18:55:53 +12:00
|
|
|
class SQLServerQuery extends Query
|
2015-12-18 07:50:59 +13:00
|
|
|
{
|
2013-04-03 17:19:26 +13:00
|
|
|
|
2015-12-18 07:50:59 +13:00
|
|
|
/**
|
|
|
|
* The SQLServerConnector object that created this result set.
|
2016-08-30 13:08:11 +12:00
|
|
|
*
|
2015-12-18 07:50:59 +13:00
|
|
|
* @var SQLServerConnector
|
|
|
|
*/
|
|
|
|
private $connector;
|
2013-04-03 17:19:26 +13:00
|
|
|
|
2015-12-18 07:50:59 +13:00
|
|
|
/**
|
|
|
|
* The internal MSSQL handle that points to the result set.
|
2016-08-30 13:08:11 +12:00
|
|
|
*
|
2015-12-18 07:50:59 +13:00
|
|
|
* @var resource
|
|
|
|
*/
|
|
|
|
private $handle;
|
2013-04-03 17:19:26 +13:00
|
|
|
|
2015-12-18 07:50:59 +13:00
|
|
|
/**
|
|
|
|
* Hook the result-set given into a Query class, suitable for use by sapphire.
|
|
|
|
* @param SQLServerConnector $connector The database object that created this query.
|
|
|
|
* @param resource $handle the internal mssql handle that is points to the resultset.
|
|
|
|
*/
|
|
|
|
public function __construct(SQLServerConnector $connector, $handle)
|
|
|
|
{
|
|
|
|
$this->connector = $connector;
|
|
|
|
$this->handle = $handle;
|
|
|
|
}
|
2013-04-03 17:19:26 +13:00
|
|
|
|
2015-12-18 07:50:59 +13:00
|
|
|
public function __destruct()
|
|
|
|
{
|
|
|
|
if (is_resource($this->handle)) {
|
|
|
|
sqlsrv_free_stmt($this->handle);
|
|
|
|
}
|
|
|
|
}
|
2013-04-03 17:19:26 +13:00
|
|
|
|
2015-12-18 07:50:59 +13:00
|
|
|
public function seek($row)
|
|
|
|
{
|
|
|
|
if (!is_resource($this->handle)) {
|
|
|
|
return false;
|
|
|
|
}
|
2013-04-03 17:19:26 +13:00
|
|
|
|
2015-12-18 07:50:59 +13:00
|
|
|
user_error('MSSQLQuery::seek() not supported in sqlsrv', E_USER_WARNING);
|
|
|
|
}
|
2013-04-03 17:19:26 +13:00
|
|
|
|
2015-12-18 07:50:59 +13:00
|
|
|
public function numRecords()
|
|
|
|
{
|
|
|
|
if (!is_resource($this->handle)) {
|
|
|
|
return false;
|
|
|
|
}
|
2013-04-03 17:19:26 +13:00
|
|
|
|
2015-12-18 07:50:59 +13:00
|
|
|
// WARNING: This will only work if the cursor type is scrollable!
|
|
|
|
if (function_exists('sqlsrv_num_rows')) {
|
|
|
|
return sqlsrv_num_rows($this->handle);
|
|
|
|
} else {
|
|
|
|
user_error('MSSQLQuery::numRecords() not supported in this version of sqlsrv', E_USER_WARNING);
|
|
|
|
}
|
|
|
|
}
|
2013-04-03 17:19:26 +13:00
|
|
|
|
2015-12-18 07:50:59 +13:00
|
|
|
public function nextRecord()
|
|
|
|
{
|
|
|
|
if (!is_resource($this->handle)) {
|
|
|
|
return false;
|
|
|
|
}
|
2013-04-03 17:19:26 +13:00
|
|
|
|
2015-12-18 07:50:59 +13:00
|
|
|
if ($data = sqlsrv_fetch_array($this->handle, SQLSRV_FETCH_ASSOC)) {
|
|
|
|
// special case for sqlsrv - date values are DateTime coming out of the sqlsrv drivers,
|
|
|
|
// so we convert to the usual Y-m-d H:i:s value!
|
|
|
|
foreach ($data as $name => $value) {
|
|
|
|
if ($value instanceof DateTime) {
|
|
|
|
$data[$name] = $value->format('Y-m-d H:i:s');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $data;
|
|
|
|
} else {
|
|
|
|
// Free the handle if there are no more results - sqlsrv crashes if there are too many handles
|
|
|
|
sqlsrv_free_stmt($this->handle);
|
|
|
|
$this->handle = null;
|
|
|
|
}
|
2013-04-03 17:19:26 +13:00
|
|
|
|
2015-12-18 07:50:59 +13:00
|
|
|
return false;
|
|
|
|
}
|
2013-04-03 17:19:26 +13:00
|
|
|
}
|