douyong1885 2018-09-01 23:37
浏览 55
已采纳

Laravel - 它可能在表上添加外键,数据类型字符串是否未签名?

i have two table, table universitas and table fakultas

on schema table universitas like below

public function up()
    {
        Schema::create('universitas', function (Blueprint $table) {
            $table->string('id');
            $table->string('nama_universitas');
            $table->timestamps();
        });
    }

and table fakultas like below

public function up()
    {
        Schema::create('fakultas', function (Blueprint $table) {
            $table->increments('id');
            $table->string('nama_fakultas');
            $table->string('nama_universitas')->unsigned();
            $table->foreign('nama_universitas')->references('id')->on('universitas');
            $table->string('keterangan');
            $table->timestamps();
        });
    }

its possible if i use data type string and use unsigned?

when i executed with php artisan migrate, i get an Error

  • 写回答

1条回答 默认 最新

  • dongwei6457 2018-09-01 23:49
    关注

    The use of unsigned on a string makes no sense from a database perspective. The purpose of unsigned is to determine whether a numeric field can take negative values. For instance, a:

    $table->tinyInteger('foo');
    

    will create a database field that will take values between -128 and +128, whereas

    $table->tinyInteger('foo')->unsigned();
    

    will create a database field with the range 0 - 255

    The important thing with your foreign keys is that the datatype of the foreign key must match the datatype of the primary key of the other table, whether it is a number or a string.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 C#读写EXCEL文件,不同编译
  • ¥15 如何提取csv文件中需要的列,将其整合为一篇完整文档,并进行jieba分词(语言-python)
  • ¥15 MapReduce结果输出到HBase,一直连接不上MySQL
  • ¥15 扩散模型sd.webui使用时报错“Nonetype”
  • ¥15 stm32流水灯+呼吸灯+外部中断按键
  • ¥15 将二维数组,按照假设的规定,如0/1/0 == "4",把对应列位置写成一个字符并打印输出该字符
  • ¥15 NX MCD仿真与博途通讯不了啥情况
  • ¥15 win11家庭中文版安装docker遇到Hyper-V启用失败解决办法整理
  • ¥15 gradio的web端页面格式不对的问题
  • ¥15 求大家看看Nonce如何配置