数据库:入门
简介
Laravel 对主流数据库系统连接和查询都提供了很好的支持,尤其是:流畅的 查询语句构造器 和强大的 Eloquent ORM。
目前,Laravel 支持以下四种数据库系统:
- MySQL
- Postgres
- SQLite
- SQL Server
译者注:Mongo DB 的支持可以使用这个项目 - laravel-mongodb
配置信息
Laravel 应用程序的数据库配置文件放置在 config/database.php
。在这个配置文件内你可以定义所有的数据库连接,以及指定默认使用哪个连接。在此文件内提供了所有支持的数据库系统示例。
默认情况下,Laravel 的 环境配置 示例会使用 Homestead,对于 Laravel 开发来说这是一个相当便利的本地虚拟机。当然你也可以根据需求来随时修改本机端的数据库设置。
数据库读写分离
有时候你也许会希望使用一个数据库作为只读数据库,而另一个数据库则负责写入、更新以及删除。Laravel 让此类操作变得轻而易举,无论使用原始查找、查询语句构造器或是 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' => '',
],
注意,有两个键加入了这个配置文件数组内:read
及 write
。这两个键内包含了数组,里面也包含了一个单独的键:host
。read
及 write
连接的其它数据库设置选项将会合并在主要的 mysql
数组内。
所以,如果需要在主要的数组内重写值,只需在 read
及 write
数组内放置设置参数即可。在这个例子中,192.168.1.1
将被使用在「读取」连接上,而 192.168.1.2
则被使用在「写入」连接上。数据库的凭证、前缀、编码设置,以及所有其它的选项都被存放在 mysql
数组内,这两个连接将会共用这些选项。
运行原始 SQL 查找
一旦你设置好了数据库连接,就可以使用 DB
facade 来进行查找。DB
facade 提供每个类型的查找方法:select
、update
、insert
、delete
、statement
。
运行一个 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']);