SqlserverStatement.php 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. <?php
  2. /**
  3. * CakePHP(tm) : Rapid Development Framework (http://cakephp.org)
  4. * Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
  5. *
  6. * Licensed under The MIT License
  7. * For full copyright and license information, please see the LICENSE.txt
  8. * Redistributions of files must retain the above copyright notice.
  9. *
  10. * @copyright Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
  11. * @link http://cakephp.org CakePHP(tm) Project
  12. * @since 3.0.0
  13. * @license http://www.opensource.org/licenses/mit-license.php MIT License
  14. */
  15. namespace Cake\Database\Statement;
  16. use Cake\Database\Statement\PDOStatement;
  17. use PDO;
  18. /**
  19. * Statement class meant to be used by an Sqlserver driver
  20. *
  21. * @internal
  22. */
  23. class SqlserverStatement extends PDOStatement {
  24. /**
  25. * The SQL Server PDO driver requires that binary parameters be bound with the SQLSRV_ENCODING_BINARY attribute.
  26. * This overrides the PDOStatement::bindValue method in order to bind binary columns using the required attribute.
  27. *
  28. * {@inheritDoc}
  29. */
  30. public function bindValue($column, $value, $type = 'string') {
  31. if ($type === null) {
  32. $type = 'string';
  33. }
  34. if (!ctype_digit($type)) {
  35. list($value, $type) = $this->cast($value, $type);
  36. }
  37. if ($type == PDO::PARAM_LOB) {
  38. $this->_statement->bindParam($column, $value, $type, 0, PDO::SQLSRV_ENCODING_BINARY);
  39. } else {
  40. $this->_statement->bindValue($column, $value, $type);
  41. }
  42. }
  43. }