Last modified by Danniar Firdausy on 2024/09/18 20:02

From version 23.1
edited by Eva Torken
on 2023/09/01 14:47
Change comment: There is no comment for this version
To version 12.1
edited by eMagiz
on 2022/06/10 12:01
Change comment: There is no comment for this version

Summary

Details

Page properties
Author
... ... @@ -1,1 +1,1 @@
1 -XWiki.etorken
1 +XWiki.eMagiz
Default language
... ... @@ -1,1 +1,0 @@
1 -en
Content
... ... @@ -1,9 +1,12 @@
1 1  {{container}}{{container layoutStyle="columns"}}(((
2 2  
3 -In the previous [[microlearning>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Database connectivity.intermediate-database-connectivity-sql-query||target="blank"]] we discussed the fundamentals of SQL queries. In this microlearning, we will learn how you could update the record(s) in the database the moment after you have read the information from the database. This functionality can help you update a status field to ensure you won't keep reading the same record(s) repeatedly.
3 +In the previous [microlearning](intermediate-database-connectivity-sql-query.md) we discussed the fundamentals of SQL queries. In this microlearning, we will learn how you could update the record(s) in the database the moment after you have read the information from the database. This functionality can help you update a status field to ensure you won't keep reading the same record(s) repeatedly.
4 4  
5 5  Should you have any questions, please get in touch with [[academy@emagiz.com>>mailto:academy@emagiz.com]].
6 6  
7 +* Last update: September 7th, 2021
8 +* Required reading time: 4 minutes
9 +
7 7  == 1. Prerequisites ==
8 8  
9 9  * Basic knowledge of the eMagiz platform
... ... @@ -12,11 +12,13 @@
12 12  
13 13  eMagiz offers the option to execute an update statement right after a select statement. In the database, this can be useful when tracking the status.
14 14  
18 +
19 +
15 15  == 3. Update database after retrieval ==
16 16  
17 -In the previous [[microlearning>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Database connectivity.intermediate-database-connectivity-sql-query||target="blank"]] we discussed the fundamentals of SQL queries. In this microlearning, we will learn how you could update the record(s) in the database the moment after you have read the information from the database. This functionality can help you update a status field to ensure you won't keep reading the same record(s) repeatedly.
22 +In the previous [microlearning](intermediate-database-connectivity-sql-query.md) we discussed the fundamentals of SQL queries. In this microlearning, we will learn how you could update the record(s) in the database the moment after you have read the information from the database. This functionality can help you update a status field to ensure you won't keep reading the same record(s) repeatedly.
18 18  
19 -To update the records we just read from the table, we need a slightly different update statement. As you probably remember the update statement in the previous example was written as follows {{code language="sql"}}UPDATE mytable SET changeddate = :headers[timestamp] where id = :headers[id]{{/code}}. However, with this functionality, the update statement should look like this {{code language="sql"}}UPDATE mytable SET processed = TRUE where id IN (:id){{/code}}.
24 +To update the records we just read from the table, we need a slightly different update statement. As you probably remember the update statement in the previous example was written as follows UPDATE mytable SET changeddate = :headers[timestamp] where id = :headers[id]. However, with this functionality, the update statement should look like this UPDATE mytable SET processed = TRUE where id IN (:id).
20 20  
21 21  As you can see, there are some subtle differences in the SQL query you need to achieve the proper result—most notable, the where statement is written differently. In the update statement, we need here; we need to define our input (IN) columns and values. Based on the input values that were returned via our SELECT statement, the update action is triggered. Within eMagiz, this is configured as follows.
22 22  
... ... @@ -24,17 +24,28 @@
24 24  
25 25  In this example, we search for all rows within the table for which the value in the column processed is equal to false. If so, the select statement will return each row. After the query returns all rows, the update query will ensure that all these rows will be updated by changing the value in the column processed to true. This way, you ensure these records won't be retrieved the next time we execute the select statement.
26 26  
27 -== 4. Key takeaways ==
28 28  
33 +
34 +== 4. Assignment ==
35 +
36 +See if you can find any database implementation within the projects you can access. This assignment can be completed with the help of the (Academy) project that you have created/used in the previous assignment.
37 +
38 +== 5. Key takeaways ==
39 +
29 29  * eMagiz offers the option to execute an update statement right after a select statement
30 30  * In the database, this can be useful when tracking the status.
31 31  * The update statement will update all rows returned via the select statement, assuming they pass the where clause
32 32  
44 +
45 +
33 33  If you are interested in this topic and want more information, please read the help text provided by eMagiz and read more information on the following link:
34 34  
35 -* [[SQL Explained>>https://www.w3schools.com/sql/default.Asp||target="blank"]]
48 +* https://www.w3schools.com/sql/default.Asp
36 36  
37 -== 5. Suggested additional readings ==
50 +== 7. Silent demonstration video ==
38 38  
39 -If you are interested in this topic and want more information, please read the help text provided by eMagiz.
52 +This video demonstrates how you could have handled the assignment and gives you some context on what you have just learned.
53 +
54 +{{video attachment="intermediate-database-connectivity-update-database-after-retrieval.mp4" reference="Main.Videos.Microlearning.WebHome"/}}
55 +
40 40  )))((({{toc/}}))){{/container}}{{/container}}