首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Laravel 5.0 之 Eloquent 属性转换

    . ---- 之前完全忘了要把这个 Laravel 5 的系列博客写完,不过最近看到了一篇关于属性转换的简介 Laravel 5 Eloquent Attribute Casting is Awesome...最常见的应用场景可能是:当你存储数字的时候——它们默认是返回字符串,但 Eloquent 属性转换可以帮你把字符串转换为 integer, real, float 或者 double,当然还可以转换为...float(real|double) Real, Float 和 Double 在 PHP 中是同一种类型。 PHP 的 (double) 和 (real) 类型转换都是 (float) 的别名。...string 这个很简单,就是把你指定的属性值转为字符串返回,用的是 return (string) $value. boolean(bool) 这是把你指定的属性值转换为布尔值返回,用 return...都是用把序列化为 JSON 格式数组的数据转换(反序列化)并返回。

    2.1K80

    PHP 基本数据类型

    上述代码执行结果如下: ?...由于双引号字符串会尝试对其中包含的 PHP 变量进行值解析,所以性能比单引号字符串差一些,因此日常可以用单引号字符串的地方,尽量用单引号字符串,除非某些场景必须使用双引号字符串,比如像上面那样包含转移字符...浮点型 对于小数或者超出整型值范围的数据,可以通过浮点型数据表示,浮点型又可以细分为 float(单精度)和 double(双精度),后者精度更高,能表示的数据范围也更大,但是会占据更多内存,运算速度也更慢...PHP 中默认的浮点型是 float,以「Laravel 精品课」为例,该书的价格可以用浮点型表示: $price = 99.00; var_dump($price); 通过 var_dump 打印结果是...: float(99) 注:当然,也可以通过 is_float/is_double 这种函数进行类型判断。

    1.9K10

    Laravel 请求生命周期

    内容涵盖当一个 HTTP 请求发送到 Laravel 服务后,这个请求在项目运行的各个阶段是如何被处理的,然后框架又是如何将处理结果发送回用户的。 我们会带领大家一步步深入挖掘出这其中的秘密。...HTTP 内核是定义在 app/Http/Kernel.php 文件内的 Kernel 实现类,它接收一个请求,然后返回一个响应,就是这么简单。...由于当前访问的 URL 地址不包含子路径,Web 服务器会查找配置文件的 index.php 文件。 4 Web 服务器将请求发送到项目的 public/index.php 文件。...6 之后,Laravel 应用实例被实例化,同时,引导安装 laravel 组件。...9 Web 服务器接收到 PHP 的输出结果,并将结果返回给用户浏览器。 10 用户浏览器接收到服务器响应,渲染页面并展现给用户。

    2.9K10

    推荐17-Laravel 中使用 JWT 认证的 Restful API

    在这种情况下, API 也是同样出色的,因为您可以在不更改任何后端代码的情况下编写不同的前端。...否则,成功的响应则将伴随用户数据一起返回。 在 login 方法中,我们得到了请求的子集,其中只包含电子邮件和密码。...->get(['name', 'price', 'quantity']) ->toArray(); } 上面的代码非常简单,我们只是使用 Eloquent 的方法获取所有的产品,然后将结果组成一个数组...最后,我们返回这个数组。Laravel 将自动将其转换为 JSON ,并创建一个为 200 成功的响应码。 继续实现 show 方法。...我们可以发送另一个请求来检测 login 路由,结果会返回 200 和令牌。 ? 获取用户详情 ? 测试身份认证已完成。接下来测试产品部分,首先创建一个产品。 ?

    11K20

    Laravel Eloquent 模型关联关系(下)

    懒惰式加载 下面这种方式就是懒惰式加载: $post = Post::findOrFail(1); $author = $post->author; 每次访问 author 属性都会执行一次数据库查询,如果返回的文章结果是列表的话...,需要遍历获取作者信息,假设要循环 N 次的话,加上文章模型本身的获取,总共需要进行 N + 1 次查询,而 PHP 对数据库的连接是短连接,每次都要重新连接数据库,所以从性能角度考虑不建议使用这种方式...很显然,它们用于过滤不包含对应关联结果的模型实例。...: 其中包含了 comments_count 字段,通过这个字段就可以访问该文章的评论数。...function($query) { $query->where('status', Comment::PENDING); } ])->findOrFail(32); 对应的返回结果如下

    19.6K30

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

    但是你打开数据库表查看结果的时候,发现那些值也成功的写入了。...新建 or 更新 接着介绍laravel模型的几个语法糖。一个常规的场景,比如在写入数据时,先判断数据库表内是否有该条记录,如果没有就创建,如何有则返回。...::create(['name' => 'Coffee and Laravel']); } 返回的总是一个 Event 对象,所以如果想要接着操作其他属性,那就接着写好了: $event->venue...' => 'Dublin']); 如果 name 字段已存在,就返回第一条数据;如果不存在,就是用第二个数组写入。...laravel还有一个方法 firstOrNew 用于不立即写入数据库,直到手动写入: $event = Event::firstOrNew(['name' => 'Coffee and Laravel

    1.9K00

    【Laravel系列4.1】连接数据库与原生查询

    连接数据库配置 首先我们可以看下配置文件,在 Laravel 程序的 config 目录下,有一个 database.php 文件,其中有关于数据库的连接配置信息。...注意,insert() 方法返回的结果是一个布尔值,也就是添加操作的成功失败情况,如果我们想获取新增加的数据的 id ,需要使用 DB::getPdo()->lastInsertId(); 这条语句才可以获取到...仔细查看这两个方法,你会发现只有返回结果的地方是稍有不同的,statement() 返回的是布尔值,而 affectingStatement() 返回的是影响行数。...查阅的源代码也在上面的那个文件中哦,大家可以自己去看一看,内容和上面的那两个 statment 方法里面的东西都差不多,也是在返回结果的地方会有些区别。...在这其中,我们还看到了 工厂模式 在这其中发挥的作用。也算是取到了一部分的真经,大家都要为自己鼓掌哦!

    3.2K50

    Laravel 5.2+ 使用url()全局函数返回前一个页面的地址

    注意:文章标题中5.2+表示该文章内容可向上兼容,适用于Laravel版本5.2及更高(目前最新为5.6),但不可向下兼容,即不适用于5.2版本以下。...推荐大家花一点点时间,将自己的Laravel更新至5.6版本。 在后台开发时,我们经常需要获取用户之前操作页面的地址并生成一个返回之前页面的链接。...而Laravel从版本5.2+开始,便提供了一系列全局帮助函数(Helper Functions)来简化我们的工作: https://laravel.com/docs/5.2/helpers#method-url...而今天我们要用到的是URLs中的函数: //返回当前页面的地址(不包含参数) url()->current(); //返回当前页面的完整地址(包含参数) url()->full(); //返回前一个页面的地址...author=eagle 如果我们在该页面点击了某个操作,那么在我们的控制器中,我们输出 echo url()->previous(); 会发现输出的结果与我们之前操作的页面的url一致: http

    1.3K20

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

    中,我们不推荐这么做,因为这些对数据表结构的操作可以通过数据库迁移功能来实现,而且那样做的话可维护性更好。...DB 门面提供了一个 select 语句帮助我们对数据表进行查询: $users = DB::select('select * from `users`'); 该方法返回包含所有查询结果的 stdClass...,此时返回的就是指定查询条件的结果: 如果你要设置多个查询条件,添加多个绑定参数即可。...查询记录 要查询指定数据表中的所有记录,可以通过以下方式实现: $users = DB::table('users')->get(); 该方法返回的是一个包含所有查询结果的 stdClass 集合:...上述代码返回的也是包含指定查询结果的 stdClass 集合: 有时候我们可能希望返回查询结果中的第一条记录,这可以通过将 get 方法替换为 first 方法来实现: $user = DB::table

    4.2K20
    领券