即使值匹配,文档和标头之间的 CosmosDB 分区键值不匹配也会出现错误
php小编西瓜在介绍CosmosDB时指出,即使值匹配,文档和标头之间的分区键值不匹配也会出现错误。CosmosDB是一种全球分布式数据库服务,它使用分区键将数据分布在不同的物理分区上。分区键是指在写入文档时指定的某个值,它决定了文档将被存储在哪个分区中。如果文档的分区键值与标头中指定的分区键值不匹配,将会导致错误的查询结果或者查询失败。因此,在使用CosmosDB时,我们需要确保文档的分区键值与标头中指定的分区键值保持一致,以避免出现错误。
问题内容
我正在使用 azure-sdk-for-go 包 azcosmos 在 cosmosdb 容器中创建项目。这是我当前收到的错误:
-------------------------------------------------------------------------------- response 400: 400 bad request error code: badrequest -------------------------------------------------------------------------------- { "code": "badrequest", "message": "message: {\"errors\":[\"partitionkey extracted from document doesn't match the one specified in the header. learn more: https:\\/\\/aka.ms\\/cosmosdb\\/sql\\/errors\\/wrong-pk-value\"]}\r\nactivityid: 9ef3ec05-b381-48c8-bd4e-96a7cb764041, request uri: /apps/d27ef9bf-18ce-4431-b8de-709648aab568/services/2c472c3b-bd86-4593-8539-814c29caac51/partitions/31299a87-b895-4b13-91c0-788756ca5ff3/replicas/132790818155726834p/, requeststats: \r\nrequeststarttime: 2023-02-23t20:53:15.4424439z, requestendtime: 2023-02-23t20:53:15.4424439z, number of regions attempted:1\r\n{\"systemhistory\":[{\"dateutc\":\"2023-02-23t20:52:06.4715437z\",\"cpu\":1.012,\"memory\":479419988.000,\"threadinfo\":{\"isthreadstarving\":\"false\",\"threadwaitintervalinms\":0.0224,\"availablethreads\":32764,\"minthreads\":52,\"maxthreads\":32767},\"numberofopentcpconnection\":431},{\"dateutc\":\"2023-02-23t20:52:16.4816322z\",\"cpu\":2.342,\"memory\":480026956.000,\"threadinfo\":{\"isthreadstarving\":\"false\",\"threadwaitintervalinms\":0.0193,\"availablethreads\":32761,\"minthreads\":52,\"maxthreads\":32767},\"numberofopentcpconnection\":431},{\"dateutc\":\"2023-02-23t20:52:26.4918299z\",\"cpu\":1.534,\"memory\":480000572.000,\"threadinfo\":{\"isthreadstarving\":\"false\",\"threadwaitintervalinms\":0.0158,\"availablethreads\":32764,\"minthreads\":52,\"maxthreads\":32767},\"numberofopentcpconnection\":437},{\"dateutc\":\"2023-02-23t20:52:36.5019603z\",\"cpu\":1.490,\"memory\":480000576.000,\"threadinfo\":{\"isthreadstarving\":\"false\",\"threadwaitintervalinms\":0.0161,\"availablethreads\":32737,\"minthreads\":52,\"maxthreads\":32767},\"numberofopentcpconnection\":438},{\"dateutc\":\"2023-02-23t20:52:46.5121122z\",\"cpu\":1.306,\"memory\":479989504.000,\"threadinfo\":{\"isthreadstarving\":\"false\",\"threadwaitintervalinms\":0.0204,\"availablethreads\":32762,\"minthreads\":52,\"maxthreads\":32767},\"numberofopentcpconnection\":438},{\"dateutc\":\"2023-02-23t20:53:06.5323276z\",\"cpu\":1.561,\"memory\":479914676.000,\"threadinfo\":{\"isthreadstarving\":\"false\",\"threadwaitintervalinms\":0.0113,\"availablethreads\":32763,\"minthreads\":52,\"maxthreads\":32767},\"numberofopentcpconnection\":424}]}\r\nrequeststart: 2023-02-23t20:53:15.4424439z; responsetime: 2023-02-23t20:53:15.4424439z; storeresult: storephysicaladdress: rntbd://cdb-ms-prod-westus1-fd44.documents.azure.com:14323/apps/d27ef9bf-18ce-4431-b8de-709648aab568/services/2c472c3b-bd86-4593-8539-814c29caac51/partitions/31299a87-b895-4b13-91c0-788756ca5ff3/replicas/132790818155726834p/, lsn: 9427, globalcommittedlsn: 9427, partitionkeyrangeid: 0, isvalid: true, statuscode: 400, substatuscode: 1001, requestcharge: 1.24, itemlsn: -1, sessiontoken: -1#9427, usinglocallsn: false, transportexception: null, belatencyms: 1.004, activityid: 9ef3ec05-b381-48c8-bd4e-96a7cb764041, retryafterinms: , transportrequesttimeline: {\"requesttimeline\":[{\"event\": \"created\", \"starttimeutc\": \"2023-02-23t20:53:15.4424439z\", \"durationinms\": 0.0115},{\"event\": \"channelacquisitionstarted\", \"starttimeutc\": \"2023-02-23t20:53:15.4424554z\", \"durationinms\": 0.0114},{\"event\": \"pipelined\", \"starttimeutc\": \"2023-02-23t20:53:15.4424668z\", \"durationinms\": 0.1556},{\"event\": \"transit time\", \"starttimeutc\": \"2023-02-23t20:53:15.4426224z\", \"durationinms\": 1.8731},{\"event\": \"received\", \"starttimeutc\": \"2023-02-23t20:53:15.4444955z\", \"durationinms\": 0.1408},{\"event\": \"completed\", \"starttimeutc\": \"2023-02-23t20:53:15.4446363z\", \"durationinms\": 0}],\"serviceendpointstats\":{\"inflightrequests\":1,\"openconnections\":1},\"connectionstats\":{\"waitforconnectioninit\":\"false\",\"callspendingreceive\":0,\"lastsendattempt\":\"2023-02-23t20:35:31.6351618z\",\"lastsend\":\"2023-02-23t20:35:31.6351618z\",\"lastreceive\":\"2023-02-23t20:35:31.6351618z\"},\"requestsizeinbytes\":551,\"requestbodysizeinbytes\":26,\"responsemetadatasizeinbytes\":186,\"responsebodysizeinbytes\":166};\r\n resourcetype: document, operationtype: create\r\n, sdk: microsoft.azure.documents.common/2.14.0" } --------------------------------------------------------------------------------
我的代码如下:
// load .env err := godotenv.Load() handle(err) // create CosmosDB credentials endpoint := os.Getenv("AZURE_COSMOS_ENDPOINT") key := os.Getenv("AZURE_COSMOS_KEY") cred, err := azcosmos.NewKeyCredential(key) handle(err) // create CosmosDB client client, err := azcosmos.NewClientWithKey(endpoint, cred, nil) handle(err) log.Println("CosmosDB client has been successfully created...") // create Container instance to perform read-write operations container, err := client.NewContainer("vaporwave", "employees") handle(err) log.Println("Container has been successfully created...") // generate a PartitionKey and example item pk := azcosmos.NewPartitionKeyString("/_partitionKey") item := map[string]string{ "id": "1", "value": "2", } marshalled, err := json.Marshal(item) handle(err) // create container item itemResponse, err := container.CreateItem(context.Background(), pk, marshalled, nil) if err != nil { var responseErr *azcore.ResponseError errors.As(err, &responseErr) log.Fatal(responseErr) } log.Printf("Item created. ActivityId %s consuming %v RU\n", itemResponse.ActivityID, itemResponse.RequestCharge)
这遵循 azcosmos 示例测试中创建项目的模式(请参阅examplecontainerclient_createitem 函数)。 azure 门户中容器分区键的屏幕截图。我如何继续收到此错误?看来pk值与我相符,也许我错过了一些东西。
解决方法
您的问题已上线:
pk := azcosmos.newpartitionkeystring("/_partitionkey")
这与其他问题的情况相同:https://www.php.cn/link/e8c1bdc555e17fd06b44ea4d3b4adbda
容器具有分区键定义/路径,该分区键定义/路径是在创建容器期间设置的,它是将包含分区键值的属性的 json 路径。
如果您的路径是 /_partitionkey
那么:
- 文档正文中应该有一个名为
_partitionkey
的属性 - 您的代码应为
pk := azcosmos.newpartitionkeystring("<该属性的值")
就您而言,您的主体没有 _partitionkey
属性:
item := map[string]string{ "id": "1", "value": "2", }
所以您需要添加它。
或者重新评估 /_partitionkey
是否确实是适合您的容器/用例的正确分区键定义/路径,也许它是不同的。无论是哪一个,“项目”操作都需要值。
以上是即使值匹配,文档和标头之间的 CosmosDB 分区键值不匹配也会出现错误的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

不要改变原内容的意思,微调内容,重写内容,不要续写红米Note13RPro不仅性能出色,使用体验更加出色,为了让大家有更舒适的使用体验,红米Note13RPro配备了字体调整功能,让用户能够调整自己的手机的字体。如果你想知道红米Note13RPro怎么调整字体大小,那么就来看一看吧。红米Note13RPro怎么调整字体大小?1.打开“设置”应用程序。2.滚动到底部,选择“显示”。3.点击“文字大小”。4.在此屏幕上,您可以通过拖动滑块调整字体大小或者选择预设字体大小。5.调整完毕后,按“确定”保

自 2009 年问世以来,比特币成为加密货币界的领头羊,其价格经历了巨大的波动。为了提供全面的历史概述,本文汇集了从 2009 年到 2025 年的比特币价格数据,涵盖了重大的市场事件、市场情绪变化和影响价格走势的重要因素。

RedmiNote13RPro这款手机最近是非常火爆的,很多消费者都购买了这款手机,不过很多用户是第一次使用这款手机所以不清楚红米Note13RPro怎么连接电脑,对此,小编在这里为大家带来了详细的教程介绍。红米Note13RPro怎么连接电脑?1.使用USB数据线将红米手机连接到电脑的USB接口上。2.打开手机设置,击选项,将USB调试打开。3.在电脑上打开设备管理器,找到移动设备选项。4.右键点击移动设备,选择更新驱动程序,然后选择自动搜索更新的驱动程序。5.如果电脑没有自动搜索到驱动程序,

红米Note13RPro手机在软件功能上集成了多项智能工具,其中,从图片中快速准确地提取文字内容便是其中之一,下面小编将为大家介绍红米Note13RPro如何提取图片中的文字。红米Note13RPro怎么提取图中的文字?使用小米扫码功能,打开手机的扫码应用,点击图片图标,选择一张图片,然后点击右边的“识别文字”选项,成功提取出图片中的文字。通过手机相册操作。在手机相册中找到需要提取文字的图片,点击图片下方的“更多”,选择“提取文字”,识别成功后,可以根据需要复制或保存文本。利用微信小程序。打开微

整个活吧是一款非常好玩的休闲解谜小游戏,大家可以在多平台体验!游戏提供了无数精彩的关卡等待解锁,每个关卡都充满了新奇和挑战,让你体验回答问题的有趣冒险,开启全新的游戏内容。那么整个活吧全关卡怎么通关呢?今天给大家带来了《整个活吧》全关卡通关攻略大全分享,大家过关遇到问题可以来参考一下哦!《整个活吧》全关卡通关攻略大全《整个活吧》全关卡通关攻略大全帮她守岁人鬼情未了帮小姐姐识别渣男狼外婆帮小女孩脱离危险户外探险假装看不见阿飘变回人形帮猩猩修成人形后座有人保持镇定和女鬼周旋夜班出租车保持镇定和女鬼周

整个活吧是抖音上非常火爆的趣味闯关小游戏,游戏中有超多的关卡等大家挑战!游戏中关卡拯救邻居这一关需要劝所有邻居下楼,具体怎么过关呢?下面是小编给大家带来的《整个活吧》拯救邻居劝所有邻居下楼通关攻略,不清楚如何过关的小伙伴们一起来看看吧,希望能帮到大家。《整个活吧》拯救邻居劝所有邻居下楼通关攻略拯救邻居劝所有邻居下楼1、楼下有人需要急救2、楼下书店在卖绝版学习资料3、楼下垃圾桶好多纸箱子4、我答应约会,你先下楼5、你家哥哥来咱们小区做推广了6、有人发现了新的钓鱼点7、拖动猫罐头到楼下8、拖动叉子给

整个活吧是抖音上非常火爆的趣味闯关小游戏,游戏中有超多的关卡等大家挑战!游戏中叛逆期这一关需要让母女相互理解并和好,具体如何过关呢?下面是小编给大家带来的《整个活吧》叛逆期让母女相互理解并和好通关攻略,不清楚如何过关的小伙伴们一起来看看吧,希望能帮到大家。《整个活吧》叛逆期让母女相互理解并和好通关攻略叛逆期让母女相互理解并和好1、拖动书包给妈妈2、拖动下图所示物品给两个人3、向下滑动右边的时间4、点击书包《整个活吧》全关卡通关攻略大全帮她守岁人鬼情未了帮小姐姐识别渣男狼外婆帮小女孩脱离危险户外探

本站5月8日消息,视频电子标准协会(VESA)今天发布新闻稿,宣布DisplayHDR1.2规范,并表示目前全球有超过3000款显示器型号通过DisplayHDR标准认证。DisplayHDR1.2版本规范带来了更严格的性能要求,对亮度、色域和位深度之外,还引入色彩精度、对比度、黑电平(blacklevel,指在经过一定校准的显示装置上,没有一行光亮输出的视频信号电平)和字幕闪烁的多项新测试要求。DisplayHDRv1.2改进了白色亮度级别测试,将黑色背景上的10%中心色块测试更改为非黑色背景
