DynamoDB Expressions
As almost every developer has worked with Relational (Mysql,Postgres,etc) and No-SQL (MongoDB) databases, and over the time has developed the intuition for writing and execution of CRUD operations queries for these databases. DynamoDB breaks this intuition in many ways.
Lately, I have been working on a project which has DynamoDB as its Database. And like most of the developers, I searched for insert, update and delete queries and started writing the DynamoDB queries with the intuition of Mysql, Postgres, MongoDB.
I was able to write basic queries but slowly I started to realise that I am struggling to understand the execution of queries. And then I found the need to go back to Basics of query writing in DynamoDB and that was Expressions.
Before Moving to Expression Let understand the Jargons in Dynamodb
Item: Refers to row, record, Document in other databases.
Attribute: Refer to column in Mysql, Postgres and Field in MongoDB and Elasticsearch.
Expressions are an integral part of using DynamoDB
Expressions are rules for simple and complex CRUD operations.
You have to follow strict syntax to write expressions
This strict nature of expression enables DynamoDB for faster execution of queries even on millions of records/Items.
The size of the table doesn't matter latency remains constant i.e <10ms for small(1 GB) or big (100 GB) tables
Types Of Expression | Read | Insert | Update |
Projection expressions | 1 | ||
Key condition expressions | 1 | ||
Condition expressions | 1 | 1 | |
Update expressions | 1 | ||
Filter expressions |
These Tables show the need of Expression for different Database operations.
Condition expressions
DynamoDB write operations are unconditional, Each operation overwrites an existing item with same primary key.
Many time need arises that you only want to insert new Item(row/documents) if it does not already exist in the table. Which means you need some condition to be satisfied, before write operation takes place. ConditionExpression
enables you to write your such conditions.
Sequence of query Execution
- DynamoDB retrieve the Item for given primary key. Atmost only 1 Item is retrieved as it is mandatory to specify the primary key.
- Then verifies that the retrieved Item satisfies the User condition (Specified in ConditionExpression) or not.
- If User condition is satisfied then write operation is executed or else the execution fails.
Condition expressions always operate on an individual item not multiple items when certain conditions are true.
On first run, this Item is inserted successfully. If you try inserting the same Item again, you'll get an error:
An error occurred (ConditionalCheckFailedException) when calling the PutItem operation: The conditional request failed
Alex has explained ConditionExpression in detail, For example you can also refer AWS Documentation, WorkingWithItems.ConditionalUpdate, ConditionExpresion PutItem and UpdateItem example
Update expression
- Update expressions are used to update a particular attribute in an existing Item.
- This is same as
Update set column_name='value'
in mysql. - DynamoDB Syntax
UpdateExpression: 'SET attributeToEdit = :newValue REMOVE attributeToDelete'
Projection expressions
- Project expressions are used to specify a subset of attributes you want to receive when reading Items.
- We used these in our GetItem calls.
- GetItem calls are same as select queries in mysql.
- We specify column name in select queries such as
Select column1, column2, column3 from tablename
in the same way we use ProjectionExpressions to specify attributes that we want to retireve in query.
Key condition expressions
- Key condition expressions are used when querying a table with a composite primary key to limit the items selected.
Filter expressions
- Filter expressions allow you to filter the results of queries and scans to allow for more efficient responses.
DynamoDB limitations