Laravel hasManyThrough eloquent relationship tutorial example – onlinecode
In this post we will give you information about Laravel hasManyThrough eloquent relationship tutorial example – onlinecode. Hear we will give you detail about Laravel hasManyThrough eloquent relationship tutorial example – onlinecodeAnd how to use it also give you demo for it if it is necessary.
In this tutorial, today we discuss about laravel hasManyThrough Eloquent relationship. Eloquent ORM means Object-relational Mapping and laravel provides a beautiful activerecord stucture. so we can easy to interact with application database. let’s start about hasManyThrough eloquent relationship.
Laravel hasManyThrough Eloquent relationship is woking with three tables of database. For example, The category is connected with products and products with orders, then we can access all orders connected with a specific category. categories have many products and products have many orders.
here, see below database stucture.
Categories
– id
– name
Products
– id
– category_id
– title
Orders
– id
– product_id
Setting Database Configuration
After complete installation of laravel. we have to database configuration. now we will open the .env file and change the database name, username, password in the .env file. See below changes in a .env file.
DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=Enter_Your_Database_Name(has_many_through_relation) DB_USERNAME=Enter_Your_Database_Username(root) DB_PASSWORD=Enter_Your_Database_Password(root)
Create Table using migration
Now, We need to create a migration. so we will below command using create the categories, products and orders table migration.
php artisan make:migration create_categories_table --create=categories php artisan make:migration create_products_table --create=products php artisan make:migration create_orders_table --create=orders
After complete migration. we need below changes in the database/migrations/create_categories_table, database/migrations/create_products_table and database/migrations/create_orders_table file.
create_categories_table.php
<?php
use IlluminateSupportFacadesSchema;
use IlluminateDatabaseSchemaBlueprint;
use IlluminateDatabaseMigrationsMigration;
class CreateCategoriesTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('categories', function (Blueprint $table) {
$table->bigIncrements('id');
$table->string('name');
$table->timestamps();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::dropIfExists('categories');
}
}
?>
create_products_table.php
<?php
use IlluminateSupportFacadesSchema;
use IlluminateDatabaseSchemaBlueprint;
use IlluminateDatabaseMigrationsMigration;
class CreateProductsTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('products', function (Blueprint $table) {
$table->bigIncrements('id');
$table->bigInteger('category_id')->unsigned();
$table->foreign('category_id')->references('id')->on('categories')->onDelete('cascade');
$table->string('title');
$table->timestamps();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::dropIfExists('products');
}
}
?>
create_orders_table.php
<?php
use IlluminateSupportFacadesSchema;
use IlluminateDatabaseSchemaBlueprint;
use IlluminateDatabaseMigrationsMigration;
class CreateOrdersTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('orders', function (Blueprint $table) {
$table->bigIncrements('id');
$table->integer('product_id')->unsigned();
$table->foreign('product_id')->references('id')->on('products')->onDelete('cascade');
$table->timestamps();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::dropIfExists('orders');
}
}
?>
Run the below command. after the changes above file.
PHP - I Can't get the $_POST Values on Ajax Request
In this post we will give you information about PHP - I Can't get the $_POST Values on Ajax Request. Hear we will give you detail about PHP - I Can't get the $_POST Values on Ajax RequestAnd how to use it also give you demo for it if it is necessary.
I want to share this posts with you because when i was working on native PHP and Ajax Post request(Specially AngularJS Post request) at that time i can't get Post value on form submit. That's why i would like to share you this post. I also want to tell you i was working on my Ubuntu 14.04. I did try lot but i can't get value.
At last find stuff to how to solve this issue, i did use "file_get_contents('php://input')" that way i could get POST value in json object and i also decode json value using "json_decode()". So let's try this way :
Example:
$post = file_get_contents('php://input');
$post = json_decode($post);
$sql = "INSERT INTO items (title) VALUES ('".$post->title."')";
$result = $mysqli->query($sql);
Hope this code and post will helped you for implement PHP - I Can't get the $_POST Values on Ajax Request. if you need any help or any feedback give it in comment section or you have good idea about this post you can give it comment section. Your comment will help us for help you more and improve us. we will give you this type of more interesting post in featured also so, For more interesting post and code Keep reading our blogs
php artisan migrate
Create Model
Here below command help through we will create the Category, Product and Order model. we will also use “hasManyThrough()” or relationship of both model.
php artisan make:model Category php artisan make:model Product php artisan make:model Order
Category.php
<?php
namespace App;
use IlluminateDatabaseEloquentModel;
class Category extends Model
{
public function orders()
{
return $this->hasManyThrough(
'AppOrder',
'AppProduct',
'category_id', // Foreign key on products table...
'product_id', // Foreign key on orders table...
'id', // Local key on categories table...
'id' // Local key on products table...
);
}
}
?>
Product.php
<?php
namespace App;
use IlluminateDatabaseEloquentModel;
class Product extends Model
{
//
}
?>
Order.php
<?php
namespace App;
use IlluminateDatabaseEloquentModel;
class Order extends Model
{
//
}
?>
Route and Controller
We have to need put below code route in routes/web.
<?php
/*
|--------------------------------------------------------------------------
| 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!
|
*/
Route::get('/', function () {
return view('welcome');
});
Route::get('product','productsController@index');
?>
Here below command help to create the product controller.
php artisan make:controller ProductsController
ProductsController.php
<?php
namespace AppHttpControllers;
use AppOrder;
use AppCategory;
use IlluminateHttpRequest;
class ProductsController extends Controller
{
/**
* Display a listing of the resource.
*
* @return IlluminateHttpResponse
*/
public function index()
{
$cate = Category::find(1);
$cateOrders = $cate->orders;
//dd($cateOrders);
}
}
?>
Hope this code and post will helped you for implement Laravel hasManyThrough eloquent relationship tutorial example – onlinecode. if you need any help or any feedback give it in comment section or you have good idea about this post you can give it comment section. Your comment will help us for help you more and improve us. we will give you this type of more interesting post in featured also so, For more interesting post and code Keep reading our blogs