laravelで会員とイベントを利用した人の可視化を目的としたシステムを作成したいます。
2つのdbから会員のテーブル、イベント参加者のテーブルの2つを取得してシステムを作っています。
その中で会員の名前のカラムとイベント参加者の名前カラムを比較して、イベント参加者のカラムの中に一人でも会員カラムの名前と一致した人物がいたらif文で表示を切り替える処理を行いたいと思っています。しかし何をしてもエラーが発生してしまいます。
現在リレーション先のテーブルのカラムを取得してbladeで利用したいのですが、そうすると下記のようなエラーが出てしまいます。
エラー内容は以下になります。
SQLSTATE [42S22]:列が見つかりません:1054 'where句'の列 'event_id'が不明です
Property [event_id] does not exist on the Eloquent builder instance.
=>joinでつないだ接続先のカラムを指定しているのですが、そのカラム名が不明になってします。
Property [event_id] does not exist on the Eloquent builder instance.
現在のblade、route、model,controllerは以下になります。
controller
php
1<?php 2 3namespace App\Http\Controllers; 4 5 6use Illuminate\Support\Facades\DB; 7use Illuminate\Http\Request; 8use Carbon\Carbon; 9use Illuminate\Support\Facades\Input; 10 11use App\Members; 12use App\Events; 13class UsersController extends Controller 14{ 15 public function index(Request $request){ 16 17 18 $data = Members::select('*',DB::raw("CONCAT(wptestswpm_members_tbl.last_name,wptestswpm_members_tbl.first_name)as name")) 19 'wptestswpm_members_tbl.name') 20 21 ->get(); 22 23 $keyword = $request->input('keyword'); 24 25 26 return view('Users.index',['data'=>$data])->with('keyword',$keyword); 27 28 } 29 30} 31 32?>
Members.php
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Members extends Model { // 既存てーぶるのモデル //デフォルと設定をprotectedでオーバーライドする protected $connection = 'mysql_2'; protected $table = 'wptestswpm_members_tbl'; protected $primaryKey = 'member_id';// プライマリキーを指定 //protected $created_at = ''; // 使用するフィールド名を指定 //protected $updated_at = ''; // 使用するフィールド名を指定 protected $timestamp = false; public function __construct(array $attributes = []) { parent::__construct($attributes); } // public function Events() // { // return $this->hasMany('App\Events'); // } } ?>
Events.php
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Events extends Model { //デフォルトの設定をprotectedでオーバーライドする // protected $connection = 'mysql'; protected $table='user_information'; protected $primaryKey = 'id'; public function __construct(array $attributes = []) { parent::__construct($attributes); } } ?>
index.blade.php
php
1 @forelse ($data as $data) 2 3 <?php $num++;?> 4 <tr> 5 <td class="table-id"><?php echo $num?></td> 6 {{-- <td>{{$data->user_name}}</td> --}} 7 {{-- <td class="table-name">{{$data->last_name}}{{$data->first_name}}</td> --}} 8 <td class="table-name">{{$data->name}}</td> 9 <td class="table-since">{{$data->member_since}}</td> 10 <td class="table-tel"><a href="tel:{{$data->phone}}">{{$data->phone}}</a></td> 11 <td class="table-email"><a href="mailto:{{$data->email}}">{{$data->email}}</a></td> 12 <td class="table-email">{{$data->txn_id}}</td> 13 14 {{-- @if($data->name === $data2) --}} 15 {{-- @if(strpos($data['name'],$data2['user_name'])!==false) 16 <td class="table-status"><div class="status-text">参加なし</div></td> 17 @else 18 <td class="table-status"><div class="status-text done">参加あり</div></td> 19 @endif --}} 20 21 {{-- @if ($data->name=== $data2) --}} 22 {{-- @if ($data->event_id) --}} 23 24 25 @if (!empty($data->txn_id)) 26 <td class="table-status"><div class="status-text">参加なし</div></td> 27 28 @else 29 <td class="table-status"><div class="status-text done">参加あり</div></td> 30 31 @endif 32 33 @empty 34 <tr><td>null</td></tr> 35 @endforelse
Route
<?php // use App\Wptestswpm_members_tbl; /* |-------------------------------------------------------------------------- | Web Routes |-------------------------------------------------------------------------- | | Here is where you can register web routes for your application. These | routes are loaded by the RouteServiceProvider within a group which | contains the "web" middleware group. Now create something great! | */ use App\Http\Controllers\UsersController; use Illuminate\Http\Request; Route::get('/', 'UsersController@index'); Route::get('/event', 'UsersController@event'); Route::get('/event/selection','UsersController@selection'); Route::get('/members','UsersController@member'); Route::post('/members', 'UsersController@update'); Route::get('/serch','SearchController@serch'); Route::post('/serch','SearchController@serch'); ?>
調べても何も出てこず、
Property [event_id] does not exist on the Eloquent builder instance
というエラーがよく出てきます。
かれこれこのエラーで2日ほど費やしてしまったので、どなたかお詳しい方、アドバイスいただければ幸いです。よろしくおねがいたします。