【PHP开辟框架】laravel入门教程之表与表之间的关联
2019-11-21php框架搜奇网129°c
A+ A-
起首关于表与表之间的关联
1.一对一
2.一对多
3.多对一
4.多对多
辨别父表与子表
1.”一”的是父表
2.”多”的一方是子表
怎样处置惩罚一对多关联
在子表中建一个字段(外键)指向父表
怎样处置惩罚多对多关联
竖立一张中心表,将”多对多”关联转化为”一对多”
案例剖析
表一: 用户表(it_user)
表二: 用户概况表(it_user_info)
表三: 文章表(it_article)
表四: 国度表(it_country)
表五: 用户角色表(it_role)
① 一对一
用户表(表一)与概况表(表二)就是一对一的关联
②一对多
用户表(表一)与文章表(表三)就是一对多的关联
③多对一
用户表(表一)与国度表(表四)就是多对一的关联
④多对多
用户表(表一)与角色表(表五)就是多对多的关联
用户表建表及测试数据
DROP TABLE IF EXISTS `it_user`; CREATE TABLE `it_user` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键', `name` varchar(64) DEFAULT NULL COMMENT '用户名', `password` char(32) DEFAULT NULL COMMENT '暗码(不运用md5)', `country_id` int(11) DEFAULT NULL, PRIMARY KEY (`id`), KEY `国度id` (`country_id`) ) ENGINE=MyISAM AUTO_INCREMENT=6 DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of it_user -- ---------------------------- INSERT INTO `it_user` VALUES ('1', 'xiaoming', '123456', '1'); INSERT INTO `it_user` VALUES ('2', 'xiaomei', '123456', '1'); INSERT INTO `it_user` VALUES ('3', 'xiaoli-new', '123', '1');
用户概况表建表及测试数据
-- ---------------------------- -- Table structure for it_user_info -- ---------------------------- DROP TABLE IF EXISTS `it_user_info`; CREATE TABLE `it_user_info` ( `user_id` int(11) NOT NULL AUTO_INCREMENT, `tel` char(11) DEFAULT NULL, `email` varchar(128) DEFAULT NULL, `addr` varchar(255) DEFAULT NULL, PRIMARY KEY (`user_id`) ) ENGINE=MyISAM AUTO_INCREMENT=4 DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of it_user_info -- ---------------------------- INSERT INTO `it_user_info` VALUES ('1', '13012345678', 'xiaoming@163.com', '北京'); INSERT INTO `it_user_info` VALUES ('2', '15923456789', 'xiaomei@163.com', '上海'); INSERT INTO `it_user_info` VALUES ('3', '18973245670', 'xiaoli@163.com', '武汉');
文章表建表及测试数据
-- ---------------------------- -- Table structure for it_article -- ---------------------------- DROP TABLE IF EXISTS `it_article`; CREATE TABLE `it_article` ( `id` int(11) NOT NULL AUTO_INCREMENT, `title` varchar(255) DEFAULT NULL, `content` text, `user_id` int(11) DEFAULT NULL, PRIMARY KEY (`id`), KEY `user_id` (`user_id`) ) ENGINE=MyISAM AUTO_INCREMENT=4 DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of it_article -- ---------------------------- INSERT INTO `it_article` VALUES ('1', '天下那末大,我想去看看', '钱包那末小,老是不够', '1'); INSERT INTO `it_article` VALUES ('2', '我想撞角遇到爱', '倒是遇到鬼', '2'); INSERT INTO `it_article` VALUES ('3', '哈哈哈哈', '嘻嘻嘻嘻', '1');
国度表建表及测试数据
-- ---------------------------- -- Table structure for it_country -- ---------------------------- DROP TABLE IF EXISTS `it_country`; CREATE TABLE `it_country` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of it_country -- ---------------------------- INSERT INTO `it_country` VALUES ('1', '中国'); INSERT INTO `it_country` VALUES ('2', '美国');
用户角色表建表及测试数据
-- ---------------------------- -- Table structure for it_role -- ---------------------------- DROP TABLE IF EXISTS `it_role`; CREATE TABLE `it_role` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=5 DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of it_role -- ---------------------------- INSERT INTO `it_role` VALUES ('1', '开辟'); INSERT INTO `it_role` VALUES ('2', '测试'); INSERT INTO `it_role` VALUES ('3', '治理');
用户和角色中心表表建表及测试数据
-- ---------------------------- -- Table structure for it_user_role -- ---------------------------- DROP TABLE IF EXISTS `it_user_role`; CREATE TABLE `it_user_role` ( `user_id` int(11) DEFAULT NULL, `role_id` int(11) DEFAULT NULL, KEY `role_id` (`role_id`), KEY `user_id` (`user_id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of it_user_role -- ---------------------------- INSERT INTO `it_user_role` VALUES ('1', '1'); INSERT INTO `it_user_role` VALUES ('1', '2'); INSERT INTO `it_user_role` VALUES ('1', '3'); INSERT INTO `it_user_role` VALUES ('2', '1'); INSERT INTO `it_user_role` VALUES ('3', '2');
准备工作
1、计划路由
在routes/web.php下写以下路由:
//ORM的关联关联 Route::get('/orm/relation/{mode}','ORM\UserController@relation');
2、在App/Http/Controllers/ORM/UserController.php编写relation要领
public function relation($mode) { switch ($mode){ case '1_1': { //一对一 } break; case '1_n': { //一对多 } break; case 'n_1': { //多对一 } break; case 'n_n': { //多对多 } break; default; } }
3、装置debug调试东西
3.1运用composer敕令装置
composer require barryvdh/laravel-debugbar
3.2、修正config/app.php文件,加载debugbar到laravel到项目中,在’providers’数组中到场以下设置:
Barryvdh\Debugbar\ServiceProvider::class,
除了装置debugbar调试东西外,也能够运用查询监听:编providers/AppServiceProvider.php的boot要领中到场以下代码
\DB::listen(function ($query) { var_dump($query->sql); var_dump($query->bindings); echo '<br>'; });
也能够打印出实行的sql语句。
一对一
1、建立Userinfo模子对象
进入cmd敕令行进入laravel项目地点目次实行以下敕令
php artisan make:model Userinfo
会在App目次下生成Userinfo.php
2、编辑Userinfo模子文件
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Userinfo extends Model { protected $table = 'user_info'; protected $primaryKey = 'user_id'; protected $fillable = ['user_id','tel','email','addr']; public $timestamps = false; }
3、编写UserModel, 到场一对一要领
<?php namespace App; use Illuminate\Database\Eloquent\Model; class UserModel extends Model { protected $table = 'user';//真是表名 protected $primaryKey = 'id';//主键字段,默以为id protected $fillable = ['name','password'];//能够操纵的字段 public $timestamps = false;//假如数据表中没有created_at和updated_id字段,则$timestamps则能够不设置, 默以为true public function Userinfo() { /* * @param [string] [name] [须要关联的模子类名] * @param [string] [foreign] [参数一指定数据表中的字段] * */ return $this->hasOne('App\Userinfo','user_id'); }
4、编写UserController, 挪用一对一要领
public function relation($mode) { switch ($mode){ case '1_1': { //一对一 $data = UserModel::find(1)->Userinfo()->get(); dd($data); } break; default; } }
一对多
1、建立article模子对象
实行敕令
php artisan make:model Article
在app下生成Article.php文件
2、编写article模子文件
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Article extends Model { protected $table = 'article'; protected $primaryKey = 'id'; protected $fillable = ['id','title','content','user_id']; public $timestamps = false; }
3、编写UserModel, 到场一对多要领
public function Artice() { return $this->hasMany('App\Article','User_id'); }
4、编写UserController,挪用一对多要领
public function relation($mode) { switch ($mode){ case '1_1': { //一对一 $data = UserModel::find(1)->Userinfo()->get(); dd($data); } break; case '1_n': { //一对多 $data = UserModel::find(1)->Artice()->get(); dd($data); } break; default; } } }
多对一
1、建立country模子对象
实行敕令
php artisan make:model Country
2、编写country模子文件
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Country extends Model { protected $table = 'country'; //实在表名 protected $primaryKey = "id"; //主键id protected $fillable = ['id','name']; //许可操纵的字段 public $timestamps = false; //假如数据表中没有created_at和updated_id字段,则$timestamps则能够不设置, 默以为true }
3、编写UserModel, 到场多对一要领
public function Country() { return $this->belongsTo('App\Country','country_id'); }
4、编写UserController, 挪用要领
public function relation($mode) { switch ($mode){ case '1_1': { //一对一 $data = UserModel::find(1)->Userinfo()->get(); dd($data); } break; case '1_n': { //一对多 $data = UserModel::find(1)->Artice()->get(); dd($data); } break; case 'n_1': { //多对一 $data = UserModel::find(1)->Country()->get(); dd($data); } break; default; } } }
多对多
1、建立role模子对象
实行敕令
php artisan make:model Role
实行敕令
php artisan make:model User_role
2、编写Role模子
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Role extends Model { protected $table = 'role'; protected $primaryKey = "id"; protected $fillable = ['name']; public $timestamps =false; }
编写User_role模子
由于表中没有主键字段,所以须要两个字段即可
<?php namespace App; use Illuminate\Database\Eloquent\Model; class User_role extends Model { protected $table = 'user_role'; public $timestamps =false; }
3、编写UserModel, 到场多对多要领
public function Role(){ /* * 第一个参数:要关联的表对应的类 * 第二个参数:中心表的表名 * 第三个参数:当前表跟中心表对应的外键 * 第四个参数:要关联的表跟中心表对应的外键 * */ return $this->belongsToMany('App\Role','user_role','user_id','role_id'); }
4、编写UserController, 挪用多对多要领
public function relation($mode) { switch ($mode){ case '1_1': { //一对一 $data = UserModel::find(1)->Userinfo()->get(); dd($data); } break; case '1_n': { //一对多 $data = UserModel::find(1)->Artice()->get(); dd($data); } break; case 'n_1': { //多对一 $data = UserModel::find(1)->Country()->get(); dd($data); } break; case 'n_n': { //多对多 $data = UserModel::find(2)->Role()->get(); dd($data); } break; default; } }
总结:
1、一对一运用要领:hasOne()
2、一对多运用要领:hasMany()
3、多对一运用要领:belongsTo()
4、多对多运用要领:belongsToMany()
ki4网,大批的免费laravel入门教程,迎接在线进修!
本文转自:https://blog.csdn.net/weixin_38112233/article/details/79220535
以上就是laravel入门教程之表与表之间的关联的细致内容,更多请关注ki4网别的相干文章!