Comments (9)
No, there isn't. At present you'd need to filter the results that were returned from a query/scan after the query to Dynamo.
I'd welcome a contribution which added support, but it's not something I'm actively working on.
from scanamo.
I was able to filter by exposing QueryRequest
. If you want to filter, you provide your own QueryRequest
else a new one is created, as usual. @philwills would you entertain a PR for this approach?
from scanamo.
@timchan-lumoslabs my current thinking is largely towards exposing the underlying driver classes less, so it's probably not the direction I'd want to take.
If I were to try and attempt something for this, I'd be looking to see if I could do something similar to how queries/scans can be limited https://github.com/guardian/scanamo/blob/master/src/main/scala/com/gu/scanamo/Table.scala#L198
from scanamo.
@philwills I am interested to see how to fix this issue but I am not sure to understand your proposal.
Do you mean adding a dynamo operator like filter
so that you could write something like this ?
index.query('key -> "k1" and 'range >= 100 and filter('foo beginsWith "bar"))
from scanamo.
@ayoub-benali I was thinking more something like index.filter('foo beginsWith "bar").x.query('key -> "k1" and 'range >= 100)
, but I like you're suggested approach better, as filtering feels pretty tightly related to the querying.
from scanamo.
@philwills Could you give some pointer where to start implementing something like that ?
For example would DynamoKeyCondition.scala be good start ?
Seems like we should add case class like FieldCondition
there and handle it later
from scanamo.
Yes, you'll need that, plus I think QueryableKeyCondition and the syntax implicits inhttps://github.com/guardian/scanamo/blob/master/src/main/scala/com/gu/scanamo/package.scala#L8
from scanamo.
I guess this issue can safely closed now that #102 is merged
from scanamo.
This is supported as of 0.9.3
from scanamo.
Related Issues (20)
- Extend transactPutAll, transactUpdateAll and transactDeleteAll with optional ConditionExpression argument HOT 2
- Extend scan operation with Segments
- Adopt `sbt-dynamodb` into the Scanamo organisation? HOT 3
- Not able to use >= on string sort key
- Publish latest?
- Question: Should I be instantiating a different client per service?
- migrate to github action HOT 6
- Conditionally apply a filter
- [error] clienterror: an error occurred (validationexception) when calling the putitem operation: one or more parameter values were invalid: contains duplicates. HOT 1
- PutReturn.NewValue is not supported by AWS DynamoDB
- Scala 3 HOT 3
- Scanamo query timeouts...
- Null Pointer Exception when trying to call any methods accessing DynamoDb
- Where is the API documentation? HOT 1
- Pagination against GSIs is cumbersome with the current API.
- Add support for BigInt
- Pekko integration HOT 1
- ZIO 2 support
- Let's release v1.0.0 and drop milestone releases! HOT 3
- Error when case class has more than 36 properties
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from scanamo.