gpt4 book ai didi

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

转载 作者:搜寻专家 更新时间:2023-10-31 08:25:19 25 4
gpt4 key购买 nike

我有一个带有日期类型列的 cassandra 表,如下所示:

create table people
(
id int primary key,
name text,
email text,
dob date
);

我正在使用 SpringBoot 1.5.2 + Spring Data Cassandra Starter。

@Table("people")
public class Person {
@PrimaryKey
Integer id;
private String name;
private String email;
private java.util.Date dob;
//setters and getters
}

public interface PersonRepository extends CrudRepository<Person, Integer>{

}

我按如下方式插入新人:

personRepository.save(new Person(1, "Siva","siva@gmail.com", new java.util.Date()));

它抛出以下错误:

Caused by: com.datastax.driver.core.exceptions.InvalidQueryException: Expected 4 byte long for date (8)
at com.datastax.driver.core.Responses$Error.asException(Responses.java:136) ~[cassandra-driver-core-3.1.4.jar:na]
at com.datastax.driver.core.DefaultResultSetFuture.onSet(DefaultResultSetFuture.java:179) ~[cassandra-driver-core-3.1.4.jar:na]
at com.datastax.driver.core.RequestHandler.setFinalResult(RequestHandler.java:177) ~[cassandra-driver-core-3.1.4.jar:na]
at com.datastax.driver.core.RequestHandler.access$2500(RequestHandler.java:46) ~[cassandra-driver-core-3.1.4.jar:na]

但是如果我将 dob 列类型设置为 timestamp 那么它工作正常。是否可以使用 date 类型的列并使用 java.util.Date 类型的属性?

P.s:即使我使用 java.sql.Date 我也会遇到同样的错误。

最佳答案

使用 com.datastax.driver.core.LocalDate

您可以使用这些方法中的任何一种从 java.util.Date 获取 LocalDate

  • 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> codec, Class<Date> javaClass) {
super(codec.getCqlType(), javaClass);
innerCodec = codec;
}

@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();
}

}

创建连接时你必须注册:

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

更多信息:http://docs.datastax.com/en/developer/java-driver/3.1/manual/custom_codecs/

关于java - 如何使用 Spring Data Cassandra 将 java.util.Date 值插入到 Cassandra 日期类型列中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43064133/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com