laravel 操作数据库一般都使用它的Eloquent ORM才操作

建立模型
<?php
namespace App; use Illuminate\Database\Eloquent\Model; class Student extends Model
{
//指定表名 默认 模型名的复数
protected $table='student'; //指定主键 默认主键 为ID
protected $primaryKey='id'; //指定允许批量赋值的字段
protected $fillable=['name','age'];
//指定不允许批量赋值的字段
protected $guarded=[]; //是否维护时间戳 默认维护
//$timestamps=falst 不维护
public $timestamps=true; //维护时间的时候保存时间戳
protected function getDateFormat()
{
return time(); // TODO: Change the autogenerated stub
} //查询的时候返回时间戳
protected function asDateTime($value)
{
// return parent::asDateTime($value); // TODO: Change the autogenerated stub
return $value;
}
}

  

ORM 查询
//all() 查询所有数据  查询数据为集合
$students=Student::all();
dd($students); //根据主键查询 查询一条数据
$student=Student::find(2);
dd($student); //findOrFail() 根据主键查询 如果没有查到 报错
$student=Student::findOrFail(2);
dd($student); //get() 查询所有数据
$students=Student::get();
dd($students); //first() 查询第一条
$students=Student::where('id','>','1')->orderBy('age','desc')->first();
dd($students); //chunk() 每次查询一定条数
Student::chunk(2,function($students){
var_dump($students);
}); //聚合函数
//count() 条数
$num = Student::count();
var_dump($num); //max() 查询最大值
$max=Student::where('id','>',1)->max('age');
var_dump($max);
添加
//新增
//save()
$student=new Student();
$student->name='vbb';
$student->age=34;
$rs=$student->save();
dd($rs); //create()
$rs=Student::create([
'name'=>'momo',
'age'=>23
]);
dd($rs); //firstOrCreate()以属性查询数据 如果没有 新建数据
$rs=Student::firstOrCreate(
['name'=>'vbb4']
); //firstOrNew() 以属性查询数据 如果没有 新建实例 如果想保存调用save()
$rs=Student::firstOrNew(
['name'=>'vbb4']
);
$bool=$rs->save(); dd($rs);
更新
//更新
//通过模型更新数据
$student=Student::find(2);
$student->age=2;
$bool=$student->save();
var_dump($bool); //批量更新
$num=Student::where('id','>',5)->update(
['age'=>41]
);
var_dump($num);
删除
//删除
//通过模型删除
$student=Student::find(2);
$bool=$student->delete();
var_dump($bool); //通过主键删除
$num=Student::destroy(3,4,5);
$num=Student::destroy([3,4,5]);
var_dump($num); //删除指定条件
$num=Student::where('id','>',7)->delete();
var_dump($num);

Laravel 数据库操作 Eloquent ORM的更多相关文章

  1. Laravel数据库操作 Eloquent ORM

    模型首先在App目录下建立student的文件夹 里面放上 Student.php 且需要继承基类Model //允许批量赋值的字段// protected $fillable = ['name',' ...

  2. Laravel 学习笔记之数据库操作——Eloquent ORM

    1. 时间戳 默认情况下在使用ORM操作数据库进行添加.修改数据时, created_at 和 updated_at列会自动存在于数据表中,并显示的是 ‘2017’格式,如果想以 Unix时间戳格式存 ...

  3. [转]Laravel 4之Eloquent ORM

    Laravel 4之Eloquent ORM http://dingjiannan.com/2013/laravel-eloquent/ 定义Eloquent模型 模型通常放在app/models目录 ...

  4. Laravel—数据库操作与Eloquent模型使用总结

    数据库操作 执行原生SQL //查询 $emp = DB::select('select * from employees where emp_no = 1'); $emp = DB::select( ...

  5. [ Laravel 5.6 文档 ]laravel数据库操作分页(自定义分页实现和自定义分页样式)

    简介 在其他框架中,分页可能是件非常痛苦的事,Laravel 让这件事变得简单.易于上手.Laravel 的分页器与查询构建器和 Eloquent ORM 集成在一起,并开箱提供方便的.易于使用的.基 ...

  6. laravel 数据库操作

    1 配置信息 1.1配置目录: config/database.php 1.2配置多个数据库 //默认的数据库 'mysql' => [ 'driver' => 'mysql', 'hos ...

  7. laravel 数据库操作之 DB facade & 查询构造器 & Eloquent ORM

    <?php namespace App\Http\Controllers; use App\Student; use Illuminate\Support\Facades\DB; class S ...

  8. Laravel 数据库操作之Eloquent ORM模型

    //模型中的相关代码 namespace App; use Illuminate\Database\Eloquent\Model; class Student extends Model{ //默认对 ...

  9. laravel数据库操作sql语句用Eloquent ORM来构造

    现在有查询语句: SELECT users.sNmame, users.iCreateTime, users_ext.iAge, users_ext.sSex FROM users LEFT JOIN ...

随机推荐

  1. 微信技术分享:微信的海量IM聊天消息序列号生成实践(算法原理篇)

    1.点评 对于IM系统来说,如何做到IM聊天消息离线差异拉取(差异拉取是为了节省流量).消息多端同步.消息顺序保证等,是典型的IM技术难点. 就像即时通讯网整理的以下IM开发干货系列一样: <I ...

  2. Android WebView 实现网页缩放

    需要对WebView设置的内容如下: //缩放开关,设置此属性,仅支持双击缩放,不支持触摸缩放 mWebView.getSettings().setSupportZoom(true); //设置是否可 ...

  3. Git使用详细教程(6):git mv重命名文件

    与使用git rm类似,Git还提供了重命名文件的命令git mv,我们可以通过该命令重命名文件. 如下图,git mv包含了以下动作

  4. system libzip must be upgraded to version >= 0.11

    PHP当前最新版本是PHP7.3,今天在尝试安装的过程中报如下错误: system libzip must be upgraded to version >= 0.11, 根据提示我们可以清楚的 ...

  5. Kali学习笔记35:使用VBScript、PowerShell、DEBUG传输文件

    其实VBScript只是一个工具 本质是开启http服务提供下载的 首先我们开启http服务:阿帕奇 然后给上传一个文件做演示: 接下来就是编写VBScript: 这些内容全部输入完成之后: 传输 早 ...

  6. Kali学习笔记9:端口扫描详解(上)

    UDP端口扫描: 原理:回应ICMP不可达,代表端口关闭:没有回应,端口开启 建议了解应用层的UDP包头结构,构建对应的UDP数据包用来提高准确度 另外:所有的扫描都存在误判情况 我们用Scapy写个 ...

  7. GitHub 近 100,000 程序员“起义”:向“996”开炮!

    作者 | 伍杏玲 出品 | 程序人生(ID:coder_life) 平常CSDN推送关于程序员加班的文章时,很多程序员边吐槽边调侃地留言“比拼”:“我们也是996”.“007来报道”…… 可在简单的数 ...

  8. 机器学习入门04 - 使用TensorFlow的起始步骤 (First Steps with TensorFlow)

    原文链接:https://developers.google.com/machine-learning/crash-course/first-steps-with-tensorflow/ 1- 工具包 ...

  9. Mac OS Sierra如何打开任何来源

    我们知道在Mac升级到最新的Mac OS Sierra系统之后,随之而来的是第三方应用都无法打开,提示的是无法打开或扔进废纸篓.而在之前的版本系统中,我们知道在系统偏好设置-->安全性与隐私-- ...

  10. Java的优点

    前几天面试被问到:“Java的优点有哪些?”,当时只回答了跨平台和解释型两点,做的并不是太好,所以今天小编就总结一下Java的几大优点,增加自己的知识储备. 1.跨平台性: Java通过自带的JVM实 ...