栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何使用Spring Data Cassandra将java.util.Date值插入Cassandra日期类型列中?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何使用Spring Data Cassandra将java.util.Date值插入Cassandra日期类型列中?

采用

com.datastax.driver.core.LocalDate

您可以使用以下任何一种方法

LocalDate
java.util.Date

  • LocalDate.fromYearMonthDay(2017,03,28)
  • LocalDate.fromMillisSinceEpoch(new Date()。getTime())

或者,您可以创建自己的编解码器,以允许您将其插入

java.util.Date
Cassandra日期类型。

您可以像下面这样开始:

public class DateCodec extends TypeCodec<Date> {    private final TypeCodec<LocalDate> innerCodec;    public DateCodec(TypeCodec<LocalDate> prec, Class<Date> javaClass) {        super(prec.getCqlType(), javaClass);        innerCodec = prec;    }    @Override    public ByteBuffer serialize(Date value, ProtocolVersion protocolVersion) throws InvalidTypeException {        return innerCodec.serialize(LocalDate.fromMillisSinceEpoch(value.getTime()), protocolVersion);    }    @Override    public Date deserialize(ByteBuffer bytes, ProtocolVersion protocolVersion) throws InvalidTypeException {        return new Date(innerCodec.deserialize(bytes, protocolVersion).getMillisSinceEpoch());    }    @Override    public Date parse(String value) throws InvalidTypeException {        return new Date(innerCodec.parse(value).getMillisSinceEpoch());    }    @Override    public String format(Date value) throws InvalidTypeException {        return value.toString();    }}

创建connectin时,必须注册:

CodecRegistry precRegistry = new CodecRegistry();precRegistry.register(new DateCodec(TypeCodec.date(), Date.class));Cluster.builder().withCodecRegistry(precRegistry).build();

有关更多信息:http : //docs.datastax.com/zh-CN/developer/java-
driver/3.1/manual/custom_precs/



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/402965.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号