laravel的firstOrCreate和firstOrNew有啥不同啊

laravel的firstOrCreate和firstOrNew有啥不同啊,第1张

firstOrCreate在未根据条件查询到数据后回向数据库发送insert命令创建一条数据

firstOrNew并不会真实的在数据库中插入一条新的记录,而是创建一个新记录的Eloquent对象,并返回,置于需不需要将这个新对象存入数据库可以自己控制

简单来说 firstOrCreate 等价于 先firstOrNew再将其返回的对象save进数据库

怎样用laravel动态创建数据库表

aravel提供了3种 *** 作数据库方式:DB facade(原始方式)、查询构造器和Eloquent ORM。下面我将逐一讲解。 数据库的配置文件在config目录下的database.PHP里。打开这个文件,找到MySQL的配置项。 这里有个env,它其实是调用了laravel根目录下的.e

基本路由 您的应用程序的绝大多数路由将在 app/routes'), function() { Route::get('user/{id}', function($account, $id) { // }) }) 路由前缀 一组路由可以通过在属性数组中使用 prefix 选项为路由组添加前缀: 为路由组添加前缀 复制代码 代码如下: Route::group(array('prefix' =>'admin'), function() { Route::get('user', function() { // }) }) 路由模型绑定 模型绑定提供了一个简单的方法向路由中注入模型。比如,不仅注入一个用户的 ID,您可以根据指定的 ID 注入整个用户模型实例。首先使用 Route::model 方法指定所需要的模型: 为模型绑定一个变量 复制代码 代码如下: Route::model('user', 'User') 然后, 定义一个包含 {user} 参数的路由: 复制代码 代码如下: Route::get('profile/{user}', function(User $user) { // }) 因为我们已经绑定 {user} 参数到 User 模型,一个 User 实例将被注入到路由中。因此,比如一个 profile/1 的请求将注入一个 ID 为 1 的 User 实例。 注意: 如果在数据库中没有找到这个模型实例,将引发404错误。 如果您希望指定您自己定义的没有找到的行为,您可以为 model 方法传递一个闭包作为第三个参数: 复制代码 代码如下: Route::model('user', 'User', function() { throw new NotFoundException }) 有时您希望使用自己的方法处理路由参数,可以使用 Route::bind 方法: 复制代码 代码如下: Route::bind('user', function($value, $route) { return User::where('name', $value)->first() }) 引发404错误 有两种方法在路由中手动触发一个404错误。首先,您可以使用 App::abort 方法: 复制代码 代码如下: App::abort(404) 其次,您可以抛出一个 Symfony\Component\HttpKernel\Exception\NotFoundHttpException 的实例。 更多关于处理404异常和为这些错误使用使用自定义响应的信息可以在 错误 章节中找到。 路由至控制器 Laravel 不仅允许您路由至闭包,也可以路由至控制器类,甚至允许创建 资源控制器. 更多信息请访问 控制器 文档。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/10025001.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存