hi,你好!欢迎访问本站!登录
本站由简数采集腾讯云宝塔系统阿里云强势驱动
当前位置:首页 - 教程 - php框架 - 正文 君子好学,自强不息!

【PHP开辟框架】laravel入门教程之表与表之间的关联

2019-11-21php框架搜奇网89°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网别的相干文章!

  选择打赏方式
微信赞助

打赏

QQ钱包

打赏

支付宝赞助

打赏

  移步手机端
【PHP开辟框架】laravel入门教程之表与表之间的关联

1、打开你手机的二维码扫描APP
2、扫描左则的二维码
3、点击扫描获得的网址
4、可以在手机端阅读此文章

本文来源:搜奇网

本文地址:https://www.sou7.cn/282655.html

关注我们:微信搜索“搜奇网”添加我为好友

版权声明: 本文仅代表作者个人观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。请记住本站网址https://www.sou7.cn/搜奇网。

发表评论

选填

必填

必填

选填

请拖动滑块解锁
>>