Вход Регистрация
Файл: vendor/laravel/framework/src/Illuminate/Database/SqlServerConnection.php
Строк: 156
<?php

namespace IlluminateDatabase;

use 
Closure;
use 
Exception;
use 
IlluminateDatabasePDOSqlServerDriver;
use 
IlluminateDatabaseQueryGrammarsSqlServerGrammar as QueryGrammar;
use 
IlluminateDatabaseQueryProcessorsSqlServerProcessor;
use 
IlluminateDatabaseSchemaGrammarsSqlServerGrammar as SchemaGrammar;
use 
IlluminateDatabaseSchemaSqlServerBuilder;
use 
IlluminateFilesystemFilesystem;
use 
RuntimeException;
use 
Throwable;

class 
SqlServerConnection extends Connection
{
    
/**
     * Execute a Closure within a transaction.
     *
     * @param  Closure  $callback
     * @param  int  $attempts
     * @return mixed
     *
     * @throws Throwable
     */
    
public function transaction(Closure $callback$attempts 1)
    {
        for (
$a 1$a <= $attempts$a++) {
            if (
$this->getDriverName() === 'sqlsrv') {
                return 
parent::transaction($callback$attempts);
            }

            
$this->getPdo()->exec('BEGIN TRAN');

            
// We'll simply execute the given callback within a try / catch block
            // and if we catch any exception we can rollback the transaction
            // so that none of the changes are persisted to the database.
            
try {
                
$result $callback($this);

                
$this->getPdo()->exec('COMMIT TRAN');
            }

            
// If we catch an exception, we will rollback so nothing gets messed
            // up in the database. Then we'll re-throw the exception so it can
            // be handled how the developer sees fit for their applications.
            
catch (Throwable $e) {
                
$this->getPdo()->exec('ROLLBACK TRAN');

                throw 
$e;
            }

            return 
$result;
        }
    }

    
/**
     * Escape a binary value for safe SQL embedding.
     *
     * @param  string  $value
     * @return string
     */
    
protected function escapeBinary($value)
    {
        
$hex bin2hex($value);

        return 
"0x{$hex}";
    }

    
/**
     * Determine if the given database exception was caused by a unique constraint violation.
     *
     * @param  Exception  $exception
     * @return bool
     */
    
protected function isUniqueConstraintError(Exception $exception)
    {
        return 
boolval(preg_match('#Cannot insert duplicate key row in object#i'$exception->getMessage()));
    }

    
/**
     * Get the default query grammar instance.
     *
     * @return IlluminateDatabaseQueryGrammarsSqlServerGrammar
     */
    
protected function getDefaultQueryGrammar()
    {
        (
$grammar = new QueryGrammar)->setConnection($this);

        return 
$this->withTablePrefix($grammar);
    }

    
/**
     * Get a schema builder instance for the connection.
     *
     * @return IlluminateDatabaseSchemaSqlServerBuilder
     */
    
public function getSchemaBuilder()
    {
        if (
is_null($this->schemaGrammar)) {
            
$this->useDefaultSchemaGrammar();
        }

        return new 
SqlServerBuilder($this);
    }

    
/**
     * Get the default schema grammar instance.
     *
     * @return IlluminateDatabaseSchemaGrammarsSqlServerGrammar
     */
    
protected function getDefaultSchemaGrammar()
    {
        (
$grammar = new SchemaGrammar)->setConnection($this);

        return 
$this->withTablePrefix($grammar);
    }

    
/**
     * Get the schema state for the connection.
     *
     * @param  IlluminateFilesystemFilesystem|null  $files
     * @param  callable|null  $processFactory
     *
     * @throws RuntimeException
     */
    
public function getSchemaState(?Filesystem $files null, ?callable $processFactory null)
    {
        throw new 
RuntimeException('Schema dumping is not supported when using SQL Server.');
    }

    
/**
     * Get the default post processor instance.
     *
     * @return IlluminateDatabaseQueryProcessorsSqlServerProcessor
     */
    
protected function getDefaultPostProcessor()
    {
        return new 
SqlServerProcessor;
    }

    
/**
     * Get the Doctrine DBAL driver.
     *
     * @return IlluminateDatabasePDOSqlServerDriver
     */
    
protected function getDoctrineDriver()
    {
        return new 
SqlServerDriver;
    }
}
Онлайн: 0
Реклама