首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【Laravel系列4.3】模型Eloquent ORM的使用(一)

Active Record 中文的意思是活动记录,特点是一个模型类对应数据库中的一个表。...赶紧查看错误信息,竟然是这个 laravel.m_tests 表不存在。小伙伴们不要惊讶,在这里出错是正常的,为什么呢?...对于 Laravel 中标准的 Eloquent 模型类来说,每个表都应该有两个字段,一个是 updated_at ,另一个是 created_at ,分别是两个时间戳字段,用于记录数据的创建时间和修改时间...其实所有的表最好都有这两个字段,而且很多后台管理系统中还需要有 创建人 和 修改人 的记录。它们的目的都是为了数据的安全和记录可追溯。...其实这段代码已经很清楚明了了,如果没有 key 就返回一个空的内容,如果 key 存在于当前这个模型类的相关属性中,则调用一些处理方法后返回。

8.9K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    30分钟用Laravel实现一个博客

    Laravel的优点在于:丰富的composer类库支持, 优雅的代码, 未来的主流框架(目前市场占有率最高的框架) Laravel的缺点在于:过于优雅(我们只需要编写极少的代码即可实现功能,意味着底层极其复杂的封装...主要解释一下 migrations 表: 这是一个记录你的迁移文件名称和批次的表。...它的主要作用是通过记录批次,方便你对数据库进行版本控制:打开 migrations表,你会发现,当前记录了4张表的迁移文件名,而他们的batch都是1,你可以理解为当前数据库是第一批,版本1。...总结 => 路由定义在浏览器中访问某控制器中某方法的地址,控制器完成一系列操作:如果需要操作数据库,需要调用模型,每一个模型对应一张表。...第三阶段总结 我们使用命令创建了一个 “资源控制器” 我们在 /routes/web.php 定义了一条资源路由 我们使用 BlogController 中的7个方法完成了对 博客文章 的 CURD(增删改查

    7.4K00

    Laravel5.5 session 的配置及使用示例讲解

    提示信息 首先,如果在 Laravel 中使用 session 功能,需要明确以下的知识点: Laravel 并没有使用 PHP 内置的 Session 功能,而且自己实现了一套更加灵活更加强大的 Session...机制,核心逻辑请参考 Illuminate\Session\Middleware\StartSession这个中间件,因此在 Laravel 应用中不要试图通过$_SESSION方式去获取应用的 Session...驱动方式的配置 SESSION_DRIVER=database 此时进行页面的访问,数据表会被插入一条数据,且不同的浏览器打开网站时,都会增加一条: ?...并且字段 user_id 没有赋值 每次页面刷新或跳转,在时效内,都会进行更新,唯一不变的是 id 不变,待到有效期过后或者更换浏览器再增加新的记录....通过网上信息搜索,基本的观点就是 CSRF的禁用限制,最简单的方式就是禁用 CSRF,可以参考文章(Laravel VerifyCsrfToken 报错解决),我选择了其中的一种. ?

    1.4K10

    通过 Laravel 查询构建器实现简单的增删改查操作

    通过前面几篇教程的预热,我们已经连接上数据库,创建好了数据表,填充好了数据,接下来,就是在 Laravel 应用中实现对数据库的增删改查了。...`name` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL)'); 只不过在 Laravel 中,我们不推荐这么做,因为这些对数据表结构的操作可以通过数据库迁移功能来实现...原生插入语句 想要在数据库中插入一条记录,通过 DB 门面提供的 insert 语句即可: $name = str_random(10); $email = str_random(10) . '@163..., [$id]); 和更新语句一样,如果删除成功,该方法返回受影响行数,删除记录不存在,返回 0,删除出错,抛出 QueryException 异常。...如果我们想要清空整张数据表,可以通过不指定 where 条件来实现: $affectedRows = DB::table('users')->delete(); 如果我们还想在清空记录之后重置自增 ID

    4.2K20

    3分钟短文:Laravel模型创建数据条目的2个语法糖

    [img] 本期我们开始讲模型中,如何插入新条目,或者更新既有条目。...一般地,使用面向对象的方式创建一条新的数据,可以这样来写: $event = new Event; $event->name = 'Coffee and Laravel'; $event->venue...我们在表中还有id字段,created_at字段,updated_at字段,并没有显式赋值。但是你打开数据库表查看结果的时候,发现那些值也成功的写入了。...新建 or 更新 接着介绍laravel模型的几个语法糖。一个常规的场景,比如在写入数据时,先判断数据库表内是否有该条记录,如果没有就创建,如何有则返回。...' => 'Dublin']); 如果 name 字段已存在,就返回第一条数据;如果不存在,就是用第二个数组写入。

    1.9K00

    Laravel学习记录--Model

    使用渴求式加载,即根据预先需求查询出所有数据 为了验证[渴求式加载]的好处,举下列例子 这里用到了Laravel Debugbar 调试 安装方法可参照我的另一个博客 - - - Laravel...该循环先执行1次查询获取表中的所有的文章,然后另一个查询获取每一篇文章的作者,因此如果有6个作者,则会执行7次查询,1次是获取文章,剩下的6次获取文章作者。...,并且没有放在数组里的id会被移除,如果是这样的话那1号学生选修的课程1将被移除,同时会向中间表添加课程id=9的记录 接下来看他的执行过程是否与我们想的一样 通过Laravel Debugbar...的附加状态,意思就是如果toggle里面的id存在于中间表,则被移除,如果不存在则会被添加 public function show(){ $stu=Stu::find(1);...有时候你需要更新中间表中已经存在的记录,使用updateExistingPivot方法 该方法接受中间记录另一个的外键和一个关联数组进行更新 public function show(){

    13.6K20

    Laravel和Thinkphp有什么区别,哪个框架好用

    7、加密方式 在TP框架中,我们对用户名密码进行加密时使用md5();的方式进行加密。...但md5的缺点在于其可以逆向破解,而且在同等规则下同样的密码md5加密出的字符串是有可能出现相同的,这就降低其安全性。...你可以通过模型查找数据表内的数据,以及将记录添加到数据表中。)...本人在实际使用中也实实在在的感受到了通过创造模型对数据表操作带来的便利,譬如:批量赋值,跨表查询,删除模型和软删除,模型关联,当然这些在TP框架中也可以利用模型实现。...laravel和thinkphp哪个框架好用 thinkphp,采用mvc思想开发,它活动范围主要是国内,而且完全免费开源,学习资料非常丰富,对于新手来说是学习php框架最佳的选择,主要还是都是中文文档

    6.1K20

    通过 Laravel Eloquent 模型实现简单增删改查操作

    ,其字段名为 id,如果你的数据表主键名不是 id,可以通过 $primaryKey 属性来指定: protected $primaryKey = 'post_id'; 如果主键不是自增的,还可以设置...: $user = User::findOrFail(111); 如果 id=111 的记录在 users 数据表中不存在,就会返回 404 响应: ?...')->max('id'); # 最大值 你会发现,如果你掌握了查询构建器,就等同于掌握了 Laravel 中的所有数据库查询操作。...执行上面的代码就会在数据库新增一条记录(我们在 Tinker 中执行上述代码): ? 我们先要创建一个新的 Post 模型实例,然后依次设置需要设置的字段,最后调用 save 方法保存即可。...同样,Eloquent 也为我们提供了快捷的更新方法 updateOrCreate,该方法首先会根据传入参数对模型对应记录进行更新,如果发现对应记录不存在,则会将更新数据作为初始数据插入数据库,并保存(

    8K20

    Laravel代码简洁之道和性能优化

    如果互相喜欢,则添加双向联系人关系,插入之前校验是否存在,存在则更新type等字段,不存在则插入双向数据 我们通过这个场景能非常好的体会laravel-upsert的强大,不仅减少了代码量,也减少了sql...列的表: Schema :: create ( 'users' , function ( Blueprint $ table ) { $ table -> increments ( 'id'...作为使用复合键和原始表达式的示例,请考虑以下表,该表计算每个帖子和每天的访问者: Schema :: create ( 'stats' , function ( Blueprint $ table )...Integer ( 'views' ); $表->主要([ 'post_id','date' ]); }); 使用upsert()登录访问。...该查询将为每个帖子和日期创建一个新记录或增加现有的查看计数器: DB :: table ( 'stats' )-> upsert ( [ [ 'post_id' => 1 , '

    5.8K20

    还得再来聊聊Laravel中的对多对模型的一些事

    确实看laravel的中文文档,看得糊里糊涂的。还是得在实践中理解啊。 情景假设 我有一张来源表(referers)来记录href和网页标题title。...还有一张信息表(netDisks)来记录一些东西。 目前需求是信息表里面的多个信息可能同属于来源表中的一条记录。 同样,来源表中的多条信息可能属于信心表中的一条记录。...---- 1、我们已经在来源表(referrers)表建立了一条记录,并且得到了一个id: $ref = Referrer::create(['href'=>$href,'title'=>$title]...); $id = $ref->id; 2、假设我们在信息表(netDisks)插入了一条记录,得到一个model: $model = NetDisk::create(['xx'=>$xx]); 那么我们可以使用以下语句建立关系...2、attach要使用,要在模型中定义关联。 ? 如图,如果前面我们 搞不懂第三张表的命名,那么在这里指定即可。也最好指定以下,避免不知道的错误发送。 ? 好了,今天到这里了。

    1.6K00

    Laravel Eloquent 模型关联关系(下)

    查询语句如下: 如果你想进一步过滤出文章标题和评论都包含「Laravel学院」的用户,可以在上述闭包函数中通过查询构建器进一步指定: $users = User::whereHas('posts',...注:实际开发中为了提高查询性能,我们往往是在 posts 表中冗余提供一个 comments_count 字段,每新增一条评论,该字段值加 1,查询的时候直接取该字段即可,从而提高查询的性能。...: // 插入一条记录 $post->comments()->create([ 'content' => $faker->paragraph, 'user_id' => mt_rand(1, 15...1); $post->tags()->attach($tag->id); // 如果中间表还有其它额外字段,可以通过第二个数组参数传入 // $post->tags()->attach($tag->id...对于那些已存在的标签记录,我们可以通过更高效的方法与文章进行关联关系的绑定和解除,这个方法就是 sync,调用该方法时只需传入刚创建/更新后文章的标签对应 ID 值,至于哪些之前不存在的关联需要绑定,哪些存在的关联需要解除

    19.6K30

    通过 Laravel Eloquent 模型实现批量赋值和软删除

    但是,细心的同学可能会发现,这里有一个安全隐患,如果用户发布的时候,包含了用户字段 user_id,并且设置的不是自己的用户 ID,而是其它用户的 ID,发布出来的文章就变成其他人发布的了;又或者文章需要审核后才能发布...虽然在表单中设置了 user_id,但是并没有应用批量赋值。 软删除 我们在日常开发过程中,删除数据库记录在所难免,但是我们多数时候并不想从数据库中物理删除记录,而只是想从业务角度逻辑删除。...这就意味着,在 Laravel 中,我们不需要编写任何额外代码就可以实现对数据库记录的「软删除」。...要软删除一条记录,在对应模型类实例上调用 delete 方法即可,底层会自动将数据表的 deleted_at 字段设置为当前时间,表示该记录已经被「删除」。...()) { dump('该记录已删除'); } 此时再查询 id=32 的记录,已经不存在了,报 404 异常。

    2.5K10

    SQL 性能优化 总结

    如果有column 没有被索引, 查询效率可能会因为你没有选择OR 而降低.在下面的例子中,LOC_ID 和REGION 上都建有索引....,索引中将不存在此记录.对于复合索引,如果每个列都为空,索引中同样不存在此记录....如果至少有一个列不为空,则记录存在于索引中.举例:如果唯一性索引建立在表的A 列和B 列上,并且表中存在一条记录的A,B 值为(123,null) , ORACLE将不接受下一条具有相同 A,B 值(123...因此你可以插入 1000条具有相同键值的记录,当然它们都是空! 因为空值不存在于索引 列中,所以WHERE子句中对索引列进行空值比较将使 ORACLE 停用该索引....记住,索引只能告诉你什么存在于表中, 而不能告诉你什么不存在于表中. (2)‘||'是字符连接函数.

    1.9K20

    深入分析MySQL行锁加锁规则

    顾名思义,行锁就是给数据库表中每行数据加锁,行锁是加在索引上的,比如某个表中id字段是主键,如果给id=2这条记录加锁,那这把锁是加在主键索引(聚簇索引)上的。...这里可以得出结论:查询条件为主键索引时,如果查询条件是等值查询且记录不存在,会对查询条件所在间隙的下一条记录加间隙锁(相当于锁的范围就是查询条件所在间隙)。...: 因为id=5的记录存在于查询条件中(id>4 and id id>4 and id id>4 and id id=5的记录加邻键锁;除此之外还要对查询条件的其他部分...“锁表”(其实锁的不是表,是对所有主键索引中所有的记录加邻键锁),事务执行这条语句加锁的情况如下,对主键索引上的每一条记录都加了邻键锁: 这里可以得出结论:查询条件是唯一索引时,如果查询条件是等值查询且记录存在...这里可以得出结论:查询条件是唯一索引时,如果查询条件是等值查询且记录不存在,在唯一索引上,只会在查询条件所在间隙的下一条记录加间隙锁;在主键索引上不加锁。

    2.1K40

    通过 Laravel 查询构建器实现复杂的查询语句

    有时候,我们想要获取的并不是一行或几行记录,而是某个字段的值,你当然你可以查询到一行记录后从结果对象中获取指定字段的值,但是 Laravel 为我们提供了更便捷的语法: $name = '学院君'; $...posts p inner join users u on p.user_id <> u.id 外链接: 左连接:返回左表中的所有行,如果左表中的行在右表中没有匹配行,则返回结果中右表中的对应列返回空值...,如 select * from posts p left join users u on p.user_id = u.id 右连接:与左连接相反,返回右表中的所有行,如果右表中的行在左表中没有匹配行,...此外,查询构建器也支持 UNION ALL 查询,对应的方法是 unionAll,该方法与 union 的区别是允许重复记录,将上述代码中的 union 方法改为 unionAll,会发现查询结果中包含一条重复记录...分页 日常开发中,另一个常见的查询场景就是分页查询了,在查询构建器中提供了两种方式来进行分页查询。

    30.2K20

    oracle数据库sql语句优化(循环语句有几种语句)

    table)将被最先处理,在FROM子句中包含多个表的情况下, 必须选择记录条数最少的表作为基础表。...7、整合简单、无关联的数据库访问: 如果有几个简单的数据库查询语句,可以整合到一个查询中(即使它们之间没有关系)。...对于单列索引,如果列包含空值,索引中将不存在此记录。 对于复合索引,如果每个列都为空,索引中同样不存在此记录。如果至少有一个列不为 空,则记录存在于索引中。...如果唯一性索引建立在表的A列和B列上, 并且表中存在一条记录的A,B值为(123,null), ORACLE将不接受下一条具有相同A,B值(123,null)的记录(插入)。...因为空值不存在于索引列中,所以WHERE子句中对索引列进行空 值比较将使ORACLE停用该索引。

    2.9K10

    Laravel中简单使用队列加快访问速度

    以上是队列所需数据表 php artisan queue:failed-table ? 以上是队列任务运行失败的记录表 多了两张表,好了,不用管了。 ?...; } 这里就记录一条日志就行 如果有额外的参数需要填写,那么就在构造方法里面传入即可。 ?...附命令 附上一些常用命令 1、运行队列监听器 php artisan queue:listen 如果执行成功, jobs 中的数据表就没有数据了 如果执行失败,可以在日志中查看原因, 默认是 storage...php artisan queue:failed 3、重新执行失败任务 重新执行指定id失败的任务 php artisan queue:retry 1 此处的 1 失败任务表中的任务的 id...:forget 2 此处的 2 失败任务表中的任务的 id, 表示清除指定id失败任务 清除所有失败的任务 php artisan queue:flush

    1.6K00
    领券