web-dev-qa-db-ja.com

Spring Data Cassandraを使用してJava.util.Date値をCassandra日付型列に挿入する方法は?

次のような日付型の列を持つcassandraテーブルがあります:

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

SpringBoot 1.5.2 + Spring Data Cassandraスターターを使用しています。

@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","[email protected]", 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型プロパティを使用することは可能ですか?

追伸: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();
    }

}

Connectinを作成するときは、登録する必要があります。

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/

12
Ashraful Islam