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

namespace IlluminateDatabaseSchema;

use 
IlluminateDatabaseQueryException;
use 
IlluminateSupportFacadesFile;

class 
SQLiteBuilder extends Builder
{
    
/**
     * Create a database in the schema.
     *
     * @param  string  $name
     * @return bool
     */
    
public function createDatabase($name)
    {
        return 
File::put($name'') !== false;
    }

    
/**
     * Drop a database from the schema if the database exists.
     *
     * @param  string  $name
     * @return bool
     */
    
public function dropDatabaseIfExists($name)
    {
        return 
File::exists($name)
            ? 
File::delete($name)
            : 
true;
    }

    
/**
     * Get the tables for the database.
     *
     * @param  bool  $withSize
     * @return array
     */
    
public function getTables($withSize true)
    {
        if (
$withSize) {
            try {
                
$withSize $this->connection->scalar($this->grammar->compileDbstatExists());
            } catch (
QueryException $e) {
                
$withSize false;
            }
        }

        return 
$this->connection->getPostProcessor()->processTables(
            
$this->connection->selectFromWriteConnection($this->grammar->compileTables($withSize))
        );
    }

    
/**
     * Get all of the table names for the database.
     *
     * @deprecated Will be removed in a future Laravel version.
     *
     * @return array
     */
    
public function getAllTables()
    {
        return 
$this->connection->select(
            
$this->grammar->compileGetAllTables()
        );
    }

    
/**
     * Get all of the view names for the database.
     *
     * @deprecated Will be removed in a future Laravel version.
     *
     * @return array
     */
    
public function getAllViews()
    {
        return 
$this->connection->select(
            
$this->grammar->compileGetAllViews()
        );
    }

    
/**
     * Drop all tables from the database.
     *
     * @return void
     */
    
public function dropAllTables()
    {
        if (
$this->connection->getDatabaseName() !== ':memory:') {
            return 
$this->refreshDatabaseFile();
        }

        
$this->connection->select($this->grammar->compileEnableWriteableSchema());

        
$this->connection->select($this->grammar->compileDropAllTables());

        
$this->connection->select($this->grammar->compileDisableWriteableSchema());

        
$this->connection->select($this->grammar->compileRebuild());
    }

    
/**
     * Drop all views from the database.
     *
     * @return void
     */
    
public function dropAllViews()
    {
        
$this->connection->select($this->grammar->compileEnableWriteableSchema());

        
$this->connection->select($this->grammar->compileDropAllViews());

        
$this->connection->select($this->grammar->compileDisableWriteableSchema());

        
$this->connection->select($this->grammar->compileRebuild());
    }

    
/**
     * Empty the database file.
     *
     * @return void
     */
    
public function refreshDatabaseFile()
    {
        
file_put_contents($this->connection->getDatabaseName(), '');
    }
}
Онлайн: 0
Реклама