donglin5770 2011-06-14 22:32
浏览 7
已采纳

Doctrine2:相关的密钥

I have following table (type, id, title).

When new object is created and type=1 id should be 1, next object with type=1 id=2... But when I create object with type=2 id should be 1.

How can I do it with Doctrine2 and Symfony2?

  • 写回答

3条回答 默认 最新

  • dongxi1680 2011-06-14 23:25
    关注

    Like other have said, Doctrine 2 does not do this out of the box. The common practice is to make the ID field auto increment and a primary key in which case this is not possible. Primary keys must be unique.

    With that said, a solution could be to use the entity manage to find the maximum value of ID where the type is the selected type and incrementing that value by 1.

    For example:

    // Retrieve the current maximum ID for the selected type
    $id = $em->createQuery("SELECT MAX(e.id) AS id FROM Entities\entity e WHERE e.type = ?1")
      ->setParameter(1, $type)
      ->getSingleScalarResult();
    
    // Set your current entity's ID
    $entity->setId(++$id);
    
    // Save the entity
    ...
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥60 用visual studio编写程序,利用间接平差求解水准网
  • ¥15 Llama如何调用shell或者Python
  • ¥20 谁能帮我挨个解读这个php语言编的代码什么意思?
  • ¥15 win10权限管理,限制普通用户使用删除功能
  • ¥15 minnio内存占用过大,内存没被回收(Windows环境)
  • ¥65 抖音咸鱼付款链接转码支付宝
  • ¥15 ubuntu22.04上安装ursim-3.15.8.106339遇到的问题
  • ¥15 blast算法(相关搜索:数据库)
  • ¥15 请问有人会紧聚焦相关的matlab知识嘛?
  • ¥15 网络通信安全解决方案