我需要使用Java低级API在整个图中找到特定节点.我曾经使用版本1.x中的Reference节点执行此操作,但该概念已在2.0版本中删除.
我以为我可以使用标签来执行此操作:我会在创建时为此节点(并且只有此节点)分配标签.随后我将获得具有此特定标签的所有节点,该标签应返回单个命中,即我正在寻找的特殊节点.不幸的是,我找不到使用Java API查找具有特定标签的所有节点的方法.
我能够用Cypher做到这一点,但我希望看起来尽可能快,因此节省查询解析,规划和执行的成本将是巨大的.
我在Cassandra有以下专栏系列:
CREATE TABLE item_index (
foo_id text,
bar_id text,
bar_metadata text,
bar_url text,
PRIMARY KEY (foo_id, bar_id)
) WITH
bloom_filter_fp_chance=0.010000 AND
caching='KEYS_ONLY' AND
comment='' AND
dclocal_read_repair_chance=0.000000 AND
gc_grace_seconds=864000 AND
read_repair_chance=0.100000 AND
replicate_on_write='true' AND
populate_io_cache_on_flush='false' AND
compaction={'class': 'SizeTieredCompactionStrategy'} AND
compression={'sstable_compression': 'SnappyCompressor'};
Run Code Online (Sandbox Code Playgroud)
我试图在cqlsh中使用此查询检索匹配25个特定bar_id列表的所有行:
SELECT * FROM stagekeyspace.item_index WHERE foo_id IN ('1947dccc791ace5eb40dd2f00d9d876f')
AND bar_id IN ('5f715d9f4a1a97b8fb54996bca5b0d91','64a8708d33b426315480b127a36663fd',
'b5f788e2c5b6e0bdfa3fc76d0f3e4fac','b6da801b86fd27e7382f5b6ce6dedf4d',
'c2e6586c0c9867157a4789a2ba3fb3c1','dc784b35764c6a3fbf083a6da59ad475',
'09c436ce046905b018a1e3fa417ee04a','0b4b5bd9c339353f6c16fcd822f50d6b',
'0c8e2e54c4629767b548830e122f295b','106735c6a97f8c8b006b9e0dbe18585e',
'11135d45b78086bc386bd9e538409915','269e2fbb4ce98f74471ec2fd0fffaa7a',
'2d2462fada062a160e60d537ab58ef81','30c617bd0dc41fde670c3796ad98ff65',
'32b458cae9762541a64e5f60b29f064c','36884ff28272675befb800eccc49b691',
'3b7f30db8c6594c5ec677d3465d47735','4054aedd79682a798d862e431be27636',
'4bee7a9cc7fd74a55e640ef6aca3864c','578e241dad54248261c341526563448b',
'59283ec34b7faa9db1c0befa38e34ea2','64a0fdc8019b32a5768900c6c30a6e66',
'65a767a4e7df8a06701c806f417c1de7','6719ab0291205b374cd50577f0a16ad7',
'6bde8f55ddb7764138d4937dfaf85795');
Run Code Online (Sandbox Code Playgroud)
这将返回21"行",即使它应返回25行,每个bar_id一行.
为了确认所有25个bar_id的数据都存在,我运行了以下查询,一次使用一个bar_id:
SELECT * FROM stagekeyspace.item_index WHERE foo_id IN
('1947dccc791ace5eb40dd2f00d9d876f') AND bar_id IN ('5f715d9f4a1a97b8fb54996bca5b0d91');
Run Code Online (Sandbox Code Playgroud)
所有25个查询都返回包含正确数据的行. …