//下面这个函数的作用:有两点 //1、后面的是前面的注释,在rules验证的时候,如果报错,会把此处的后面的内容显示出来 //2、hint作用,即表单中用户插入数据时,提示用户该字段该填什么内容...public function attributeLabels() { return [ 'id' => 'ID',//id为数据表中的字段名,ID 为表单显示的描述...'name' => '这是用户名', 'password' => 'Password', ]; } 可以新增加个属性,设置set和get 代码如下,添加到模型中即可...,name1是修改后的值 private $name; public function getName(){ return $this->name1; } public
做什么事情 更新book_borrow表,设置其中的student_name为student表中的name,关联条件为book_borrow.student_id = student_id student...表 book_borrow表 几种不同的更新方式 保留原表数据的更新 只会更新student表中有的数据,student表中查不到的数据,在book_borrow表中还保持不变,不会更新,相当于内连接...更新结果以student的查询结果为准,student中没有查到的记录会全部被更新为null 相当于外连接 update book_borrow br set student_name = (select...update book_borrow br left join student st on br.student_id = st.id set br.student_name = st.name; 将一张表的查询结果插入到另外一张表中...insert select :将一条select语句的结果插入到表中 -- insert into 表名1 (列名) select (列名) from 表名2 ; insert into tableA
默认情况下,Laravel Eloquent 模型默认数据表有 created_at 和 updated_at 两个字段。当然,我们可以做很多自定义配置,实现很多有趣的功能。下面举例说明。 1....Laravel 在自动填充 created_at / updated_at 的时候,无法找到这两个字段。...多对多:带时间戳的中间表 当在多对多的关联中,时间戳不会自动填充,例如 用户表 users 和 角色表 roles 的中间表 role_user。...(Role::class); } } 然后当你想用户中添加角色时,可以这样使用: $roleID = 1; $user- roles()- attach($roleID); 默认情况下,这个中间表不包含时间戳...例如,某个 comment 被更新,那么您希望将 post 表的 updated_at 也更新。
namespace App; use Zizaco\Entrust\EntrustRole; class Role extends EntrustRole { } Role模型拥有三个主要属性: name —— 角色的唯一名称...和description 属性都是可选的,在数据库中的相应字段默认为空。...:在User模型中添加roles() 、hasRole(name) 、can(permission) 以及ability(roles,permissions, 软删除 使用Entrust提供的迁移命令生成的关联关系表中默认使用了...如果你由于某种原因不能在数据库中使用级联删除,那么可以在EntrustRole 、EntrustPermission 类以及HasRole trait提供的事件监听器中手动删除关联表中的记录。...总结 到此这篇关于使用Entrust扩展包在laravel 中实现RBAC的功能的文章就介绍到这了,更多相关Entrust扩展包实现RBAC内容请搜索ZaLou.Cn以前的文章或继续浏览下面的相关文章希望大家以后多多支持
使用模型的唯一缓存键,您可以缓存模型(或关联模型)更新时自动更新(以及缓存失效)的模型上的属性和关联,一个好处是访问缓存的数据比在控制器中缓存的数据更具可复用性,因为它在模型上而不是在单个控制器方法中。...不过在新增或删除一个评论时,我们怎么触发修改文章的updated_at字段呢? 碰巧 Eloquent 模型中有一个属性就叫$touches 。下面是我们的评论模型的大概样子: <?...':comments_count', 15, function () { return $this- comments- count(); }); } 我们使用唯一键值的cacheKey()...我设置了一个定时器,以便在每隔 15 分钟的缓存刷新间隔里,缓存可在该时间的多数范围内有最高的命中率。 cacheKey()方法要用到模型的唯一键值,并且在模型更新时对应缓存失效。.../1-1515650910 这个键值是由表名、模型id值及当前updated_at 的 timestamp 值组成。
如果互相喜欢,则添加双向联系人关系,插入之前校验是否存在,存在则更新type等字段,不存在则插入双向数据 我们通过这个场景能非常好的体会laravel-upsert的强大,不仅减少了代码量,也减少了sql...第二个参数是唯一标识记录的列。除 SQL Server 外的所有数据库都要求这些列具有PRIMARY或UNIQUE索引。 提供要更新的列作为第三个参数(可选)。默认情况下,将更新所有列。...upsert()还将添加updated_at到更新的列中。...当然了还是有一些注意点和坑,下面分享一下 注意的问题 要根据需求添加唯一索引 根据官方文档中的说明,我们的model中必须添加这行代码,才能以Eloquent的方式用 use \Staudenmeir\...LaravelUpsert\Eloquent\HasUpsertQueries; 因为我们数据库的时间是int类型,不是laravel默认的时间格式,并且我们的插入时间和更新时间也不是laravel默认的字段
这两个包都已经假设你已经有一个默认的 Laravel 用户数据库表,但没有任何角色和权限的结构。 它们会添加自己的表和字段。 这两个包都在 README 上有非常清晰的文档来描述各自的用法。...说明: 字段 guard_name 具有默认值 web — 允许你使用多个 guard; 正如你看到的,有两个权限 中间表 — 角色和用户; 字段 model_type 具有默认值 App\User ,...所以没有直接外键关联到 users 表,也没有其他表有 user_id 字段。...然后,permissions 是附加到 entity 的一组功能; Entity (在所有表中)是分配权限的对象。它可能是角色或用户。...他们添加了一些附加功能,但在 README 文件中并没有很好的解释; Spatie 有 guard 字段但是 Bouncer 没有。
创建新表没啥好说的,字段类型一定要选好,如果写好了,又进行了迁移,数据库也生效了,这时候,半路上要修改字段类型, 最好数据库里没数据,要是有,可就要遭殃,比如说原本是 varchar(50),有的字段写满了...而在 laravel 里对一个空表修改字段,完全可以通过,我们创建新的迁移文件,然后在 up 方法内这样调用: $table->string('name', 100)->change(); 看,只用调用一个...->after('last_name'); 仅仅修改字段名,只需调用对应方法: $table->renameColumn('promoted', 'is_promoted'); 或者在回滚方法中对某些新增的字段进行删除...']); // 联合主键 还有唯一性约束,为存在的字段创建: $table->unique('email'); // 唯一性 $table->unique('email', 'optional_custom_index_name...上面给的这些个方法,足够应对很多很多场景了。 写在最后 本文介绍了laravel中使用迁移功能操作数据库的创建,修改,移除字段,删除表等,把开发者从手动维护数据库的状态中解脱出来。
(不包括),从开始行数开始的共几行 UPDATE 更新 注意WHERE 加更新的条件,不然会更新所有 UPDATE 表名 SET 字段名1=字段值1[,字段名2=字段值2] [WHERE 条件表达式...VARCHAR(20) DEFAULT '在用'; 删除表中字段 ALTER TABLE 表名 DROP 字段名; 修改字段(列)名,添加唯一键约束 ALTER TABLE 表名 CHANGE...KEY 唯一键:可以用有空值,不能出现重复值,也不能为 NULL, 查看、删除、添加 表中的索引 #查看表有哪些索引 SHOW INDEXES FROM 表名; 单独新增 去除唯一键约束...#给字段 DEV_NAM 增加唯一键约束 ALTER TABLE USER_MESG ADD UNIQUE INDEX (DEV_NAME); #给字段 DEV_NAM 去除唯一键约束 #查看索引表中...;一张表中只能有一个主键, 但是一张表中可以有多个唯一键 #not null:表示此字段不允许为NULL 数据表高级操作 克隆表,将数据表的数据记录生成到新的表中 方法一:使用 like #先克隆表结构
# JWT 多表验证隔离 为什么要做隔离 当同一个 laravel 项目有多端(移动端、管理端……)都需要使用 jwt 做用户验证时,如果用户表有多个(一般都会有),就需要做 token 隔离,...会引发这个问题的原因是 laravel 的 jwt token 默认只会存储数据表的主键的值,并没有区分是那个表的。所以只要 token 里携带的 ID 在你的用户表中都存在,就会导致越权验证。...这个 token 通过你的验证中间件时,你使用不同的 guard 就能拿到对应表 id 为 1 的用户(了解 guard 请查看 laravel 的文档)。...解决办法 想要解决用户越权的问题,我们只要在 token 上带上我们的自定义字段,用来区分是哪个表或哪个验证器生成的,然后再编写自己的中间件验证我们的自定义字段是否符合我们的预期。...: getJWTIdentifier 的:获取会储存到 jwt 声明中的标识,其实就是要我们返回标识用户表的主键字段名称,这里是返回的是主键 ‘id’, getJWTCustomClaims:返回包含要添加到
两张比较大的表进行 JOIN,但是没有给表的相应字段加索引 表存在索引,但是查询的条件过多,且字段顺序与索引顺序不一致 对很多查询结果进行 GROUPBY 索引 创 建 索 引 的 目 的 就...表 示 唯 一 的 , 不 允 许 重 复 的 索 引 , 支 持 单 列 和 多 列 。...注 意 , 如 果 是 多 列 共 同 构 成 唯 一 索 引 , 代 表 的 是 多 列 的 数 据 组 合 是 唯 一 的 。...尽量选择区分度高的列作为索引,区分度的公式是 count(distinct col)/count(*),表示字段不重复的比例,比例越大我们 扫描的记录数越少,唯一键的区分度是 1,而一些状态、性别字段可能在大数据面前区分度就是...索引列不能参与计算,保持列“干净”,比如 from_unixtime(create_time) = ’2014-05-29’就不能使用到索引,原因很 简单,b+树中存的都是数据表中的字段值,但进行检索时
每一个页面认证当前需要的权限一次 在统一的地方(中间件)验证 先上一下简单的表结构(只保留重要的信息)数据库的模型 ER 图 数据库模型图 (ps:这个设计中,用户不会直接拥有权限,只能通过角色继承权限...需要的权限 * 2. 遍历当期那用户拥有的所有角色 * 3....php namespace App\Models; class Permission extends Model { // 角色和权限的模型关联关系 public function...,还是要在不同的方法进行验证,而且可扩展性不高,这时候我们只需要在权限表加一个字段,就可以解决问题 1. permissions (加多一个 route 字段, 如果不在 laravel 中使用,可以加一个...$route = Route::currentRouteName(); // 判断权限表中这条路由是否需要验证 if ($permission
resultType做SQL语句返回结果类型处理时,对于SQL语句查询出的字段在相应的pojo中必须有和它相同的字段对应,而resultType中的内容就是pojo在本项目中的位置。...因此对于单表查询的话用resultType是最合适的。但是,如果在写pojo时,不想用数据库表中定义的字段名称,也是可以使用resultMap进行处理对应的。...多表连接查询时,若是一对一的连接查询,那么需要新建一个pojo,pojo中包括两个表中需要查询出的所有的字段,这个地方的处理方式通常为创建一个继承一个表字段的pojo,再在里面添加另外一个表内需要查询出的字段即可...-- id:指定查询列中的唯 一标识,订单信息的中的唯 一标识,如果有多个列组成唯一标识,配置多个id column:订单信息的唯 一标识 列 property...-- id:指定查询列中的唯 一标识,订单信息的中的唯 一标识,如果有多个列组成唯一标识,配置多个id column:订单信息的唯 一标识 列 property
约束:constraint MySQL中的约束分类 主键:primary key 唯一键:unique 非空:not null 缺省:default 外键:foreign key 主键、唯一键...、外键都会自动创建索引 主键:一个表只能有一个主键,其可以对应一个字段,也可以对应多个字段(组合主键) 唯一键:也成为候选主键(跟主键的区别在于可以存储null值) 外键:来源于主表的主键或唯一键...key(对应字段) references 主表(主键字段或唯一键字段) 创建组合主键 primary key (字段1,字段2) 对于已经存在的表,创建唯一键约束 alter table 表名 add...alter table 表名 drop foreign key 外键名称; 删除唯一键 注意:唯一键删除后对应的索引也会自动删除 alter table 表名 drop index 唯一键字段名;...删除指定名称的索引 alter table 表名 drop index 索引名称; 提醒:对于有主外关联的表,删除表中数据,如果无删除的级联操作,那么删除主表数据之前,必须先删除从表对应数据
基本用法:on dupdate key update 语句基本功能是:当表中没有原来记录时,就插入,有的话就更新。...1,on duplicate key update 语句根据主键id或唯一键来判断当前插入是否已存在。 2,记录已存在时,只会更新on duplicate key update之后指定的字段。...3,如果同时传递了主键和唯一键,以主键为判断存在依据,唯一键字段内容可以被修改。 4,特殊用法:参考第五、第六条。...结论: 4.如果传递了主键,是可以修改唯一键字段内容的。 这里要注意,如果这里的name修改为 caocao,huahua2 会报唯一键冲突的。可以自行尝试。...,则name会保持数据库中的值,不会更新。
,数据不能重复,但是一张表中只能有一个主键:唯一键就可以解决表中有多个字段需要唯一性约束的问题。...唯一键的本质和主键差不多,唯一键允许为空,而且可以多个为空,空字段不做唯一性比较。 关于唯一键和主键的区别: 我们可以简单理解成,主键更多的是标识唯一性的。...而唯一键更多的是保证在业务上,不要和别的信息出现重复。...而我们设计员工工号的时候,需要一种约束:而所有的员工工号都不能重复。具体指的是在公司的业务上不能重复,我们设计表的时候,需要这个约束,那么就可以将员工工号设计成为唯 一键。...foreign key (字段名) references 主表(列) 举例: 由于学生表(stu)中的class_id是班级表(myclass)中的id的外键,因此,主表为班级表(myclass),
[img] 本期我们开始讲模型中,如何插入新条目,或者更新既有条目。...代码时间 我们在构建一个hello world页面的时候,已经介绍了如何使用laravel的命令行脚手架创建新的模型文件,以及通过迁移功能创建数据库表。这样就把数据操作衔接起来了。...我们在表中还有id字段,created_at字段,updated_at字段,并没有显式赋值。但是你打开数据库表查看结果的时候,发现那些值也成功的写入了。...这样laravel在处理模型数据的时候,会默认更新此二字段。 然而,对于写入数据库的那些数据,并不是所有字段都会允许写入的。在模型内我们可以手动指定哪些字段可以写,哪些字段不可以写。...新建 or 更新 接着介绍laravel模型的几个语法糖。一个常规的场景,比如在写入数据时,先判断数据库表内是否有该条记录,如果没有就创建,如何有则返回。
,虽然没有信息研究核心源码,至少要能灵活顺畅的应用,接下来,主要是介绍Session在 Laravel5.5 中的应用,欢迎指导建议,必将虚心求知 … 框架:Laravel5.5 重点:Session...机制,核心逻辑请参考 Illuminate\Session\Middleware\StartSession这个中间件,因此在 Laravel 应用中不要试图通过$_SESSION方式去获取应用的 Session...另外,还有一个大家都感到困惑的问题,就是在 Laravel 的控制器构造函数中是无法获取应用 Session 数据的,这是因为 Laravel 的 Session 通过 StartSession 中间件启动...可以使用 Artisan 命令 session:table 在数据库中创建表: php artisan session:table ?...并且字段 user_id 没有赋值 每次页面刷新或跳转,在时效内,都会进行更新,唯一不变的是 id 不变,待到有效期过后或者更换浏览器再增加新的记录.
Artisan 是一个 SHELL 脚本,是通过命令行操作 Laravel 的唯一入口。...因为我们已经完成了数据表中字段的定义、表与表的关系、以及最重要的一步:如何将数据及数据之间的关系写入数据库中,下面简单的来介绍下在 Laravel 是如何完成的。...而 Laravel 提供的 FormRequest 就可以非常方便的做到这一点;你可以在 FormRequest 中定义前端传入的每一个字段的验证规则。...强大的的辅助函数和丰富的 API,在下面的代码中我们甚至可以做到一行代码就完成课程的创建及依赖关系的更新。...我们还使用了 Laravel Resource 来格式化最终的输出格式,这样做的原因是很多情况下我们不希望直接将数据库的字段暴露出去,你甚至还能在 Laravel Resource 中按不同的角色显示不同的字段
领取专属 10元无门槛券
手把手带您无忧上云