Changes for page Update database after retrieval
                  Last modified by Danniar Firdausy on 2024/09/18 20:02
              
      
      From version  11.1 
    
    
              edited by Erik Bakker
        
on 2022/06/10 12:00
     on 2022/06/10 12:00
      Change comment:
              Renamed from xwiki:Migrated Pages.Update database after retrieval
          
         
      To version  23.6 
    
    
              edited by Danniar Firdausy
        
on 2024/09/18 20:02
     on 2024/09/18 20:02
      Change comment:
              There is no comment for this version
          
         Summary
- 
          Page properties (5 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Title
-   ... ... @@ -1,0 +1,1 @@ 1 +Update database after retrieval 
- Parent
-   ... ... @@ -1,0 +1,1 @@ 1 +WebHome 
- Author
-   ... ... @@ -1,1 +1,1 @@ 1 -XWiki. ebakker1 +XWiki.dfirdausy 
- Default language
-   ... ... @@ -1,0 +1,1 @@ 1 +en 
- Content
-   ... ... @@ -1,13 +1,11 @@ 1 1 {{container}}{{container layoutStyle="columns"}}((( 2 -= Update database after retrieval = 3 3 4 -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.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. 5 5 5 +In our previous [[microlearning>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Database connectivity.intermediate-database-connectivity-sql-query||target="blank"]], we explored the basics of SQL queries. Now, we will take it a step further by learning how to update database records immediately after retrieving them. This approach is useful for managing statuses, ensuring you do not repeatedly read, or retrieve, the same records. Let's dive into how this functionality works and how to implement it within eMagiz. 6 + 6 6 Should you have any questions, please get in touch with [[academy@emagiz.com>>mailto:academy@emagiz.com]]. 7 7 8 -* Last update: September 7th, 2021 9 -* Required reading time: 4 minutes 10 - 11 11 == 1. Prerequisites == 12 12 13 13 * Basic knowledge of the eMagiz platform ... ... @@ -16,13 +16,11 @@ 16 16 17 17 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. 18 18 19 - 20 - 21 21 == 3. Update database after retrieval == 22 22 23 -In theprevious [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.19 +In a 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. 24 24 25 -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). 21 +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}}. 26 26 27 27 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. 28 28 ... ... @@ -30,28 +30,20 @@ 30 30 31 31 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. 32 32 29 +== 4. Key takeaways == 33 33 31 +* eMagiz allows you to execute an update statement immediately after a select statement. 32 +* This feature is particularly useful for tracking and updating record statuses, preventing repeated retrieval of the same records. 33 +* The update statement applies to all rows returned by the select query, with the changes based on the specified conditions in the where clause. 34 34 35 -== 4.Assignment==35 +== 5. Suggested additional readings == 36 36 37 -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. 38 - 39 -== 5. Key takeaways == 40 - 41 -* eMagiz offers the option to execute an update statement right after a select statement 42 -* In the database, this can be useful when tracking the status. 43 -* The update statement will update all rows returned via the select statement, assuming they pass the where clause 44 - 45 - 46 - 47 47 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: 38 +* [[Intermediate Level (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.WebHome||target="blank"]] 39 +** [[Solution Architecture (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Database connectivity.WebHome||target="blank"]] 40 +*** [[SQL Query (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Database connectivity.intermediate-database-connectivity-sql-query||target="blank"]] 41 +* [[Update database (Search Results)>>url:https://docs.emagiz.com/bin/view/Main/Search?sort=score&sortOrder=desc&highlight=true&facet=true&r=1&f_space_facet=0%2FMain.&l_space_facet=10&f_type=DOCUMENT&f_locale=en&f_locale=&f_locale=en&text=%22update+database%22||target="blank"]] 42 +* [[SQL Explained (External)>>https://www.w3schools.com/sql/default.Asp||target="blank"]] 48 48 49 -* https://www.w3schools.com/sql/default.Asp 50 50 51 -== 7. Silent demonstration video == 52 - 53 -This video demonstrates how you could have handled the assignment and gives you some context on what you have just learned. 54 - 55 -{{video attachment="intermediate-database-connectivity-update-database-after-retrieval.mp4" reference="Main.Videos.Microlearning.WebHome"/}} 56 - 57 57 )))((({{toc/}}))){{/container}}{{/container}} 
 
