Laravel 4: how to run a raw SQL?

前端 未结 7 951
情书的邮戳
情书的邮戳 2020-11-29 01:26

I want to rename a table in Laravel 4, but don\'t know how to do that.

The SQL is alter table photos rename to images. If there is an Eloquent solution,

相关标签:
7条回答
  • 2020-11-29 01:39

    In the Laravel 4 manual - it talks about doing raw commands like this:

    DB::select(DB::raw('RENAME TABLE photos TO images'));
    

    edit: I just found this in the Laravel 4 documentation which is probably better:

    DB::statement('drop table users');
    

    Update: In Laravel 4.1 (maybe 4.0 - I'm not sure) - you can also do this for a raw Where query:

    $users = User::whereRaw('age > ? and votes = 100', array(25))->get();
    

    Further Update If you are specifically looking to do a table rename - there is a schema command for that - see Mike's answer below for that.

    0 讨论(0)
  • 2020-11-29 01:40

    The accepted way to rename a table in Laravel 4 is to use the Schema builder. So you would want to do:

    Schema::rename('photos', 'images');
    

    From http://laravel.com/docs/4.2/schema#creating-and-dropping-tables

    If you really want to write out a raw SQL query yourself, you can always do:

    DB::statement('alter table photos rename to images');
    

    Note: Laravel's DB class also supports running raw SQL select, insert, update, and delete queries, like:

    $users = DB::select('select id, name from users');
    

    For more info, see http://laravel.com/docs/4.2/database#running-queries.

    0 讨论(0)
  • 2020-11-29 01:44

    You can also use DB::unprepared for ALTER TABLE queries.

    DB::unprepared is meant to be used for queries like CREATE TRIGGER. But essentially it executes raw sql queries directly. (without using PDO prepared statements)

    https://github.com/laravel/framework/pull/54

    0 讨论(0)
  • 2020-11-29 01:44

    The best way to do this I have found so far it to side step Laravel and execute the query directly using the Pdo object.

    Example

    DB::connection()->getPdo()->exec( $sql );
    

    I usually find it faster and more efficient for a one time query to simply open my database query tool and type the query with full syntax checking then execute it directly.

    This becomes essential if you have to work with stored procedures or need to use any database functions

    Example 2 setting created_at to a the value you need it to be and side steeping any carbon funkiness

    $sql = 'UPDATE my_table SET updated_at = FROM_UNIXTIME(nonce) WHERE id = ' . strval($this->id);
    DB::statement($sql);
    

    I found this worked in a controller but not in a migration

    0 讨论(0)
  • 2020-11-29 01:48

    Actually, Laravel 4 does have a table rename function in Illuminate/Database/Schema/Builder.php, it's just undocumented at the moment: Schema::rename($from, $to);.

    0 讨论(0)
  • 2020-11-29 01:49

    This is my simplified example of how to run RAW SELECT, get result and access the values.

    $res = DB::select('
            select count(id) as c
            from prices p 
            where p.type in (2,3)
        ');
        if ($res[0]->c > 10)
        {
            throw new Exception('WOW');
        }
    

    If you want only run sql script with no return resutl use this

    DB::statement('ALTER TABLE products MODIFY COLUMN physical tinyint(1) AFTER points;');
    

    Tested in laravel 5.1

    0 讨论(0)
提交回复
热议问题