Laravel 数据库操作 Eloquent ORM
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的更多相关文章
- Laravel数据库操作 Eloquent ORM
模型首先在App目录下建立student的文件夹 里面放上 Student.php 且需要继承基类Model //允许批量赋值的字段// protected $fillable = ['name',' ...
- Laravel 学习笔记之数据库操作——Eloquent ORM
1. 时间戳 默认情况下在使用ORM操作数据库进行添加.修改数据时, created_at 和 updated_at列会自动存在于数据表中,并显示的是 ‘2017’格式,如果想以 Unix时间戳格式存 ...
- [转]Laravel 4之Eloquent ORM
Laravel 4之Eloquent ORM http://dingjiannan.com/2013/laravel-eloquent/ 定义Eloquent模型 模型通常放在app/models目录 ...
- Laravel—数据库操作与Eloquent模型使用总结
数据库操作 执行原生SQL //查询 $emp = DB::select('select * from employees where emp_no = 1'); $emp = DB::select( ...
- [ Laravel 5.6 文档 ]laravel数据库操作分页(自定义分页实现和自定义分页样式)
简介 在其他框架中,分页可能是件非常痛苦的事,Laravel 让这件事变得简单.易于上手.Laravel 的分页器与查询构建器和 Eloquent ORM 集成在一起,并开箱提供方便的.易于使用的.基 ...
- laravel 数据库操作
1 配置信息 1.1配置目录: config/database.php 1.2配置多个数据库 //默认的数据库 'mysql' => [ 'driver' => 'mysql', 'hos ...
- laravel 数据库操作之 DB facade & 查询构造器 & Eloquent ORM
<?php namespace App\Http\Controllers; use App\Student; use Illuminate\Support\Facades\DB; class S ...
- Laravel 数据库操作之Eloquent ORM模型
//模型中的相关代码 namespace App; use Illuminate\Database\Eloquent\Model; class Student extends Model{ //默认对 ...
- laravel数据库操作sql语句用Eloquent ORM来构造
现在有查询语句: SELECT users.sNmame, users.iCreateTime, users_ext.iAge, users_ext.sSex FROM users LEFT JOIN ...
随机推荐
- AJAX从入门到放弃(二)
XHR 响应 由 driventokill 创建,路飞 最后一次修改 2015-09-25 AJAX - 服务器 响应 由于 HTTP 响应是由服务端发出的,并且服务器做出响应需要时间(比如网速慢等原 ...
- MapReduce多种join实现实例分析(一)
一.概述 对于RDBMS中的join操作大伙一定非常熟悉,写sql的时候要十分注意细节,稍有差池就会耗时巨久造成很大的性能瓶颈,而在Hadoop中使用MapReduce框架进行join的操作时同 ...
- 【面试必备】常见Java面试题大综合
一.Java基础 1.Arrays.sort实现原理和Collections.sort实现原理答:Collections.sort方法底层会调用Arrays.sort方法,底层实现都是TimeSort ...
- ProgressBar 进度条开源项目总结
在Android开发中,我们不免会遇到进度条展示的需求,以下是本人之前star的开源项目,供大家参考: 一.ArcProgressBar 开源项目地址:https://github.com/zenoT ...
- linux创建用户并设置密码
1.在root权限下,useradd只是创建了一个用户名,如(useradd+用户名),它并没有在/home目录下创建同名文件夹,也没有创建密码,因此利用这个用户登录系统,是登录不了的,为了避免这样的 ...
- 微信小程序提交审核并发布详细流程
微信小程序提交审核并发布详细流程 审核在1小时到N天不等 官方7天,一般3天内 提交审核?如何发布?审核过程中注意事项? 服务器: 域名只支持 https (request.uploadFile.do ...
- netty入门(一)
1. netty入门(一) 1.1. 传统socket编程 在任何时候都可能有大量的线程处于休眠状态,只是等待输入或者输出数据就绪,这可能算是一种资源浪费. 需要为每个线程的调用栈都分配内存,其默认值 ...
- Python文件操作与函数目录
文件操作 python文件操作 函数 Python函数学习——初步认识 Python函数学习——作用域与嵌套函数 Python函数学习——匿名函数 python内置函数 Python函数学习——递归 ...
- document.getElementsByClassName返回的是一个数组
转载自:https://www.cnblogs.com/shark1100913/p/6713327.html document.getElementsByClassName("a&qu ...
- python搭建web服务
import json from urlparse import parse_qs from wsgiref.simple_server import make_server import os im ...