Почему не отображаются все конференции, которые относятся к категории, по которой щелкнули?(Столбец не найден: 1054 Неизвестный столбец) - PullRequest
0 голосов
/ 16 мая 2018

У меня есть список, который показывает некоторые категории:

<ul class="Categories__Menu">
    @foreach($categories->take(6) as $category)
        <li class="active">
            <a href="#" name="category" id="{{$category->id}}" href="#">{{$category->name}}</a>
        </li>
    @endforeach

    <li><a  data-toggle="modal" data-target=".bd-example-modal-lg" href="">More <i class="fa fa-caret-down" aria-hidden="true"></i></a></li>
</ul>

Когда пользователь щелкает по категории, делается запрос ajax, чтобы получить конференции, которые принадлежат к этой категории, по которой щелкают.Например, когда пользователь щелкает в категории «IT», в базе данных которой есть 2 конференции с категорией «IT», вместо отображения 2 конференций в представлении на вкладке сети с «dd ($ conference)»;появляется:

"SQLSTATE[42S22]: Column not found: 1054 Unknown column 'categories.conference_id' in 'where clause' (SQL: select * from conferences where exists (select * from categories where conferences.id = categories.conference_id and category_conference.id = 2))".

Маршрут:

Route::get('conferences/where/category/{id}','ConferenceController@WhereHasCategory')->name('category.conferences');

Метод ConferenceController:

public function WhereHasCategory(Request $request)
    {
        $conferences = Conference::whereHas('categories', function ($categories) use (&$request) {
            $categories->where('category_conference.id',$request->id);
        })->get();

        //dd($conferences);

        return response()->json($conferences);
    }

Ajax:

$("a[name='category']").on('click', function(){

    var category_id = $(this).attr("id");

    $('.Categories__Menu li').removeClass('ative');
    $(this).parent('li').addClass('ative');

    $.ajax({

        url: '{{ route('category.conferences',null) }}/' + category_id,
        type: 'GET',
        success:function(result){
            $('#conferences').empty();
            var newConferences='';
            var placeholder = "{{route('conferences.show', ['id' => '1', 'slug' => 'demo-slug'])}}";
            $.each(result, function(index, conference) {
                var url = placeholder.replace(1, conference.id).replace('demo-slug', conference.slug);

                newConferences += '<div class="col-12 col-sm-6 col-lg-4 col-xl-3 mb-4">\n' +
'                        <div class="card box-shaddow">\n' +
'                            <img class="card-img-top" src='+ conference.image +' alt="Card image cap">\n' +
'                            <div class="card-body">\n' +
'                                <p class="font-size-sm"><i class="fa fa-calendar" aria-hidden="true"></i>  '+conference.start_date+'</p>\n' +
'                                <h5 class="card-title h6 font-weight-bold text-heading-blue">'+conference.name+'</h5>\n' +
'                                <p class="card-text font-size-sm"><i class="fa fa-map-marker" aria-hidden="true"></i> '+conference.place+', '+conference.city+'</p>\n' +
'                            </div>\n' +
'                           <div class="card-footer d-flex justify-content-between align-items-center">\n' +
'                                 <a href="' + url + '" class="btn btn-primary text-white">More</a>' +
                    ' <span class="font-weight-bold font-size-sm text-heading-blue"> </span>\n'+
'                           </div>\n' +
'                    </div></div>';
            });

            $('#conferences').html(newConferenes);

        },
        error: function(error) {
            console.log(error.status)
        }

    });

});

Например, вВ базе данных есть 5 конференций, имеющих category_id "2".А когда нажимается категория с идентификатором 2, получается результат, о котором идет речь, только с одним результатом.Сводная таблица category_conference имеет:

id conference_id   category_id

1             1                       1
2            7                      2
3            8                      2
4            9                     2
5            10                    2
...
11           16                    2

Модели:

 class Conference extends Model{
         public function categories(){
            return $this->belongsToMany('App\Category');
        }
    }

    class Category extends Model
    {
        public function conferences(){
            return $this->belongsToMany('App\Conference');
        }
    }

ДД (Category :: find (1) -> конференции) показывает:

Collection {#269
#items: array:2 [
0 => Conference {#273
#fillable: array:18 [
0 => "name"
...
]
#dates: array:2 [
0 => "start_date"
1 => "end_date"
]
#appends: array:1 [
0 => "price_range"
]
#connection: "mysql"
#table: null
#primaryKey: "id"
#keyType: "int"
+incrementing: true
#with: []
#withCount: []
#perPage: 15
+exists: true
+wasRecentlyCreated: false
#attributes: array:23 [
"id" => 1
"name" => "Conference title test"
...
]
#original: array:25 [
"id" => 1
"name" => "Conference title test"
...
]
#changes: []
#casts: []
#dateFormat: null
#dispatchesEvents: []
#observables: []
#relations: array:1 [
"pivot" => Pivot {#262
+pivotParent: Category {#268
#connection: "mysql"
#table: null
#primaryKey: "id"
#keyType: "int"
+incrementing: true
#with: []
#withCount: []
#perPage: 15
+exists: true
+wasRecentlyCreated: false
#attributes: array:5 [
"id" => 1
"name" => "Category1"
...
]
#original: array:5 [
"id" => 1
"name" => "Category1"
...
]
#changes: []
#casts: []
#dates: []
#dateFormat: null
#appends: []
#dispatchesEvents: []
#observables: []
#relations: array:1 [
"conferences" => Collection {#269}
]
#touches: []
+timestamps: true
#hidden: []
#visible: []
#fillable: []
#guarded: array:1 [
0 => "*"
]
}
#foreignKey: "category_id"
#relatedKey: "confenrece_id"
#guarded: []
#connection: "mysql"
#table: "category_conference"
#primaryKey: "id"
#keyType: "int"
+incrementing: true
#with: []
#withCount: []
#perPage: 15
+exists: true
+wasRecentlyCreated: false
#attributes: array:2 [
"category_id" => 1
"conference_id" => 1
]
#original: array:2 [
"category_id" => 1
"conference_id" => 1
]
#changes: []
#casts: []
#dates: []
#dateFormat: null
#appends: []
#dispatchesEvents: []
#observables: []
#relations: []
#touches: []
+timestamps: false
#hidden: []
#visible: []
#fillable: []
}
]
#touches: []
+timestamps: true
#hidden: []
#visible: []
#guarded: array:1 [
0 => "*"
]
}
1 => Conference {#270
#fillable: array:18 [
0 => "name"
1 => "description"
]
#dates: array:2 [
0 => "start_date"
1 => "end_date"
]
#appends: array:1 [
0 => "price_range"
]
#connection: "mysql"
#table: null
#primaryKey: "id"
#keyType: "int"
+incrementing: true
#with: []
#withCount: []
#perPage: 15
+exists: true
+wasRecentlyCreated: false
#attributes: array:23 [
"id" => 2
"name" => "conference test title 2"
...
]
#original: array:25 [
"id" => 2
"name" => "conference test title 2"
...
]
#changes: []
#casts: []
#dateFormat: null
#dispatchesEvents: []
#observables: []
#relations: array:1 [
"pivot" => Pivot {#267
+pivotParent: Category {#268}
#foreignKey: "category_id"
#relatedKey: "conference_id"
#guarded: []
#connection: "mysql"
#table: "category_conference"
#primaryKey: "id"
#keyType: "int"
+incrementing: true
#with: []
#withCount: []
#perPage: 15
+exists: true
+wasRecentlyCreated: false
#attributes: array:2 [
"category_id" => 1
"conference_id" => 2
]
#original: array:2 [
"category_id" => 1
"conference_id" => 2
]
#changes: []
#casts: []
#dates: []
#dateFormat: null
#appends: []
#dispatchesEvents: []
#observables: []
#relations: []
#touches: []
+timestamps: false
#hidden: []
#visible: []
#fillable: []
}
]
#touches: []
+timestamps: true
#hidden: []
#visible: []
#guarded: array:1 [
0 => "*"
]
}
]
}

1 Ответ

0 голосов
/ 18 мая 2018

Просто получите конференции из категории:

$conferences = Category::find($request->id)->conferences;

Как предложил Фаррух Айяз, привязка модели маршрута более элегантна:

Route::get('conferences/where/category/{category}', ...

public function WhereHasCategory(Category $category)
{
    return response()->json($category->conferences);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...