web-dev-qa-db-fra.com

Laravel - SQLSTATE [42000]: erreur de syntaxe ou violation d'accès: 1064 lors de la migration

Je n'ai jamais eu cette erreur jusqu'à présent, cela se produit lorsque je lance la migration de php artisan
J'utilise MySQL 5.6.34
.

[PDOException]
  SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax
  to use near 'unsigned not null, `address_1` varchar(191) unsigned not null, `address_2` varch' at line 1

Voici mon fichier de migration

public function up()
    {
        Schema::create('rmaRequests', function (Blueprint $table) {
           $table->increments('id');
           $table->integer('user_id')->unsigned();
           $table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');
           $table->string('reference_number')->unique();
           $table->string('first_name');
           $table->string('last_name');
           $table->string('email');
           $table->string('phone');
           $table->string('fax');
           $table->string('company');
           $table->integer('marketplaceId')->unsigned();
           $table->string('order_number')->unsigned();
           $table->string('address_1');
           $table->string('address_2');
           $table->string('city');
           $table->string('state');
           $table->string('Zip');
           $table->integer('returnTypeId')->unsigned();
           $table->string('sku');
           $table->string('qty');
           $table->string('productName');
           $table->text('comments');
           $table->integer('status_id')->unsigned();
           $table->string('replacement_tracking');
           $table->string('return_tracking');
           $table->string('rma_number');
           $table->string('refund_number');
           $table->timestamps();
        });
    }



/**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::drop('rmaRequests');
    }
7
Yosef

Je pense que c'est parce que vous utilisez unsigned vers un varchar?

Ici:

$table->string('order_number')->unsigned();

La méthode unsigned() dans la description Laravel:

Définissez les colonnes integer sur UNSIGNED

Pour plus d'informations: https://laravel.com/docs/5.4/migrations#column-modifiers

13
Wreigh