cari
Rumahpembangunan bahagian belakangtutorial phpLaravel如何操作数据库?Laravel数据库操作的三种方式(代码)

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(&#39;delete from vipinfo where vip_ID= ?&#39;,[5]);
    echo $num;

二、数据库操作之查询构造器

laravel查询构造器提供了方便流畅的接口,用来建立及执行数据库查找语法。使用了pdo参数绑定,使应用程序免于sql注入,因此传入的参数不需要额外转义特殊字符。基本上可以满足所有的数据库操作,而且在所有支持的数据库系统上都可以执行。

1.使用查询构造器实现增删改查

同样在Student控制器里测试以下代码:

(1)新增

    $bool=DB::table("vipinfo")->insert([&#39;vip_ID&#39;=>6,&#39;vip_name&#39;=>&#39;zls&#39;,&#39;vip_type&#39;=>"出行",&#39;vip_fenshu&#39;=>800]);
    echo $bool; //返回bool值
    //如果想得到新增的id,则使用insertGetId方法
    $id=DB::table("vipinfo")->insertGetId([&#39;vip_ID&#39;=>5,&#39;vip_name&#39;=>&#39;wyp&#39;,&#39;vip_type&#39;=>"出行",&#39;vip_fenshu&#39;=>800]);
    echo $id;
    //插入多条数据
    $bool=DB::table("vipinfo")->insert([
    [&#39;vip_ID&#39;=>5,&#39;vip_name&#39;=>&#39;wyp&#39;,&#39;vip_type&#39;=>"出行",&#39;vip_fenshu&#39;=>800],
    [&#39;vip_ID&#39;=>6,&#39;vip_name&#39;=>&#39;zls&#39;,&#39;vip_type&#39;=>"出行",&#39;vip_fenshu&#39;=>800],
    ]);
    echo $bool; //返回bool值

(2)修改

$bool=DB::table("vipinfo")->where(&#39;vip_ID&#39;,6)->update([&#39;vip_fenshu&#39;=>500]);
echo $bool;
//自增
$bool=DB::table("vipinfo")->where(&#39;vip_ID&#39;,6)->increment("vip_fenshu");//自增1
$bool=DB::table("vipinfo")->where(&#39;vip_ID&#39;,6)->increment("vip_fenshu",3);//自增3
echo $bool;
//自减
$bool=DB::table("vipinfo")->where(&#39;vip_ID&#39;,6)->decrement("vip_fenshu");//自1
$bool=DB::table("vipinfo")->where(&#39;vip_ID&#39;,6)->decrement("vip_fenshu",3);//自增3
echo $bool;
//自增时再修改其他字段
$bool=DB::table("vipinfo")->where(&#39;vip_ID&#39;,6)->increment("vip_fenshu",3,[&#39;vip_name&#39;=>&#39;dbdibi&#39;]);//自增3

(3)删除

$num=DB::table("vipinfo")->where(&#39;vip_ID&#39;,6)->delete();//删除1条
$num=DB::table("vipinfo")->where(&#39;vip_ID&#39;,&#39;>&#39;,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(&#39;vip_ID&#39;,&#39;desc&#39;)->first();//按vip_ID倒序排序
var_dump($student);  
//where()条件查询
$student=DB::table("vipinfo")->where(&#39;vip_ID&#39;,&#39;>=&#39;,2)->get(); //一个条件   
$student=DB::table("vipinfo")->whereRaw(&#39;vip_ID> ? and vip_fenshu >= ?&#39;,[2,300])->get(); //多个条件
dd($student);
//pluck()指定字段,后面不加get
$student=DB::table("vipinfo")->pluck(&#39;vip_name&#39;);
dd($student);
//lists()指定字段,可以指定某个字段作为下标
$student=DB::table("vipinfo")->lists(&#39;vip_name&#39;,&#39;vip_ID&#39;);   //指定vip_ID为下标
dd($student);
$student=DB::table("vipinfo")->lists(&#39;vip_name&#39;);   //不指定下标,默认下标从0开始
//select()指定某个字段
$student=DB::table("vipinfo")->select(&#39;vip_name&#39;,&#39;vip_ID&#39;)->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= &#39;vipinfo&#39;;
//指定主键
protected $primaryKey= &#39;vip_ID&#39;;
}

在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[&#39;attributes&#39;]);//查询构造器的使用,省略了指定表名
$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=&#39;xiaoming&#39;;
    $student->vip_type=&#39;出行&#39;;
    $student->vip_fenshu=900;
    $bool=$student->save(); //保存
    echo $bool;

从数据库里取得某条记录的时间戳时,默认取得的是按日期格式化好的时间戳,如果想取得原本的时间戳,则在模型里增加asDateTime方法。

    protected function asDateTime($val){    
    return $val;
    }

(2)使用create方法新增时,需要在模型里增加:

protected $fillable=[&#39;vip_name&#39;,&#39;vip_fenshu&#39;,&#39;vip_type&#39;];   //允许批量赋值的字段

 控制器里写:

Student::create([&#39;vip_name&#39;=>&#39;mmm&#39;,&#39;vip_fenshu&#39;=>999,&#39;vip_type&#39;=>&#39;出行&#39;]);

这样即可新增成功!

(3)firstOrCreate()以属性查找记录,若没有则新增

    $student=Student::firstOrCreate([&#39;vip_name&#39;=>&#39;mmm&#39;]);
    echo $student;

(4)firstOrNew()以属性查找记录,若没有则会创建新的实例。若需要保存,则自己调用save方法()

    $student=Student::firstOrNew([&#39;vip_name&#39;=>&#39;mmm&#39;]);
    $student->save();
    echo $student;

3.  修改数据

    //通过模型更新数据
    $student=Student::find(2);
    $student->vip_fenshu=10000;
    $student->save(); //返回bool值
    //通过查询构造器更新
    $num=Student::where(&#39;vip_ID&#39;,&#39;>&#39;,2)->update([&#39;vip_fenshu&#39;=>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; //返回删除的行数

 相关推荐:

Laravel框架数据库CURD操作、连贯操作使用方法

Laravel教程之基础入门和如何操作数据库

Atas ialah kandungan terperinci Laravel如何操作数据库?Laravel数据库操作的三种方式(代码). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
PHP: Pengenalan kepada bahasa skrip sisi pelayanPHP: Pengenalan kepada bahasa skrip sisi pelayanApr 16, 2025 am 12:18 AM

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 dan Web: Meneroka kesan jangka panjangnyaPHP dan Web: Meneroka kesan jangka panjangnyaApr 16, 2025 am 12:17 AM

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.

Mengapa menggunakan PHP? Kelebihan dan faedah dijelaskanMengapa menggunakan PHP? Kelebihan dan faedah dijelaskanApr 16, 2025 am 12:16 AM

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.

Debunking the Myths: Adakah PHP benar -benar bahasa yang mati?Debunking the Myths: Adakah PHP benar -benar bahasa yang mati?Apr 16, 2025 am 12:15 AM

PHP tidak mati. 1) Komuniti PHP secara aktif menyelesaikan masalah prestasi dan keselamatan, dan Php7.x meningkatkan prestasi. 2) PHP sesuai untuk pembangunan web moden dan digunakan secara meluas di laman web besar. 3) PHP mudah dipelajari dan pelayan berfungsi dengan baik, tetapi sistem jenis tidak begitu ketat sebagai bahasa statik. 4) PHP masih penting dalam bidang pengurusan kandungan dan e-dagang, dan ekosistem terus berkembang. 5) Mengoptimumkan prestasi melalui OPCACHE dan APC, dan gunakan corak OOP dan reka bentuk untuk meningkatkan kualiti kod.

Perbahasan PHP vs Python: Mana yang lebih baik?Perbahasan PHP vs Python: Mana yang lebih baik?Apr 16, 2025 am 12:03 AM

PHP dan Python mempunyai kelebihan dan kekurangan mereka sendiri, dan pilihannya bergantung kepada keperluan projek. 1) PHP sesuai untuk pembangunan web, mudah dipelajari, sumber komuniti yang kaya, tetapi sintaks tidak cukup moden, dan prestasi dan keselamatan perlu diberi perhatian. 2) Python sesuai untuk sains data dan pembelajaran mesin, dengan sintaks ringkas dan mudah dipelajari, tetapi terdapat kesesakan dalam kelajuan pelaksanaan dan pengurusan memori.

Tujuan PHP: Membina Laman Web DinamikTujuan PHP: Membina Laman Web DinamikApr 15, 2025 am 12:18 AM

PHP digunakan untuk membina laman web dinamik, dan fungsi terasnya termasuk: 1. Menjana kandungan dinamik dan menghasilkan laman web secara real time dengan menyambung dengan pangkalan data; 2. Proses Interaksi Pengguna dan Penyerahan Bentuk, Sahkan Input dan Menanggapi Operasi; 3. Menguruskan sesi dan pengesahan pengguna untuk memberikan pengalaman yang diperibadikan; 4. Mengoptimumkan prestasi dan ikuti amalan terbaik untuk meningkatkan kecekapan dan keselamatan laman web.

PHP: Pengendalian pangkalan data dan logik sisi pelayanPHP: Pengendalian pangkalan data dan logik sisi pelayanApr 15, 2025 am 12:15 AM

PHP menggunakan sambungan MySQLI dan PDO untuk berinteraksi dalam operasi pangkalan data dan pemprosesan logik sisi pelayan, dan memproses logik sisi pelayan melalui fungsi seperti pengurusan sesi. 1) Gunakan MySQLI atau PDO untuk menyambung ke pangkalan data dan laksanakan pertanyaan SQL. 2) Mengendalikan permintaan HTTP dan status pengguna melalui pengurusan sesi dan fungsi lain. 3) Gunakan urus niaga untuk memastikan atomik operasi pangkalan data. 4) Mencegah suntikan SQL, gunakan pengendalian pengecualian dan sambungan penutup untuk debugging. 5) Mengoptimumkan prestasi melalui pengindeksan dan cache, tulis kod yang sangat mudah dibaca dan lakukan pengendalian ralat.

Bagaimana anda menghalang suntikan SQL di PHP? (Penyataan yang disediakan, PDO)Bagaimana anda menghalang suntikan SQL di PHP? (Penyataan yang disediakan, PDO)Apr 15, 2025 am 12:15 AM

Menggunakan penyataan preprocessing dan PDO dalam PHP secara berkesan dapat mencegah serangan suntikan SQL. 1) Gunakan PDO untuk menyambung ke pangkalan data dan tetapkan mod ralat. 2) Buat kenyataan pra -proses melalui kaedah menyediakan dan lulus data menggunakan ruang letak dan laksanakan kaedah. 3) Hasil pertanyaan proses dan pastikan keselamatan dan prestasi kod.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

mPDF

mPDF

mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.