根據您所看到的,我猜,attributes
未在表定義中定義的錯誤消息。你介意用這個編輯你的文章嗎?
但是,當我建立我的CQL表像這樣(注意itemid
複合分區鍵和version
):
CREATE TABLE products.itemmaster (
itemid text,
version int,
productid uuid,
supplierskumap map<uuid, text>,
PRIMARY KEY ((itemid,version), productid)
);
...插入該行:
INSERT INTO products.itemmaster (itemid,version,productid,supplierskumap)
VALUES ('item1',1,26893749-dcfc-42c7-892c-bee8c9cff630,
{1351f82f-5dc5-4328-82f4-962429c92a2b:'86CCG123'});
...和我建立我的POJO是這樣的:
@Table(keyspace = "products", name = "itemmaster")
public class Product {
@PartitionKey(0)
private String itemid;
@PartitionKey(1)
private int version;
@ClusteringColumn
private UUID productid;
@Column(name="supplierskumap")
private Map<UUID,String> suppliersku;
public UUID getProductid() {
return productid;
}
public void setProductid(UUID _productid) {
this.productid = _productid;
}
public int getVersion() {
return this.version;
}
public void setVersion(int _version)
{
this.version = _version;
}
public String getItemid() {
return itemid;
}
public void setItemid(String _itemid) {
this.itemid = _itemid;
}
public Map<UUID, String> getSuppliersku() {
return suppliersku;
}
public void setSuppliersku(Map<UUID, String> _suppliersku) {
this.suppliersku = _suppliersku;
}
}
...用這個構造函數和我的數據訪問對象(DAO)上方法:
public ProductsDAO()
{
session = connect(CASSANDRA_NODES, USERNAME, PASSWORD);
prodMapper = new MappingManager(session).mapper(Product.class);
}
public Product getProd(String itemid, int version, UUID productid) {
return prodMapper.get(itemid,version,sku);
}
...那麼這個main
類成功查詢我的表格和地圖我Map
:
private static void main(String[] args) {
ProductsDAO dao = new ProductsDAO();
Product prod = dao.getProd("item1", 1, UUID.fromString("26893749-dcfc-42c7-892c-bee8c9cff630"));
System.out.println(
prod.getProductid() + " - " +
prod.getItemid() + " - " +
prod.getSuppliersku().get(UUID.fromString("1351f82f-5dc5-4328-82f4-962429c92a2b")));
dao.closeCassandra();
}
...併產生這樣的輸出:
26893749-dcfc-42c7-892c-bee8c9cff630 - item1 - 86CCG123
注意:編輯上述示例以支持複合分區鍵。
你可以分享你的'創建表'cql嗎?這可能只是抱怨沒有「屬性」列。驅動程序將爲每個查詢創建預先準備好的語句,這些語句將作爲您聲明的模型的結果進行生成,而且看起來服務器正在拒絕這個語句。 –
是的,你是正確的問題解決。 –