php – Doctrine迁移表排序规则
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了php – Doctrine迁移表排序规则,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1523字,纯文字阅读大概需要3分钟。
内容图文
![php – Doctrine迁移表排序规则](/upload/InfoBanner/zyjiaocheng/734/898dc0306aad412d9fb1975da21b39fd.jpg)
试图找到一种以编程方式创建具有特定排序规则的表格的方法,但似乎无法找到如何正确完成的方法.我正在使用“doctrine / doctrine-migrations-bundle”:“2.1.*@dev”和Symfony 2.3,
我在config.yml中设置:
# Doctrine Configuration
doctrine:
dbal:
driver: "%database_driver%"
host: "%database_host%"
port: "%database_port%"
dbname: "%database_name%"
user: "%database_user%"
password: "%database_password%"
charset: LATIN1
orm:
auto_generate_proxy_classes: "%kernel.debug%"
entity_managers:
default:
auto_mapping: true
doctrine_migrations:
dir_name: %kernel.root_dir%/../src/CF/EscritorioBundle/Migrations
namespace: MyNameSpace\Migrations
table_name: migrations
name: Application Migrations
当我运行doctrine:database:create tool时,它使用LATIN1 charset和latin1_swedish_ci作为默认排序规则创建数据库.
然后我运行我的迁移,所有表都是utf8_general_ci
查看$schema-> createTable()函数,但无法找到传递我需要的排序规则的方法.这里适当的解决方法是什么?
解决方法:
嗯,这有点难看,但我找到的唯一方法是在所有表之后生成另一组迁移,这些迁移改变了表并转换了编码.迁移up()和down()函数看起来像:
......
/**
* @param Schema $schema
*/
public function up(Schema $schema)
{
// this up() migration is auto-generated, please modify it to your needs
$this->addSql("ALTER TABLE MyTable CONVERT TO CHARACTER SET LATIN1 COLLATE latin1_general_ci");
}
/**
* @param Schema $schema
*/
public function down(Schema $schema)
{
// this down() migration is auto-generated, please modify it to your needs
$this->addSql("ALTER TABLE MyTable CONVERT TO CHARACTER SET UTF8 COLLATE utf8_general_ci");
}
内容总结
以上是互联网集市为您收集整理的php – Doctrine迁移表排序规则全部内容,希望文章能够帮你解决php – Doctrine迁移表排序规则所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。