数据库起步 - Database: Getting Started - Laravel 5.1 文档

   2016-10-31 0
核心提示:Laravel让连接多种数据库和运行查询都变得非常简单,不论使用原生SQL、还是查询构建器,还是Eloquent ORM。目前,Laravel支持四种类型的数据库系统:MysqlPostgresSQLiteSQL Server配置Laravel让连接数据库和运行查询都变的非常简单。应用数据库的配置位于con

Laravel让连接多种数据库和运行查询都变得非常简单,不论使用原生SQL、还是查询构建器,还是Eloquent ORM。目前,Laravel支持四种类型的数据库系统:

  • Mysql
  • Postgres
  • SQLite
  • SQL Server

配置

Laravel让连接数据库和运行查询都变的非常简单。应用数据库的配置位于 config/database.php .再该文件中你可以定义所有的数据库连接,并指定哪一个是默认的连接。该文件提供了支持数据库系统的配置示例。

1.读/写分离

有时候你希望使用一个数据库连接做查询,另一个数据库连接做插入,更新和删除,Laravel让这件事件轻而易举,不管你是用原生的SQL,还是查询构建器,还是Eloquent ORM,合适的连接总是会被使用.

想要如何配置读写连接,让我们看看下面的例子:

'mysql' => [
    'read' => [
        'host' => '192.168.1.1',
    ],
    'write' => [
        'host' => '196.168.1.2'
    ],
    'driver'    => 'mysql',
    'database'  => 'database',
    'username'  => 'root',
    'password'  => '',
    'charset'   => 'utf8',
    'collation' => 'utf8_unicode_ci',
    'prefix'    => '',
],

注意我们在配置数组中新增了两个键: readwrite ,这两个键都对应一个包含单个键“host”的数组,读/写连接的其它数据库配置选项都共用 mysql 的主数组配置。

如果我们想要覆盖主数组中的配置,只需要将相应配置项放到 readwrite 数组中即可。在本例中, 192.168.1.1 将被用作“读”连接,而 192.168.1.2 将被用作“写”连接。两个数据库连接的凭证(用户名/密码)、前缀、字符集以及其它配置将会共享 mysql 数组中的设置。

运行原生的SQL查询

一旦配置好数据库的连接,就可以使用DB门面来运行查询。DB门面提供了下面的方法:

select , update , insert , delete , statement

1. select 查询

运行最基本的查询,可以使用DB门面的 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;
}

### 2. 使用命名绑定
除了使用```?```占位符来代表参数绑定外,还可以使用命名绑定来执行查询:
```php
    public function index($id)
    {
        $user = DB::select('select * from users where id = :id', ['id' => $id]);

        return $user;
    }

3. 运行插入语句

使用DB门面的 insert 方法执行插入语句。和select一样,改方法将原生SQL语句作为第一个参数,将绑定作为第二个参数:

// 插入成功,返回的是true
DB::insert('insert into users (id, name) values (?, ?)', [1, 'Dayle']);

4. 运行更新语句

update 方法用于更新数据库中已存在的记录,该方法返回受更新语句影响的行数:

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

5. 运行删除语句

delete 方法用于删除数据库中已存在的记录,和update一样,该语句返回被删除的行数:

$rows = DB::delete('delete from users where name = ?', ['zhoujiping']);

6.运行一个通用语句

有些数据库语句不返回任何值,对于这种类型的操作,可以使用DB门面的 statement 方法, 以上使用的命令都可以用 statement 代替。

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

7.监听查询事件

如果获取应用中每次SQL语句的执行,可以使用 listen 方法,该方法对查询日志和调试非常有用,我们可以在服务提供者中注册监听器:

<?php

namespace App\Providers;

use DB;
use Illuminate\Support\ServiceProvider;

class AppServiceProvider extends ServiceProvider{
    /**
     * 启动所有应用服务
     *
     * @return void
     */
    public function boot()
    {
        DB::listen(function() {
            echo '只要你执行sql语句,就会输出这句话';
        });
    }

    /**
     * 注册服务提供者
     *
     * @return void
     */
    public function register()
    {
        //
    }
}

数据库事务

想要在一个数据库事务中运行一连串操作,可以使用DB门面的 transaction 方法,如果事务闭包中抛出异常,事务将会自动回滚。如果闭包执行成功,事务将会自动提交。使用 transaction 方法时不需要担心手动回滚或提交:

DB::transaction(function () {
    DB::table('users')->update(['votes' => 1]);
    DB::table('posts')->delete();
});

手动执行数据库事务

如果你想要手动开始事务从而对回滚和提交有一个完整的控制,可以使用DB门面的 beginTransaction 方法:

DB::beginTransaction();

你可以通过rollBack方法回滚事务:

DB::rollBack();

最后,你可以通过commit方法提交事务:

DB::commit();

注意:使用DB门面的事务方法还可以用于控制查询构建器和Eloquent ORM的事务。

使用多个数据库连接

使用多个数据库连接的时候,可以使用DB门面的 connection 方法访问每个连接。传递给 connection 方法的连接名对应配置文件 config/database.php 中相应的连接:

$users = DB::connection('foo')->select(...);

你还可以通过连接实例上的getPdo方法底层原生的PDO实例:

$pdo = DB::connection()->getPdo();
 
标签: 数据库 Laravel
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • 【Rust】标准库-Result rust数据库
    环境Rust 1.56.1VSCode 1.61.2概念参考:https://doc.rust-lang.org/stable/rust-by-example/std/result.html示例main.rsmod checked {#[derive(Debug)]pub enum MathError {DivisionByZero,NonPositiveLogarithm,NegativeSquareRoot,}pub type MathResult =
    02-09
  • 【Rust】标准库-引用 rust 数据库框架
    环境Rust 1.56.1VSCode 1.61.2概念参考:https://doc.rust-lang.org/stable/rust-by-example/std/rc.html示例rust 使用 Rc 来实现引用计数。main.rsuse std::rc::Rc;fn main() {let rc_examples = "Rc examples".to_string();{println!("--- rc_a is created
    02-09
  • DELPHI中使用UNIDAC连接ORACLE数据库
    


		
DELPHI中使用UNIDAC连接ORACLE数据库
    DELPHI中使用UNIDAC连接ORACLE数据库
      最近在DELPHI中使用到UNIDAC连接到oracle数据库,这样可以不要安装oracle客户端,比较方便使用;所以简单学习了一下,主要是用到查询和执行存储过程,其中存储过程我测试了没有返回参数、有返回参数、有多高返回参数、有返回游标等存储过程,没有深入研究
    02-09
  • Perl操作Mysql数据库 perl操作excel
    一. 安装DBI模块步骤1:从TOOLS栏目中下载DBI.zip,下载完后用winzip解开到一个temp目录,共有三个文件:ReadmeDBI.ppdDBI.tar.gz步骤2: 在DOS窗口下,temp目录中运行下面的DOS命令:ppm install DBI.ppd 如果提示无效命令,可在perl/bin目录下运行 二. 安装DBD
    02-09
  • 在OS X系统中配置Ruby on Rails使其可以访问Sql
    经过大半天的折腾,终于可以让RoR在OS X系统里访问Sql Server数据库了。这里记录一下操作的过程,免得以后忘了。第一步,安装FreeTDS从FreeTDS的官网上下载最新的稳定版的压缩包,然后,遵照这里的说明进行手工编译(好怀念微软的Setup.exe和*.msi啊),其中
    02-09
  • 小程序-列表页跳详情页(不在数据库)
    1.缓存localstorage,可以长期保存数据2.绑定到view层id='',只要显示历史记录,就能携带id到详情页e.currentTarget.id访问点击当前的view的id
    02-09
  • Mysql数据库一个小程序实现自动创建分表。
    每当跨月的时候也是系统出问题最多的时候,没有表和字段缺失是两个最常见的错误。为了解决这个问题,研究了一下mysql的 information_schema 表:information_schema这张数据表保存了MySQL服务器所有数据库的信息。如数据库名,数据库的表,表栏的数据类型与访
    02-09
  • C#连接本地Access数据库及简单操作的winform小程序
    C#连接本地Access数据库及简单操作的winform小
    连接本地Access数据库及简单操作的winform小程序一、准备工作用Access创建一个数据库并创建一个表格。(对于非远程数据库,Access十分简单。表格可参考三、界面设计)。二、代码using System;using System.Collections.Generic;using System.ComponentModel;u
    02-09
  • 解决小程序云函数操作数据库回调不执行
    背景最近写个微信小程序,在云函数中操作数据库时,明明操作成功了,理应回调success,却没有;而在小程序端,一样的代码,却能成功回调。 问题原因参见官方文档:https://developers.weixin.qq.com/miniprogram/dev/wxcloud/reference-server-api/init.html
    02-09
  • Rust 连接 SQLite 数据库
    Rust 连接 SQLite 数据库
    使用 Rust 语言连接操作 SQLite 数据库,我使用 rusqlite 这个 crate。看例子:首先,使用 cargo 创建一个 Rust 项目,然后添加依赖 rusqlite: 来到 main.rs,其余所有的代码都写在这里。首先引入 rusqlite 相关的类型,并建立一个 Person struct:Person
    02-09
点击排行