Title: Tutorial Mapping Query
Now that we've got a feel of how DataContext works and how to create and save objects, let's take a small diversion and implement a piece of code that will delete all data from the database every time the tutorial application is started. We'll learn how to map a raw SQL query with parameters using the modeler and then execute it in the code.
Ignore "Select Properties" settings as the query will not select anything. Rather it will delete all rows from the table with name specified as a parameter.
delete from $table
Note that "$table" is a variable that will be dynamically substituted by Cayenne in runtime with the table name. (Detailed discussion of SQLTemplate scripting options is provided here).
QueryChain chain = new QueryChain(); chain.addQuery(new NamedQuery("DeleteAll", Collections.singletonMap( "table", "PAINTING"))); chain.addQuery(new NamedQuery("DeleteAll", Collections.singletonMap( "table", "ARTIST"))); chain.addQuery(new NamedQuery("DeleteAll", Collections.singletonMap( "table", "GALLERY"))); context.performGenericQuery(chain);
Note that since we need to run the same query three times with different sets of parameters, first we created a QueryChain that can hold other queries. Then we added three NamedQueries (the order is important - painting has to be deleted before artist or gallery due to the foreign key constraints). NamedQuery is a query that is a reference to another query mapped via CayenneModeler (in this case - a query called "DeleteAll" that we mapped above).
Now we can re-run the application and see the following output in the beginning of the log:
INFO QueryLogger: delete from PAINTING INFO QueryLogger: === updated 2 rows. INFO QueryLogger: delete from ARTIST INFO QueryLogger: === updated 1 row. INFO QueryLogger: delete from GALLERY INFO QueryLogger: === updated 1 row.
Note that raw sql queries above (aka SQLTemplates) are run directly against the database bypassing Cayenne object layer. If instead of bulk delete you needed to delete individual objects, you should do so using DataContext.deleteObject(..) as discussed here.
Next Step: Tutorial SelectQuery