回 帖 发 新 帖 刷新版面

主题:数据库入门之运行原始 SQL 查找

数据库入门之运行原始 SQL 查找

一旦你设置好了数据库连接,就可以使用 DB facade 来进行查找。DB facade 提供每个类型的查找方法:selectupdateinsertdeletestatement下面兄弟连帮你一一介绍。

 

运行一个 Select 查找#

 

DB facade 中使用 select 可以运行一个基本的查找:

 

<?php

 

namespace App\Http\Controllers;

 

use DB;

use App\Http\Controllers\Controller;

 

class UserController extends Controller

{

    /**

     * 显示应用程序中所有用户的列表。

     *

     * @return Response

     */

    public function index()

    {

        $users = DB::select('select * from users where active = ?', [1]);

 

        return view('user.index', ['users' => $users]);

    }

}

 

传递给 select 方法的第一个参数是原始的 SQL 查找,而第二个参数是任何查找所需要的参数绑定。通常,这些都是 where 语句的限定值。参数绑定主要是为了防止 SQL 注入。

 

select 方法总会返回结果的数组数据。数组中的每个结果都是一个 PHP StdClass 对象,这使你能够访问到结果的值:

 

foreach ($users as $user) {

    echo $user->name;

}

 

使用命名绑定#

 

除了使用 ? 来表示你的参数绑定外,你也可以使用命名绑定运行查找:

 

$results = DB::select('select * from users where id = :id', ['id' => 1]);

 

运行 Insert#

 

若要运行 insert 语法,则可以在 DB facade 使用 insert 方法。如同 select 一样,这个方法的第一个参数是原始的 SQL 查找,第二个参数则是绑定:

 

DB::insert('insert into users (id, name) values (?, ?)', [1, 'Dayle']);

 

运行 Update#

 

update 方法用于更新已经存在于数据库的记录。该方法会返回此声明所影响的行数:

 

$affected = DB::update('update users set votes = 100 where name = ?', ['John']);

 

运行 Delete#

 

delete 方法用于删除已经存在于数据库的记录。如同 update 一样,删除的行数将会被返回:

 

$deleted = DB::delete('delete from users');

 

运行一般声明#

 

有时候一些数据库操作不应该返回任何参数。对于这种类型的操作,你可以在 DB facade 使用 statement 方法:

 

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

 

监听查找事件#

 

如果你希望能够监控到程序执行的每一条 SQL 语句,则可以使用 listen 方法。这个方法对于纪录查找跟调试将非常有用。你可以在 服务容器 中注册你的查找侦听器:

 

<?php

 

namespace App\Providers;

 

use DB;

use Illuminate\Support\ServiceProvider;

 

class AppServiceProvider extends ServiceProvider

{

    /**

     * 启动任何应用程序的服务。

     *

     * @return void

     */

    public function boot()

    {

        DB::listen(function($sql, $bindings, $time) {

            //

        });

    }

 

    /**

     * 注册一个服务提供者。

     *

     * @return void

     */

    public function register()

    {

        //

    }

}

0

回复列表 (共1个回复)

沙发

在线博彩平台:www.pb258.com
在线博彩平台:www.jjxtech.com 
在线博彩平台:www.lcmty.com 
在线博彩平台:www.7macau.com
在线博彩平台:www.7macau.net
在线博彩平台:www.bp258.com
在线博彩平台:www.258bp.com
博狗:http://679.258bp.com
博狗:http://680.258bp.com
博狗:http://681.258bp.com
博狗:http://682.258bp.com
博狗:http://683.258bp.com
博狗:http://684.258bp.com
博狗:http://685.258bp.com
博狗:http://686.258bp.com
博狗:http://687.258bp.com
博狗:http://688.258bp.com
博狗:http://689.258bp.com
博狗:http://690.258bp.com
博狗:http://691.258bp.com
博狗:http://692.258bp.com
博狗:http://693.258bp.com
博狗合营:http://694.258bp.com
888真人:http://695.258bp.com
888真人:http://696.258bp.com
888真人:http://697.258bp.com
加百利:http://698.258bp.com
加百利:http://699.258bp.com 
必威:http://700.258bp.com
必威:http://701.258bp.com
必威:http://702.258bp.com
必威:http://703.258bp.com
必威:http://704.258bp.com
必威:http://705.258bp.com
必威:http://706.258bp.com
必威合营:http://707.258bp.com
新博:http://708.258bp.com
鸿运国际:http://709.258bp.com
鸿运国际:http://710.258bp.com
鸿运国际:http://711.258bp.com
新橙娱乐:http://712.258bp.com
新橙娱乐:http://713.258bp.com
新橙娱乐:http://714.258bp.com
新橙娱乐:http://715.258bp.com
新橙娱乐合营:http://716.258bp.com
乐虎:http://717.258bp.com
乐虎:http://718.258bp.com
乐虎:http://719.258bp.com
乐虎:http://720.258bp.com
乐虎:http://721.258bp.com
乐虎:http://722.258bp.com
亚虎:http://723.258bp.com
亚虎:http://724.258bp.com
亚虎:http://725.258bp.com
龙8国际娱乐:http://726.258bp.com
龙8国际娱乐:http://727.258bp.com
龙8国际娱乐:http://728.258bp.com
龙8国际娱乐:http://729.258bp.com
龙8国际娱乐:http://730.258bp.com
龙8国际娱乐:http://731.258bp.com
必博:http://2274.bbo233.com
必博:http://2274.bbo998.com

我来回复

您尚未登录,请登录后再回复。点此登录或注册