【发布时间】:2023-03-10 18:37:01
【问题描述】:
使用 Doctrine ODM (MongoDB) 可以使用注解 Doctrine\ODM\MongoDB\Mapping\Annotations\Id 来设置文档的 ID。
因为我想使用哈希作为 ID,所以我这样设置我的文档:
class WebResource
{
/**
* @ODM\Id(strategy="NONE", type="bin_md5")
*
* @var string
*/
private $hash;
...
}
此配置将774a0f33ede410cde2d785e2d9e52561 之类的哈希转换为_id: 'Nzc0YTBmMzNlZGU0MTBjZGUyZDc4NWUyZDllNTI1NjE='。
现在,当我从文档中获取 $hash 时,我得到了值 774a0f33ede410cde2d785e2d9e52561。
这让我无法在 MongoDB Compass 中使用这样的查询:
{"_id": "774a0f33ede410cde2d785e2d9e52561"}
事实上,这个查询永远不会返回任何值,因为实际 ID 是Nzc0YTBmMzNlZGU0MTBjZGUyZDc4NWUyZDllNTI1NjE=。
如何通过 ID 找到文档,而只有其哈希尚未转换?
我尝试了很多方法:
- 使用
md5()php函数; - 使用
(new Binary($resource->getHash(), Binary::TYPE_MD5))->getData() - 使用
new \MongoBinData($resource->getHash(), \MongoBinData::MD5)
这些尝试似乎都不起作用。
有什么想法吗?
【问题讨论】:
标签: php mongodb doctrine doctrine-odm