Laravel是PHP Web开发框架(PHP Web Framework)。它可以让你从杂乱的代码中解脱出来;它可以帮你构建一个完美的网络APP,而且每行代码都可以简洁、富于表达力。那么,laravel框架是如何操作数据库的呢?请看一下具体的内容。
Laravel提供了3种操作数据库方式:DB facade(原始方式)、查询构造器和Eloquent ORM。
数据库的配置文件在config目录下的database.php里。打开这个文件,找到mysql的配置项。
这里有个env,它其实是调用了laravel根目录下的.env文件,这个文件存储了Laravel 数据库配置的信息。打开它。修改为项目的数据库信息即可。
请自行建一个数据库,其中数据库得包含vipinfo表,并且插入一些数据,以方便下面使用。表的结构如下图。
顾名思义:这张表是会员表,分别有会员ID(主键),会员名字,会员类型,会员积分等字段。
一、数据库操作之DB facade
在app->Http->Controllers目录下新建一个Student控制器,StudentController.php。 StudentController.php代码如下:
<?php namespace App\Http\Controllers; use Illuminate\Support\Facades\DB;class StudentController extends Controller { }
1.laravel 数据库查询
在Student控制器里添加一个test1方法,查询用的是DB类的静态方法select(),参数是原生的sql语句,返回的是一个二维数组。dd()是laravel提供的方法,可以将一个数组以节点树的形式展示出来。具体代码如下:
public function test1() { $student=DB::select("select * from vipinfo"); //返回一个二维数组 $student var_dump($student); //以节点树的形式输出结果 dd($student); }
路由配置: Route::get('test1',['uses'=>'StudentController@test1']);
URL访问:http://localhost/laravel/public/index.php/test1 ,则会打印出结果。
2.新增操作
新增使用的是DB类的静态方法insert(),第一个参数是sql语句,第二个参数是一个数组,数组里放要插入的数据。这里?是占位符,通过数据库接口层pdo的方式,达到防sql注入的目的。返回的是执行的结果。插入成功则返回true,否则为false。
public function test1() { $student=DB::select("select * from vipinfo"); //返回一个二维数组 $student var_dump($student); //以节点树的形式输出结果 dd($student); }
3. 更新操作
更新使用的是DB类的静态方法update(),第一个参数是sql语句,第二个参数是一个数组,数组里的元素分别对应sql语句里的问号。更新成功返回true。
$bool=DB::update('update vipinfo set vip_fenshu= ? where vip_ID= ? ',[700,5]); var_dump($bool); //更新成功返回true
4. 删除操作
删除使用的是DB类的静态方法delete(),第一个参数是sql语句,第二个参数是一个数组,数组里的元素分别对应sql语句里的问号。返回的是删除的行数。
$num=DB::delete('delete from vipinfo where vip_ID= ?',[5]); echo $num;
二、数据库操作之查询构造器
laravel查询构造器提供了方便流畅的接口,用来建立及执行数据库查找语法。使用了pdo参数绑定,使应用程序免于sql注入,因此传入的参数不需要额外转义特殊字符。基本上可以满足所有的数据库操作,而且在所有支持的数据库系统上都可以执行。
1.使用查询构造器实现增删改查
同样在Student控制器里测试以下代码:
(1)新增
$bool=DB::table("vipinfo")->insert(['vip_ID'=>6,'vip_name'=>'zls','vip_type'=>"出行",'vip_fenshu'=>800]); echo $bool; //返回bool值 //如果想得到新增的id,则使用insertGetId方法 $id=DB::table("vipinfo")->insertGetId(['vip_ID'=>5,'vip_name'=>'wyp','vip_type'=>"出行",'vip_fenshu'=>800]); echo $id; //插入多条数据 $bool=DB::table("vipinfo")->insert([ ['vip_ID'=>5,'vip_name'=>'wyp','vip_type'=>"出行",'vip_fenshu'=>800], ['vip_ID'=>6,'vip_name'=>'zls','vip_type'=>"出行",'vip_fenshu'=>800], ]); echo $bool; //返回bool值
(2)修改
$bool=DB::table("vipinfo")->where('vip_ID',6)->update(['vip_fenshu'=>500]); echo $bool; //自增 $bool=DB::table("vipinfo")->where('vip_ID',6)->increment("vip_fenshu");//自增1 $bool=DB::table("vipinfo")->where('vip_ID',6)->increment("vip_fenshu",3);//自增3 echo $bool; //自减 $bool=DB::table("vipinfo")->where('vip_ID',6)->decrement("vip_fenshu");//自1 $bool=DB::table("vipinfo")->where('vip_ID',6)->decrement("vip_fenshu",3);//自增3 echo $bool; //自增时再修改其他字段 $bool=DB::table("vipinfo")->where('vip_ID',6)->increment("vip_fenshu",3,['vip_name'=>'dbdibi']);//自增3
(3)删除
$num=DB::table("vipinfo")->where('vip_ID',6)->delete();//删除1条 $num=DB::table("vipinfo")->where('vip_ID','>',4)->delete();//删除多条 echo $num; //删除的行数 $num=DB::table("vipinfo")->truncate();//删除整表,不能恢复,谨慎使用
(4)查询
//get()返回多条数据 $student=DB::table("vipinfo")->get(); var_dump($student); //first()返回1条数据 $student=DB::table("vipinfo")->first(); //结果集第一条记录 $student=DB::table("vipinfo")->orderBy('vip_ID','desc')->first();//按vip_ID倒序排序 var_dump($student); //where()条件查询 $student=DB::table("vipinfo")->where('vip_ID','>=',2)->get(); //一个条件 $student=DB::table("vipinfo")->whereRaw('vip_ID> ? and vip_fenshu >= ?',[2,300])->get(); //多个条件 dd($student); //pluck()指定字段,后面不加get $student=DB::table("vipinfo")->pluck('vip_name'); dd($student); //lists()指定字段,可以指定某个字段作为下标 $student=DB::table("vipinfo")->lists('vip_name','vip_ID'); //指定vip_ID为下标 dd($student); $student=DB::table("vipinfo")->lists('vip_name'); //不指定下标,默认下标从0开始 //select()指定某个字段 $student=DB::table("vipinfo")->select('vip_name','vip_ID')->get(); dd($student); //chunk()每次查n条 $student=DB::table("vipinfo")->chunk(2,function($students){ //每次查2条 var_dump($students); if(.......) return false; //在满足某个条件下使用return就不会再往下查了 });
2.使用聚合函数
//count()统计记录条数$nums=DB::table("vipinfo")->count(); echo $nums;//max()某个字段的最大值,同理min是最小值$max=DB::table("vipinfo")->max("vip_fenshu"); echo $max;//avg()某个字段的平均值$avg=DB::table("vipinfo")->avg("vip_fenshu"); echo $avg;//sum()某个字段的和$sum=DB::table("vipinfo")->sum("vip_fenshu"); echo $sum;
四、数据库操作之 - Eloquent ORM
1.简介、模型的建立及查询数据
简介:laravel所自带的Eloquent ORM 是一个ActiveRecord实现,用于数据库操作。每个数据表都有一个与之对应的模型,用于数据表交互。
建立模型,在app目录下建立一个Student模型,即Student.php,不需要带任何后缀。
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Student extends Model{ //指定表名 protected $table= 'vipinfo'; //指定主键 protected $primaryKey= 'vip_ID'; }
在Student控制器里增加一个test3方法,配置路由Route::get('test3',['uses'=>'StudentController@test3']);
public function test3(){// all()方法查询所有数据$studnets=Student::all(); dd($studnets);//find()查询一条,依据主键查询。findOrFail()查找不存在的记录时会抛出异常 $student=Student::find(5); //主键为5的记录 var_dump($student['attributes']);//查询构造器的使用,省略了指定表名 $student=Student::get(); var_dump($student); }
2 . 新增数据、自定义时间戳、批量赋值
(1)使用save方法新增
laravel会默认维护created_at,updated_at 两个字段,这两个字段都是存储时间戳,整型11位的,因此使用时需要在数据库添加这两个字段。如果不需要这个功能,只需要在模型里加一个属性:public $timestamps=false; 以及一个方法,可以将当前时间戳存到数据库
protected function getDateFormat(){ return time(); }
这样就不需要那两个字段了。
控制器里写:
$student=new Student(); //设定数据 $student->vip_name='xiaoming'; $student->vip_type='出行'; $student->vip_fenshu=900; $bool=$student->save(); //保存 echo $bool;
从数据库里取得某条记录的时间戳时,默认取得的是按日期格式化好的时间戳,如果想取得原本的时间戳,则在模型里增加asDateTime方法。
protected function asDateTime($val){ return $val; }
(2)使用create方法新增时,需要在模型里增加:
protected $fillable=['vip_name','vip_fenshu','vip_type']; //允许批量赋值的字段
控制器里写:
Student::create(['vip_name'=>'mmm','vip_fenshu'=>999,'vip_type'=>'出行']);
这样即可新增成功!
(3)firstOrCreate()以属性查找记录,若没有则新增
$student=Student::firstOrCreate(['vip_name'=>'mmm']); echo $student;
(4)firstOrNew()以属性查找记录,若没有则会创建新的实例。若需要保存,则自己调用save方法()
$student=Student::firstOrNew(['vip_name'=>'mmm']); $student->save(); echo $student;
3. 修改数据
//通过模型更新数据 $student=Student::find(2); $student->vip_fenshu=10000; $student->save(); //返回bool值 //通过查询构造器更新 $num=Student::where('vip_ID','>',2)->update(['vip_fenshu'=>2000]); echo $num; //返回更新的行数
4. 删除数据
//(1)通过模型删除数据 $student=Student::find(11); $student->delete(); //返回bool值 //(2)通过主键删除 $num=Student::destroy(10); //删除主键为10的一条记录 echo $num; //返回删除的行数 $num=Student::destroy(10,5); //删除多条 或者$num=Student::destroy([10,5]); echo $num; //返回删除的行数
相关推荐:
Atas ialah kandungan terperinci Laravel如何操作数据库?Laravel数据库操作的三种方式(代码). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Jenis PHP meminta untuk meningkatkan kualiti kod dan kebolehbacaan. 1) Petua Jenis Skalar: Oleh kerana Php7.0, jenis data asas dibenarkan untuk ditentukan dalam parameter fungsi, seperti INT, Float, dan lain -lain. 2) Return Type Prompt: Pastikan konsistensi jenis nilai pulangan fungsi. 3) Jenis Kesatuan Prompt: Oleh kerana Php8.0, pelbagai jenis dibenarkan untuk ditentukan dalam parameter fungsi atau nilai pulangan. 4) Prompt jenis yang boleh dibatalkan: membolehkan untuk memasukkan nilai null dan mengendalikan fungsi yang boleh mengembalikan nilai null.

Dalam PHP, gunakan kata kunci klon untuk membuat salinan objek dan menyesuaikan tingkah laku pengklonan melalui kaedah Magic \ _ _ _. 1. Gunakan kata kunci klon untuk membuat salinan cetek, mengkloning sifat objek tetapi bukan sifat objek. 2. Kaedah klon \ _ \ _ boleh menyalin objek bersarang untuk mengelakkan masalah menyalin cetek. 3. Beri perhatian untuk mengelakkan rujukan pekeliling dan masalah prestasi dalam pengklonan, dan mengoptimumkan operasi pengklonan untuk meningkatkan kecekapan.

PHP sesuai untuk pembangunan web dan sistem pengurusan kandungan, dan Python sesuai untuk sains data, pembelajaran mesin dan skrip automasi. 1.PHP berfungsi dengan baik dalam membina laman web dan aplikasi yang cepat dan berskala dan biasanya digunakan dalam CMS seperti WordPress. 2. Python telah melakukan yang luar biasa dalam bidang sains data dan pembelajaran mesin, dengan perpustakaan yang kaya seperti numpy dan tensorflow.

Pemain utama dalam tajuk cache HTTP termasuk kawalan cache, ETAG, dan modifikasi terakhir. 1.Cache-Control digunakan untuk mengawal dasar caching. Contoh: Cache-Control: Max-Age = 3600, Awam. 2. ETAG mengesahkan perubahan sumber melalui pengenal unik, Contoh: ETAG: "686897696A7C876B7E". 3. Modified Last Menunjukkan Masa Pengubahsuaian Terakhir Sumber, Contoh: Modified Last: Wed, 21OCT201507: 28: 00GMT.

Dalam php, kata laluan_hash dan kata laluan 1) password_hash menjana hash yang mengandungi nilai garam untuk meningkatkan keselamatan. 2) Kata Laluan_verify Sahkan kata laluan dan pastikan keselamatan dengan membandingkan nilai hash. 3) MD5 dan SHA1 terdedah dan kekurangan nilai garam, dan tidak sesuai untuk keselamatan kata laluan moden.

PHP adalah bahasa skrip sisi pelayan yang digunakan untuk pembangunan web dinamik dan aplikasi sisi pelayan. 1.Php adalah bahasa yang ditafsirkan yang tidak memerlukan kompilasi dan sesuai untuk perkembangan pesat. 2. Kod PHP tertanam dalam HTML, menjadikannya mudah untuk membangunkan laman web. 3. PHP memproses logik sisi pelayan, menghasilkan output HTML, dan menyokong interaksi pengguna dan pemprosesan data. 4. PHP boleh berinteraksi dengan pangkalan data, penyerahan borang proses, dan melaksanakan tugas-tugas sampingan pelayan.

PHP telah membentuk rangkaian sejak beberapa dekad yang lalu dan akan terus memainkan peranan penting dalam pembangunan web. 1) PHP berasal pada tahun 1994 dan telah menjadi pilihan pertama bagi pemaju kerana kemudahan penggunaannya dan integrasi lancar dengan MySQL. 2) Fungsi terasnya termasuk menghasilkan kandungan dinamik dan mengintegrasikan dengan pangkalan data, yang membolehkan laman web dikemas kini secara real time dan dipaparkan secara peribadi. 3) Aplikasi dan ekosistem PHP yang luas telah mendorong kesan jangka panjangnya, tetapi ia juga menghadapi kemas kini versi dan cabaran keselamatan. 4) Penambahbaikan prestasi dalam beberapa tahun kebelakangan ini, seperti pembebasan Php7, membolehkannya bersaing dengan bahasa moden. 5) Pada masa akan datang, PHP perlu menangani cabaran baru seperti kontena dan microservices, tetapi fleksibiliti dan komuniti aktif menjadikannya boleh disesuaikan.

Manfaat utama PHP termasuk kemudahan pembelajaran, sokongan pembangunan web yang kukuh, perpustakaan dan kerangka yang kaya, prestasi tinggi dan skalabilitas, keserasian silang platform, dan keberkesanan kos. 1) mudah dipelajari dan digunakan, sesuai untuk pemula; 2) integrasi yang baik dengan pelayan web dan menyokong pelbagai pangkalan data; 3) mempunyai rangka kerja yang kuat seperti Laravel; 4) Prestasi tinggi dapat dicapai melalui pengoptimuman; 5) menyokong pelbagai sistem operasi; 6) Sumber terbuka untuk mengurangkan kos pembangunan.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft