php – 如何在eloquent中创建多列主键

发布时间:2022-04-30 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了php – 如何在eloquent中创建多列主键脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
我将Managers,Course_TyPE和Course Years存储在数据库中.

我将根据递增的值来命名我的课程,例如

Course_type    course_order      course_year

    Course_type[0]      1              2015 
    Course_type[0]      2              2015
    Course_type[0]      3              2015
    Course_type[0]      4              2015
    Course_type[0]      1              2016
    Course_type[1]      1              2015
    Course_type[2]      1              2015
    Course_type[2]      2              2015

所以我创建数据库就像

Schema::create('courses',function (BluePRint $table) {
            $table->increments('id');
            $table->enum('course_type',[
                'Yos','Tomerabc','TomerA1A2','TomerB1B2','TomerC1C2','TomerAB','TomerBC','SatMatGeo','SatCriRea','SatCriReamat',]);

            $table->integer('added_by');
            $table->integer('start');
            $table->integer('year_code');
            $table->integer('end');
            $table->integer('course_order');
            $table->unique( array('added_by','year_code','course_order') );

这是我在createprocess上的控制器

$courSEOrder = \App\Courses::where('added_by',\Auth::id())
            ->where('year_code',$input['year_code'])->;max('course_order');

$course->course_order = $courSEOrder + 1;

但是因为我在数据库中寻找max(‘course_order’)如果我删除让我们说课程顺序2.接下来添加的课程将是4而不是3.

php – 如何在eloquent中创建多列主键

所以我的问题是如何在删除之后检查course_order之间的缺失值以填充位置?

P.S一个MysqL解决方案比我认为的更快,更好.

解决方法

您可以使用新表来存储已删除的记录. 当您首先需要一个新的course_order号码时,您应该检查DeletedCourses表.如果DeletedRecord有匹配的记录,则从DeletedRecords表中删除它并将其用于新的course_order.

脚本宝典总结

以上是脚本宝典为你收集整理的php – 如何在eloquent中创建多列主键全部内容,希望文章能够帮你解决php – 如何在eloquent中创建多列主键所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。