Symfony and Doctrine making migration with no effect
Doctrine is generating migration in symfony and nothing changes afer running the migration so during next diff it is the same. How to make Doctrine not generate this migration? Running the alter table command manually does not remove column collation.
bin/console doctrine:migration:diff
up
$this->addSql('ALTER TABLE session CHANGE sess_id sess_id VARCHAR(128) NOT NULL');
down
$this->addSql('ALTER TABLE session CHANGE sess_id sess_id VARCHAR(128) NOT NULL COLLATE utf8_unicode_ci');
Table looks like that:
show create table session;
CREATE TABLE session
( sess_id
varchar(128) COLLATE utf8_unicode_ci NOT NULL, sess_data
longblob NOT NULL, sess_time
int(11) NOT NULL, sess_lifetime
int(11) NOT NULL, PRIMARY KEY ( sess_id
) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci
Entity is after adding collation like below
<?php
namespace AppEntity;
use DoctrineORMMapping as ORM;
/**
* Session
*
* @ORMTable(name="session")
* @ORMEntity(repositoryClass="AppRepositorySessionRepository")
*/
class Session
{
/**
* @var string
*
* @ORMColumn(name="sess_id", type="string", length=128, options={"collation":"utf8_unicode_ci"})
* @ORMId
* @ORMGeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @var string
*
* @ORMColumn(name="sess_data", type="blob")
*/
private $sessData;
/**
* @var int
*
* @ORMColumn(name="sess_time", type="integer")
*/
private $sessTime;
/**
* @var int
*
* @ORMColumn(name="sess_lifetime", type="integer")
*/
private $sessLifetime;
/**
* Get id
*
* @return string
*/
public function getId()
{
return $this->id;
}
/**
* Get sessData
*
* @return string
*/
public function getSessData()
{
return $this->sessData;
}
/**
* Set sessData
*
* @param string $sessData
*
* @return Session
*/
public function setSessData($sessData)
{
$this->sessData = $sessData;
return $this;
}
/**
* Get sessTime
*
* @return int
*/
public function getSessTime()
{
return $this->sessTime;
}
/**
* Set sessTime
*
* @param integer $sessTime
*
* @return Session
*/
public function setSessTime($sessTime)
{
$this->sessTime = $sessTime;
return $this;
}
/**
* Get sessLifetime
*
* @return int
*/
public function getSessLifetime()
{
return $this->sessLifetime;
}
/**
* Set sessLifetime
*
* @param integer $sessLifetime
*
* @return Session
*/
public function setSessLifetime($sessLifetime)
{
$this->sessLifetime = $sessLifetime;
return $this;
}
}
尝试将其添加到列注释中:
/**
* @var string
*
* @ORMColumn(options={"collation":"utf8_unicode_ci"})
*/
private $sess_id;
I had a similar problem.
I use :
Solution :
For correct my problem, commented OR set value 'mariadb-10.2.14' on the property server_version
in config/packages/doctrine.yaml
.
Highly inspired by : https://github.com/doctrine/dbal/issues/2985
链接地址: http://www.djcxy.com/p/68784.html上一篇: 多核系统的编程和编译状态