[ 
https://issues.apache.org/jira/browse/CASSANDRA-20012?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Caleb Rackliffe updated CASSANDRA-20012:
----------------------------------------
    Change Category: Operability
         Complexity: Normal
      Fix Version/s: 5.0.x
                     5.x
          Reviewers: Caleb Rackliffe
             Status: Open  (was: Triage Needed)

> SAI (maybe) could support the blob CQL type
> -------------------------------------------
>
>                 Key: CASSANDRA-20012
>                 URL: https://issues.apache.org/jira/browse/CASSANDRA-20012
>             Project: Apache Cassandra
>          Issue Type: Improvement
>          Components: Feature/SAI
>            Reporter: Vincent Rischmann
>            Assignee: Terry Moschou
>            Priority: Normal
>             Fix For: 5.0.x, 5.x
>
>          Time Spent: 10m
>  Remaining Estimate: 0h
>
> Hello,
> we're currently exploring SAI for a use case, we have a table like this:
> ```
> CREATE TABLE ucp.profile (
>     project_key blob,
>     profile_id blob,
>     age int,
>     PRIMARY KEY ((project_key, profile_id))
> )
> ```
> we tried using a SAI index but we get an error:
> ``` 
> cqlsh:ucp> create custom index ucp_profile_project_key on ucp.profile 
> (project_key) using 'sai';
> InvalidRequest: Error from server: code=2200 [Invalid query] 
> message="Unsupported type: blob"
> ```
> The documentation is clear, it lists all the types that are supported, but it 
> didn't say _why_ the `blob` type is not supported and it seemed a little 
> weird to me that `blob` isn't supported because in my mind it should be the 
> easiest type to support; I have no clue if that is _true_ but I started to 
> investigate anyway.
> I took a look at the code and stumbled upon [this 
> line](https://github.com/apache/cassandra/blob/6bbe85ef51d2a5a52b9a585e7c1d3031a7fb0c80/src/java/org/apache/cassandra/index/sai/StorageAttachedIndex.java#L163-L168)
>  which lists all the supported types. I thought "why not just add the BLOB 
> type and see what happens ?"
> So that's basically what I did and to my surprise it _seems_ to work from my 
> limited testing:
> ```
> cqlsh:ucp> CREATE TABLE ucp.profile (    project_key blob,    profile_id 
> blob,   age int,    PRIMARY KEY ((project_key, profile_id)));
> cqlsh:ucp> create custom index ucp_profile_profile_id on ucp.profile 
> (profile_id) using 'sai';                                                     
>                                                    
> cqlsh:ucp> insert into profile(project_key, profile_id, age) values(0xcafe, 
> 0xdeadbeef, 200);                                                             
>                                               cqlsh:ucp> select * from 
> profile_id = 0xdeadbeef;                                                      
>                                                           
> cqlsh:ucp> select * from profile where profile_id = 0xdeadbeef;
>  project_key | profile_id | age
> -------------+------------+-----
>       0xcafe | 0xdeadbeef | 200
> (1 rows)
> ```
> I didn't test further, but I'm left wondering if it is simply an oversight 
> that blob are not supported with SAI today ? and if it is _not_ an oversight, 
> I'd love to know the reasons.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to