当前位置:首页 > CMS教程 > 其它CMS > 列表

Laravel5.1 框架数据库操作DB运行原生SQL的方法分析

发布:smiling 来源: PHP粉丝网  添加日期:2022-02-03 18:57:44 浏览: 评论:0 

本文实例讲述了Laravel5.1 框架数据库操作DB运行原生SQL的方法,分享给大家供大家参考,具体如下:

Laravel操作数据库有三种:DB原生SQL、构建器、Model。这三种依情况而决定使用哪种更合适。

那么今儿咱就从DB原生SQL说起:

1 用DB门面原生SQL语句操作

用DB门面操作的话呢 无非就是:insert、select、update、delete 另外附加一个statement(通用语句 比如drop之类的)。

1.1 insert

  1. public function getInsert() 
  2.   DB::insert('INSERT INTO articles (title, body)VALUE(?, ?)', ['learn laravel''balablalabalabla']); 

insert方法接受两个参数 第一个参数呢 就是原生的SQL语句,第二个参数是一个数组 对应的sql语句中的?

1.2 select

  1. public function getArticles(){ 
  2.   $articles = DB::select('SELECT * FROM articles WHERE title=:title', ['title' => 'learn laravel']); 
  3.   foreach ($articles as $article){ 
  4.     echo "<p>$article->id</p>"
  5.     echo "<p>$article->title</p>"
  6.     echo "<p>$article->body</p>"
  7.   } 

我们的占位符不仅仅是? 也可以用":name" 来表示,对应的数组就是一对儿一对儿的键值。

1.3 update

  1. public function getUpdate() 
  2.   $affected = DB::update('UPDATE articles SET title=:title,body=:body WHERE id=:id',['title' => 'laravel database''body' => 'balabala''id' => 1]); 
  3.   echo $affected

update方法还返回了一个affected 这是受到影响的总行数。

1.4 delete

  1. public function getDelete() 
  2.   $affected = DB::delete('DELETE FROM articles WHERE id=:id', ['id' => 2]); 
  3.   echo $affected

1.5 statement

  1. public function getDrop() 
  2.   DB::statement('DROP TABLE articles'); 

2 监听查询

我们可以用 listen方法 监听每一次操作数据库动作,这样我们就可以用于 记录日志啊 调试啊什么的:

  1. class AppServiceProvider extends ServiceProvider 
  2.   /** 
  3.    * Bootstrap any application services. 
  4.    * 
  5.    * @return void 
  6.    */ 
  7.   public function boot() 
  8.   { 
  9.     DB::listen(function($sql$bindings$time){ 
  10.       // $sql   = 查询语句 
  11.       // $bindings = 绑定的键和值 数组类型 
  12.       // 所用的时间 
  13.     }); 
  14.   } 
  15.   /** 
  16.    * Register any application services. 
  17.    * 
  18.    * @return void 
  19.    */ 
  20.   public function register() 
  21.   { 
  22.     // 
  23.   } 
  24. }

Tags: Laravel5.1原生SQL

分享到: