queryScope と setAttribute の使用法
setAttribute
コントローラーに時間を書き込む代わりに、フォームに日付を作成し、それを直接処理します。
app/Http/Controllers/ArticlesController.php public function store(Request $requests){ $input = Request::$requests->all(); $input['publish_at']=Carbon::now(); //原来这里是通过直接硬性写时间进去 Articles::create($input); return redirect('/articles'); }
代わりに、フォームの時間を処理します
app/Http/Controllers/ArticlesController.php public function store(Request $requests){ //现在取消掉硬性写时间 Articles::create($requests->all()); return redirect('/articles'); }
(form)
resources/views/articles/create.blade.php@extends('layout.app')@section('content') <h1>创建文章</h1> {!! Form::open(['url'=>'/articles/store']) !!} <!--- Title Field ---> <div class="form-group"> {!! Form::label('title', 'Title:') !!} {!! Form::text('title', null, ['class' => 'form-control']) !!} </div> <!--- Content Field ---> <div class="form-group"> {!! Form::label('content', 'Content:') !!} {!! Form::textarea('content', null, ['class' => 'form-control']) !!} </div> <!--- Field ---> <div class="form-group"> {!! Form::label('publish_at', 'publish_at:') !!} {!! Form::date('publish_at', date('Y-m-d'), ['class' => 'form-control']) !!} //这里写时间,由用户选择输入 </div> {!! Form::submit('发表文章',['class'=>'btn btn-primary form-control']) !!} {!! Form::close() !!}@stop
データベースに表示される状況
id title content publish_at created_at updated_at5 我是一篇新文章 你好 2016-05-21 00:00:00 2016-05-21 07:32:48 2016-05-21 07:32:48 //这里的时间只有日期,而没有时分
したがって、モデルにメソッドを記述し、モデルをデータベースに関連付けて、書き込み時に時刻形式の変換を実行するという解決策が導き出されます。データベース(他のデータ処理でも同様の原理が使えます)
setAttributeの使い方です
モデルに書いて自動処理関数setattributeを書きます
app/Articles.phpclass Articles extends Model{ protected $fillable=['title','content','publish_at']; public function setPublishAtAttribute($date) //set + 字段名 + attribute 组成的,laravel会自动判断字段名,并且名字要遵循驼峰命名法 { $this->attributes['publish_at'] = Carbon::createFromFormat('Y-m-d',$date); //调用model的attributes方法来设置 }}
データベースはデータが生成されたことを確認でき、時間が分かれています。
id title content publish_at created_at updated_at6 我是第二篇文章 爱的飒飒大 2016-05-27 08:17:29 2016-05-21 08:17:29 2016-05-21 08:17:29
元の setattribute は setattribute と呼ばれますが、途中でのフィールドの挿入もサポートしています
in Carbon.php line 425at Carbon::createFromFormat('Y-n-j G:i:s', 'Y-m-d-2016-05-27-21 8:21:00', null) in Carbon.php line 368at Carbon::create('Y-m-d', '2016-05-27', null, null, null, null, null) in Carbon.php line 383at Carbon::createFromDate('Y-m-d', '2016-05-27') in Articles.php line 14 at Articles->setPublishAtAttribute('2016-05-27') in Model.php line 2860 //这里调用setPublishAtAttributeat Model->setAttribute('publish_at', '2016-05-27') in Model.php line 447 //这里就转变成setAttributeat Model->fill(array('_token' => '', 'title' => '我是第二篇文章', 'content' => '爱的飒飒大', 'publish_at' => '2016-05-27')) in Model.php line 281at Model->__construct(array('_token' => '', 'title' => '我是第二篇文章', 'content' => '爱的飒飒大', 'publish_at' => '2016-05-27')) in Model.php line 569at Model::create(array('_token' => '', 'title' => '我是第二篇文章', 'content' => '爱的飒飒大', 'publish_at' => '2016-05-27')) in ArticlesController.php line 31at ArticlesController->store(object(Request))
queryscope
コントローラーの処理に元のハードを記述します。 time メソッド
app/Http/Controllers/ArticlesController.php public function index(){ $articles = Articles::latest()->where('publish_at','>=',Carbon::now())->get(); //这里通过直接写时间处理方法来实现数据处理 return view('articles.index',compact('articles')); }
の内容:
public function index(){// $articles = Articles::latest()->where('publish_at','< =',Carbon::now())->get(); $articles = Articles::latest()->publish()->get(); //创造一个新的方法,目的是更灵活也让目前的代码更加简洁和容易理解, //例如这里就是从articles里获取大概是最后一条数据然后过滤publish时间然后获取最终数据的大概意思,不用再看where什么的了 return view('articles.index',compact('articles')); }
次に、モデル記事にスコープを追加します
app/Articles.php public function scopePublish($query){ //scope语法限制,scope+刚才的publish函数名字(需要驼峰法命名) $query->where('publish_at','< =',Carbon::now()); //固定是传入一个$query,暂时的理解是一个数据查询结果,然后使用where过滤数据 }
モデル記事のインスタンスが使用されるため、スコープの名前付けにより、laravel が自動データクエリを実行するため、データクエリの結果 $クエリが渡されて処理されます
一般的な科学知識:
latest() はビルダー オブジェクトを返します
Builder|Builder latest(string $column = 'created_at')Add an "order by" clause for a timestamp to the query.Parametersstring $column Return ValueBuilder|Builder
ビルダー オブジェクトは特別なデータ オブジェクトであり、laravel のデータベースによって管理されるオブジェクトであり、ビルダーです 多くのデータ情報が含まれています簡単かつ直接的に使用できます。
alls メソッドはコレクション オブジェクトを返します
static Collection|Model[] all(array|mixed $columns = array('*'))Get all of the models from the database.Parametersarray|mixed $columns Return ValueCollection|Model[]
これはコレクションの形式です:
Collection {#136 ▼ #items: array:6 [▼ 0 => Articles {#137 ▼ #fillable: array:3 [▶] #connection: null #table: null #primaryKey: "id" #perPage: 15 +incrementing: true +timestamps: true #attributes: array:6 [▼ "id" => 6 "title" => "我是第二篇文章" "content" => "爱的飒飒大" "publish_at" => "2016-05-27 08:17:29" "created_at" => "2016-05-21 08:17:29" //collection里面的数据是数组包含对象,所以方便调用。 "updated_at" => "2016-05-21 08:17:29" ] #original: array:6 [▶] #relations: [] #hidden: [] #visible: [] #appends: [] #guarded: array:1 [▶] #dates: [] #dateFormat: null #casts: [] #touches: [] #observables: [] #with: [] #morphClass: null +exists: true +wasRecentlyCreated: false } 1 => Articles {#138 ▶} 2 => Articles {#139 ▶} 3 => Articles {#140 ▶} 4 => Articles {#141 ▶} 5 => Articles {#142 ▶} ]}
これはビルダーの形式です:
Builder {#128 ▼ #query: Builder {#127 ▼ #connection: MySqlConnection {#123 ▶} #grammar: MySqlGrammar {#124 ▶} #processor: MySqlProcessor {#125} #bindings: array:6 [▶] +aggregate: null +columns: null +distinct: false +from: "articles" +joins: null +wheres: array:1 [▼ //builder里面包含的数据会存在这里,不过不能直接使用,需要使用像get这样的方法来转换数据。 0 => array:5 [▼ "type" => "Basic" "column" => "publish_at" "operator" => ">=" "value" => Carbon {#129 ▼ +"date": "2016-05-21 09:08:10.000000" +"timezone_type": 3 +"timezone": "UTC" } "boolean" => "and" ] ] +groups: null +havings: null +orders: array:1 [▶] +limit: null +offset: null +unions: null +unionLimit: null +unionOffset: null +unionOrders: null +lock: null #backups: [] #bindingBackups: [] #operators: array:26 [▶] #useWritePdo: false } #model: Articles {#121 ▼ #fillable: array:3 [▶] #connection: null #table: null #primaryKey: "id" #perPage: 15 +incrementing: true +timestamps: true #attributes: [] #original: [] #relations: [] #hidden: [] #visible: [] #appends: [] #guarded: array:1 [▶] #dates: [] #dateFormat: null #casts: [] #touches: [] #observables: [] #with: [] #morphClass: null +exists: false +wasRecentlyCreated: false } #eagerLoad: [] #macros: [] #onDelete: null #passthru: array:11 [▶] #scopes: []}

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











多くの場合、キーワードと追跡パラメーターで散らかった長いURLは、訪問者を阻止できます。 URL短縮スクリプトはソリューションを提供し、ソーシャルメディアやその他のプラットフォームに最適な簡潔なリンクを作成します。 これらのスクリプトは、個々のWebサイトにとって価値があります

2012年のFacebookによる有名な買収に続いて、Instagramはサードパーティの使用のために2セットのAPIを採用しました。これらはInstagramグラフAPIとInstagram Basic Display APIです。

Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

これは、LaravelバックエンドとのReactアプリケーションの構築に関するシリーズの2番目と最終部分です。シリーズの最初の部分では、基本的な製品上場アプリケーションのためにLaravelを使用してRESTFUL APIを作成しました。このチュートリアルでは、開発者になります

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

2025 PHP Landscape Surveyは、現在のPHP開発動向を調査しています。 開発者や企業に洞察を提供することを目的とした、フレームワークの使用、展開方法、および課題を調査します。 この調査では、現代のPHP Versioの成長が予想されています
