laravel支援四種資料庫:1、MySQL,一個關聯式資料庫管理系統;2、PostgreSQL,一個「物件-關聯」型資料庫管理系統;3、SQLite,一款輕型的關聯式資料庫管理系統;4、SQL Server,一款關係型資料庫管理系統。
本教學操作環境:windows7系統、Laravel6版、Dell G3電腦。
Laravel 支援原生的 SQL 查詢、流暢的查詢建構器 和 Eloquent ORM 這些操作在各種資料庫後台與資料庫的互動變得非常簡單。
目前Laravel 支援以下四個資料庫:
MySQL 5.7 :一個關係型資料庫管理系統,由瑞典MySQL AB 公司開發,屬於Oracle 旗下產品。
PostgreSQL 9.6 :一個特性非常齊全的自由軟體的物件-關聯式資料庫管理系統,是以加州大學電腦系開發的POSTGRES,4.2版本為基礎的物件關係型資料庫管理系統。
SQLite 3.8.8 :一款輕型的資料庫,是遵守ACID的關聯式資料庫管理系統,它包含在一個相對小的C函式庫中。
SQL Server 2017 :Microsoft 公司推出的關係型資料庫管理系統
##設定
SQLite 設定
在使用touch database/database.sqlite
一類的建立指令,建立了一個新的SQLite 資料庫之後,你就可以使用資料庫的絕對路徑,配置環境變數來指向這個新建立的資料庫:DB_CONNECTION=sqlite DB_DATABASE=/absolute/path/to/database.sqlite若要為SQLite 連線啟用外鍵約束,應將DB_foreign_KEYS 環境變數設為true:
DB_FOREIGN_KEYS=true
URLs 形式配置
通常,資料庫連線使用多個設定值,例如host
、database
、username、password
等。這些配置值中的每一個都有其對應的環境變數。這意味著在生產伺服器上配置資料庫連接資訊時,需要管理多個環境變數。 一些託管資料庫提供者(如 Heroku)提供單一資料庫“URL”,該 URL 在單一字串中包含資料庫的所有連接資訊。範例資料庫 URL 可能如下所示:mysql://root:password@127.0.0.1/forge?charset=UTF-8
这些 URLs 通常遵循标准模式约定: driver://username:password@host:port/database?options為了方便起見,Laravel 支援這些 URLs,作為使用多個設定選項來配置資料庫的替代方法。如果存在 url(或對應的 DATABASE_URL 環境變數)配置選項,則將使用此選項提取資料庫連線和憑證資訊。 #########讀寫分離#########有時你希望 SELECT 語句使用一個資料庫連接,而 INSERT、UPDATE 和 DELETE 語句使用另一個資料庫連接。在 Laravel 中,無論你是使用原生查詢,查詢建構器,或是 Eloquent ORM,都能輕鬆的實作。 ######為了弄清楚讀寫分離是如何配置的,我們先來看個例子:###
'mysql' => [ 'read' => [ 'host' => [ '192.168.1.1', '196.168.1.2', ], ], 'write' => [ 'host' => [ '196.168.1.3', ], ], 'sticky' => true, 'driver' => 'mysql', 'database' => 'database', 'username' => 'root', 'password' => '', 'charset' => 'utf8mb4', 'collation' => 'utf8mb4_unicode_ci', 'prefix' => '', ],####注意在以上的例子中,配置數組中增加了三個鍵,分別是read 、write 和sticky。 read 和 write 都包含一個鍵為 host 的陣列。而 read 和 write 的其他資料庫選項都在鍵為 mysql 的陣列中。 ######如果你想重寫主數組中的配置,只需要修改 read 和 write 陣列即可。所以,這個範例中:192.168.1.1 和 192.168.1.2 將作為 “讀” 連接主機,而 192.168.1.3 將作為 “寫” 連接主機。這兩個連線會共用 mysql 陣列的各項配置,如資料庫的憑證(使用者名稱 / 密碼),前綴,字元編碼等。 #########sticky 選項#########sticky 是一個 可選值,它用於立即讀取在目前請求週期內已寫入資料庫的記錄。若 sticky 選項啟用,且目前請求週期內執行過「寫入」操作,那麼任何「讀取」操作都會使用「寫入」連線。這樣可確保同一個請求週期內寫入的資料可以立即讀取到,從而避免主從同步延遲導致資料不一致的問題。不過是否啟用它,取決於應用程式的需求。 #########使用多資料庫連線#########當使用多資料庫連線時,你可以透過 DB Facade 門面的 connection 方法存取每一個連線。傳遞給connection 方法的參數name 應該是config/database.php 設定檔中connections 陣列中的一個值:###
$users = DB::connection('foo')->select(...);###你也可以使用一個連線實例上的getPdo 方法存取底層的PDO 實例:## #
$pdo = DB::connection()->getPdo();
执行原生 SQL 查询
一旦配置好数据库连接后,便可以使用 DB facade 门面运行查询。DB facade 为每种类型的查询提供了相应的方法:select,update,insert,delete 和 statement。
执行 Select 查询
你可以使用 DB Facade 的 select 方法来运行基础的查询语句:
<?php namespace App\Http\Controllers; use App\Http\Controllers\Controller; use Illuminate\Support\Facades\DB; 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 方法将始终返回一个 array 数组,数组中的每个结果都是一个 stdClass 对象,可以像下面这样访问结果中的数值:
foreach ($users as $user) { echo $user->name; }
使用命名绑定
除了使用 ? 表示参数绑定外,你还可以使用命名绑定的形式来执行一个查询:
$results = DB::select('select * from users where id = :id', ['id' => 1]);
执行 Insert 语句
你可以使用 DB Facade 的 insert 方法来执行 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');
运行未预处理的语句
有时你可能希望在不绑定任何值的情况下运行语句。对于这些类型的操作,可以使用 DB Facade 的 unprepared 方法:
DB::unprepared('update users set votes = 100 where name = "Dries"');
请注意,这些语句不会像上面的语句那样绑定值。它们可以打开你的应用程序进行 SQL 注入,应该非常小心地使用。
隐式提交
在事务中使用 DB 外观的 statement 和 unprepared 方法时,必须小心避免导致 [隐式提交] 的语句 (https://dev.mysql.com/doc/refman/8.0/en/implicit-commit.html)。 这些语句将导致数据库引擎间接提交整个事务,从而使 Laravel 不知道数据库的事务级别。这种语句的一个例子是创建数据库表:
DB::unprepared('create table a (col varchar(1) null)');
请参考 MySQL 手册中的触发隐式提交的所有语句列表。
监听查询事件
如果你想监控程序执行的每一个 SQL 查询,你可以使用 listen 方法。这个方法对于记录查询或调试非常有用。你可以在 服务提供器 中注册你的查询监听器:
<?php namespace App\Providers; use Illuminate\Support\Facades\DB; use Illuminate\Support\ServiceProvider; class AppServiceProvider extends ServiceProvider { /** * 注册所有应用的服务 * * @return void */ public function register() { // } /** * 引导所有应用的服务 * * @return void */ public function boot() { DB::listen(function ($query) { // $query->sql // $query->bindings // $query->time }); } }
数据库事务
你可以使用 DB facade 的 transaction 方法在数据库事务中运行一组操作。如果事务的闭包 Closure 中出现一个异常,事务将会回滚。如果事务闭包 Closure 执行成功,事务将自动提交。一旦你使用了 transaction, 就不必担心手动回滚或提交的问题:
DB::transaction(function () { DB::table('users')->update(['votes' => 1]); DB::table('posts')->delete(); });
处理死锁
transaction 方法接受一个可选的第二个参数,该参数用来表示事务发生死锁时重复执行的次数。一旦定义的次数尝试完毕,就会抛出一个异常:
DB::transaction(function () { DB::table('users')->update(['votes' => 1]); DB::table('posts')->delete(); }, 5);
手动使用事务
如果你想要手动开始一个事务,并且对回滚和提交能够完全控制,那么你可以使用 DB Facade 的 beginTransaction 方法:
DB::beginTransaction();
你可以使用 rollBack 方法回滚事务:
DB::rollBack();
最后,你可以使用 commit 方法提交事务:
DB::commit();
技巧:DB facade 的事务方法同样适用于 查询构造器 和 Eloquent ORM。
连接到数据库 CLI
如果要连接到数据库的 CLI,可以使用 db Artisan 命令:
php artisan db
如果需要,可以指定数据库连接名称以连接到不是默认连接的数据库连接:
php artisan db mysql
【相关推荐:laravel视频教程】
以上是laravel支援什麼資料庫的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于单点登录的相关问题,单点登录是指在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于Laravel的生命周期相关问题,Laravel 的生命周期从public\index.php开始,从public\index.php结束,希望对大家有帮助。

在laravel中,guard是一个用于用户认证的插件;guard的作用就是处理认证判断每一个请求,从数据库中读取数据和用户输入的对比,调用是否登录过或者允许通过的,并且Guard能非常灵活的构建一套自己的认证体系。

laravel中asset()方法的用法:1、用于引入静态文件,语法为“src="{{asset(‘需要引入的文件路径’)}}"”;2、用于给当前请求的scheme前端资源生成一个url,语法为“$url = asset('前端资源')”。

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于使用中间件记录用户请求日志的相关问题,包括了创建中间件、注册中间件、记录用户访问等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于中间件的相关问题,包括了什么是中间件、自定义中间件等等,中间件为过滤进入应用的 HTTP 请求提供了一套便利的机制,下面一起来看一下,希望对大家有帮助。

laravel路由文件在“routes”目录里。Laravel中所有的路由文件定义在routes目录下,它里面的内容会自动被框架加载;该目录下默认有四个路由文件用于给不同的入口使用:web.php、api.php、console.php等。

在laravel中,fill方法是一个给Eloquent实例赋值属性的方法,该方法可以理解为用于过滤前端传输过来的与模型中对应的多余字段;当调用该方法时,会先去检测当前Model的状态,根据fillable数组的设置,Model会处于不同的状态。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)