首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在编写Java字符串之前,如何检查它是否适合Cassandra文本列?

在编写Java字符串之前,如何检查它是否适合Cassandra文本列?
EN

Stack Overflow用户
提问于 2021-05-17 15:04:25
回答 1查看 102关注 0票数 2

我们支持一个有一些糟糕设计的应用程序。此应用程序将数据存储在文本列中的Cassandra集群中,有时会在该列中写入相当大的字符串,我们将得到一个WriteFailureException.

Cassandra对写入大小有限制(默认为16 is:kb),这是很好的。我们想通知用户,如果达到这样的限制,他们正在尝试编写大量数据。据我所知,没有办法区分这个异常是因为这个限制而发生的,还是由于Cassandra集群中的任何其他错误而发生的。

试图用Cassandra编写它之前,检查日期的大小是否超过了极限的会更好。Java是UTF-16,Cassandra的文本是UTF-8,所以我天真的方法是将字符串转换为UTF-8,并检查它的大小:s.getBytes(StandardCharsets.UTF_8).lenght()

然而,这似乎是相当昂贵的转换字符串到UTF-8,只是为了扔掉它。有什么明智的办法吗?在编写数据之前,人们如何检查数据是否符合卡桑德拉的要求?

Java 8,Cassandra 3.11

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-05-17 16:10:16

更好的方法是检查请求的大小,而不是单个字符串的大小,因为它也依赖于协议版本。如果使用准备好的语句,则可以绑定值,然后对绑定语句(对于驱动程序3.x)调用requestSizeInBytes,如下所示(源代码)

代码语言:javascript
复制
int stmtSize = boundStatement.requestSizeInBytes(protocolVersion, codecRegistry);

对于驱动程序4.x,它是computeSizeInBytes函数(文档)

但是考虑到它的近似大小,但无论如何它可能是相当好的近似

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67572280

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档