如何从Cassandra表中检索数据类型为"list"的列?

Sha*_*ava 5 java scala cql cassandra

我使用Scala连接Cassandra并在其中应用我的查询,我在Cassandra中创建了一个简单的表,它有两列row_id和row_values.row_id的数据类型为"varchar",row_values存储元素列表.我在表中插入了一些随机值,并希望检索这些值.用于创建表:

CREATE TABLE Matrix1(row_id VARCHAR PRIMARY KEY, row_values LIST<VARCHAR>);
Run Code Online (Sandbox Code Playgroud)

对于插入表格:

INSERT INTO Matrix1(row_id, row_values) VALUES ('abcd3', ['dsf23', 'fsf1','dsdf1']);
Run Code Online (Sandbox Code Playgroud)

现在我想检索值并使用Scala打印它们,我正在使用代码来保存查询中的值

val results: ResultSet = session.execute("SELECT * FROM Matrix1 where row_id = 'abcd3'") 
Run Code Online (Sandbox Code Playgroud)

现在我要打印"row_id"和"row_values"

var rowid: String = null
var rowval: List[String] = null
for (row <- results) {
      rowid = row.getString("row_id")
      rowval = row.getList("row_values")
      }   
Run Code Online (Sandbox Code Playgroud)

使用此代码我在"rowid"中获取值,因为它是一个String,但"rowval"有错误.如何从ResultSet中检索列(列表类型)?

Cor*_*ave 7

尝试将类添加到getList方法:

row.getList("row_values", classOf[String])
Run Code Online (Sandbox Code Playgroud)