CoderFunda
  • Home
  • About us
    • Contact Us
    • Disclaimer
    • Privacy Policy
    • About us
  • Home
  • Php
  • HTML
  • CSS
  • JavaScript
    • JavaScript
    • Jquery
    • JqueryUI
    • Stock
  • SQL
  • Vue.Js
  • Python
  • Wordpress
  • C++
    • C++
    • C
  • Laravel
    • Laravel
      • Overview
      • Namespaces
      • Middleware
      • Routing
      • Configuration
      • Application Structure
      • Installation
    • Overview
  • DBMS
    • DBMS
      • PL/SQL
      • SQLite
      • MongoDB
      • Cassandra
      • MySQL
      • Oracle
      • CouchDB
      • Neo4j
      • DB2
      • Quiz
    • Overview
  • Entertainment
    • TV Series Update
    • Movie Review
    • Movie Review
  • More
    • Vue. Js
    • Php Question
    • Php Interview Question
    • Laravel Interview Question
    • SQL Interview Question
    • IAS Interview Question
    • PCS Interview Question
    • Technology
    • Other

18 May, 2022

Laravel looks to insert records in a table that does not exists

 Programing Coderfunda     May 18, 2022     Laravel, php     No comments   

 1

It's since two days that I'm trying to solve an issue that i face when i try to insert a record in the DB.

I'm building a project where an admin can create a list of places to visit for users.

I have created 3 tables and relative models as follow : places , place_categories, category_places (this the pivot table).

places table has the following inside :

 Schema::create('places', function (Blueprint $table) {
            $table->id();
            $table->timestamps();
            $table->string('google_place_id');
            $table->unsignedBigInteger('property_id');
            $table->foreign('property_id')->references('id')->on('properties');
        });

And the Place model has the following :

protected $fillable = [
        'google_place_id',
        'property_id'
    ];

    public function property(){
        return $this->belongsTo(Property::class);
    }

    public function category(){
        return $this->belongsToMany(PlaceCategory::class);
    }

The place_categories table has the following code :

 Schema::create('place_categories', function (Blueprint $table) {
            $table->id();
            $table->string('name');
            $table->timestamps();
        });

the PlaceCategory model has the following :

 protected $fillable = [
        'name'
    ];

    public function place(){
        return $this->belongsToMany(Place::class);
    }

While the pivot category_places table has the following :

 Schema::create('category__places', function (Blueprint $table) {
            $table->id();
            $table->unsignedBigInteger('place_id');
            $table->foreign('place_id')->references('id')->on('places');
            $table->unsignedBigInteger('category_id');
            $table->foreign('category_id')->references('id')->on('place_categories');
            $table->timestamps();
        });

And the Category_Place has the following code :

   protected $table = 'category_places';

    protected $fillable = [
        'category_id', 
        'place_id',
    ];
}

In my PlaceController, in the store method i wrote the following :

public function store(Request $request)
    {
        $googlePlaceId = $request->input('google_place_id');
        $propertyId= $request->input('property_id');
        $categories= $request->input('categories');
        

        $place = Place::create([
            'google_place_id' => $googlePlaceId,
            'property_id'=> $propertyId,
        ]);

        $place->category()->attach($categories);

        return redirect()->route('home', ['property'=> $propertyId])->with('message', 'Place correctly created');
    }

Now, when i try to insert a new place with relative categories i keep getting the following error :

SQLSTATE[42S02]: Base table or view not found: 1146 Table 'myhosthtl.place_place_category' doesn't exist
insert into `place_place_category` (`place_category_id`, `place_id`) values (1, 3)

So he's looking for a table called place_place_category that obviously does not exist, but where do he get this table from? I have also declared the protected $table in my Category_Place model.

After debugging a bit the code, i found out the the error i thrown at line 63 in the store method at this line :

  $place->category()->attach($categories);

It seem like he cant find the place_categories table, but he should insert in the category_places the record for the pivot, not in the places_categories.

Is there anybody able to help me? What Am i doing wrong?

Thank you so much for your help.

  • Share This:  
  •  Facebook
  •  Twitter
  •  Google+
  •  Stumble
  •  Digg
Email ThisBlogThis!Share to XShare to Facebook

Related Posts:

  • Smart Error Checking and Refactoring Development Tool for Laravel Microscope is a Laravel development tool that includes smart checks to discover errors related to your applications. The highlight features… Read More
  • Google Chat Laravel Notification Channel The Laravel Notification Channels project now has a Google Chat notification channel for Laravel. This package makes it easy… Read More
  • Laravel HTTP Client Logger HTTP Client Logger is a logger for the built-in Laravel HTTP client. It makes logging the request and response simple by sending it to a co… Read More
  • Use Leaflet.js and Google Maps Blade Components in Laravel Laravel Maps is a package to easily create maps using Leaflet.js or Google Maps and Blade components. The main features that work… Read More
  • Exclude Model Entities From Eloquent With the Laravel Exclusions Package Laravel Excludable is a package to exclude models from Eloquent queries. You can define a subset of models that should be exclude… Read More
Newer Post Older Post Home

0 comments:

Post a Comment

Thanks

Meta

Popular Posts

  • Spring boot app (error: method getFirst()) failed to run at local machine, but can run on server
    The Spring boot app can run on the online server. Now, we want to replicate the same app at the local machine but the Spring boot jar file f...
  • Log activity in a Laravel app with Spatie/Laravel-Activitylog
      Requirements This package needs PHP 8.1+ and Laravel 9.0 or higher. The latest version of this package needs PHP 8.2+ and Laravel 8 or hig...
  • Vue3 :style backgroundImage not working with require
    I'm trying to migrate a Vue 2 project to Vue 3. In Vue 2 I used v-bind style as follow: In Vue 3 this doesn't work... I tried a...
  • Laravel auth login with phone or email
          <?php     Laravel auth login with phone or email     <? php     namespace App \ Http \ Controllers \ Auth ;         use ...
  • Enabling authentication in swagger
    I created a asp.net core empty project running on .net6. I am coming across an issue when I am trying to enable authentication in swagger. S...

Categories

  • Ajax (26)
  • Bootstrap (30)
  • DBMS (42)
  • HTML (12)
  • HTML5 (45)
  • JavaScript (10)
  • Jquery (34)
  • Jquery UI (2)
  • JqueryUI (32)
  • Laravel (1017)
  • Laravel Tutorials (23)
  • Laravel-Question (6)
  • Magento (9)
  • Magento 2 (95)
  • MariaDB (1)
  • MySql Tutorial (2)
  • PHP-Interview-Questions (3)
  • Php Question (13)
  • Python (36)
  • RDBMS (13)
  • SQL Tutorial (79)
  • Vue.js Tutorial (68)
  • Wordpress (150)
  • Wordpress Theme (3)
  • codeigniter (108)
  • oops (4)
  • php (853)

Social Media Links

  • Follow on Twitter
  • Like on Facebook
  • Subscribe on Youtube
  • Follow on Instagram

Pages

  • Home
  • Contact Us
  • Privacy Policy
  • About us

Blog Archive

  • September (100)
  • August (50)
  • July (56)
  • June (46)
  • May (59)
  • April (50)
  • March (60)
  • February (42)
  • January (53)
  • December (58)
  • November (61)
  • October (39)
  • September (36)
  • August (36)
  • July (34)
  • June (34)
  • May (36)
  • April (29)
  • March (82)
  • February (1)
  • January (8)
  • December (14)
  • November (41)
  • October (13)
  • September (5)
  • August (48)
  • July (9)
  • June (6)
  • May (119)
  • April (259)
  • March (122)
  • February (368)
  • January (33)
  • October (2)
  • July (11)
  • June (29)
  • May (25)
  • April (168)
  • March (93)
  • February (60)
  • January (28)
  • December (195)
  • November (24)
  • October (40)
  • September (55)
  • August (6)
  • July (48)
  • May (2)
  • January (2)
  • July (6)
  • June (6)
  • February (17)
  • January (69)
  • December (122)
  • November (56)
  • October (92)
  • September (76)
  • August (6)

  • Failed to install 'cordova-plugin-firebase': CordovaError: Uh oh - 9/21/2024
  • pyspark XPath Query Returns Lists Omitting Missing Values Instead of Including None - 9/20/2024
  • SQL REPL from within Python/Sqlalchemy/Psychopg2 - 9/20/2024
  • MySql Explain with Tobias Petry - 9/20/2024
  • How to combine information from different devices into one common abstract virtual disk? [closed] - 9/20/2024

Laravel News

  • Sublime Text Releases Update With Support for Right Sidebar - 5/22/2025
  • Enhance Email Validation with Laravel's Fluent Email Rule Object - 5/18/2025
  • Locale-aware Number Parsing in Laravel 12.15 - 5/21/2025
  • Handle Fluent Values as Arrays with Laravel's array() Method - 5/18/2025
  • Chargebee Starter Kit for Billing in Laravel - 5/20/2025

Copyright © 2025 CoderFunda | Powered by Blogger
Design by Coderfunda | Blogger Theme by Coderfunda | Distributed By Coderfunda