質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

1回答

879閲覧

Laravel 数字ではなく同じ名前同士でリレーションしたい。(別のdbのテーブルで)

TakehiroShinmyo

総合スコア16

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2020/04/24 05:22

編集2020/04/27 00:24

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日ほど費やしてしまったので、どなたかお詳しい方、アドバイスいただければ幸いです。よろしくおねがいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

rozeo_s

2020/04/29 09:29

UsersController@indexで呼んでいるview名と添付のビュー名が異なっているんですがエラーがでているのは本当に UsersController@index ですか?それ以外にもいそうなんですが
guest

回答1

0

hasManyの第2引数以降でテーブル名、FK列名を任意で決めれます

投稿2020/04/30 04:38

mikkame

総合スコア5036

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

TakehiroShinmyo

2020/04/30 07:05

ご回答ありがとうございます! 検証してみます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問