Working with databases
Lesson 9: Manipulating data
This lesson will show how to use a business process to manipulate data.
- From within the DataFlex Studio select the ‘Create New’ icon from the top toolbar.
data:image/s3,"s3://crabby-images/d38fc/d38fcd1834873cf0f83de31aba74ab78a67dbf39" alt=""
- Select the ‘Other’ tab.
- Select ‘Business Process.’ Select OK.
data:image/s3,"s3://crabby-images/06f85/06f854882600b8e354f6bf9e041ce9ea25aea7ef" alt=""
- Enter “ReduceRating” as the ‘Object Name.’ Select OK.
data:image/s3,"s3://crabby-images/aee9d/aee9d11816aae4124a32ca4ba98c638704193e39" alt=""
- Write a find loop to calculate the rating of each recipe…
- Use the DDO Explorer on the right to add objects…
- Select the ‘Add DDO’ icon from the top of the panel.
data:image/s3,"s3://crabby-images/ce874/ce874ec54d4968485ae78e0dd35486a2577e2900" alt=""
- Select ‘cRecipeDataDictionary’ form the list. Select ‘Select.’
data:image/s3,"s3://crabby-images/66d90/66d903154c5dbcafb48c8c03bc86e63673e6c0bc" alt=""
- Write a find loop in ReduceRating.bp…
Procedure OnProcess
Integer iRating
Boolean bErr
Send Find of oRecipe_DD FIRST_RECORD 1
While (Found)
Send Update_Status (“Processing: “ + Field_Current_Value(oRecipe_DD, RefTable(Recipe.Name)))
Get Field_Current_Value of oRecipe_DD (RefTable(Recipe.Rating)) to iRating
Decrement iRating
If (iRating < 0) Begin
Move 0 to iRating
End
Set Field_Changed_Value of oRecipe_DD (RefTable(Recipe.Rating)) to iRating
Get Request_Validate of oRecipe_DD to bErr
If (not(bErr)) Begin
Send Request_Save of oRecipe_DD
End
Send Find of oRecipe_DD NEXT_RECORD 1
Loop
End_Procedure
data:image/s3,"s3://crabby-images/e48e1/e48e1097542ad955dde2daa7b87570e9399d8617" alt=""
- This business process now needs to be added to the application…
- Navigate to source view of ‘Cookbook.src’
- Scroll to the bottom to add a Use statement…
- Use ReduceRating.bp
data:image/s3,"s3://crabby-images/4d0a9/4d0a9c29a685e0a35051aff99958070bcf772ebd" alt=""
- Add a menu item to the application’s toolbar…
- From the design view of ‘Cookbook.src [Design]’…
- Click ‘Help’ on the application’s menu.
- Click on the ‘Type Here’ prompt that appears.
data:image/s3,"s3://crabby-images/6bd38/6bd3847fff37f8c46e784f2967822b1b8246ff7e" alt=""
- Enter “Reduce Rating,” hit ENTER.
data:image/s3,"s3://crabby-images/0e0e1/0e0e147d97e21c95bf4f90659bf39ac07854fae8" alt=""
- Double click the text you just entered to open the source code where it has created a C Codejock menu item (cCJMenuItem).
data:image/s3,"s3://crabby-images/b4eb1/b4eb18917e25758c2cbbdb47fe57a488a7c6f375" alt=""
- From within the menu item write code to implement the onExecute event.
- Press CTRL+2 to open the ‘Properties’ panel on the right for the specified object (the cursor must be located on the desired object).
- Select the ‘Events’ tab.
- Double click ‘OnExecute’ to generate the onExecute procedure in the code that will be triggered when the menu item is clicked.
data:image/s3,"s3://crabby-images/b82c3/b82c31efc64289cd3d03bdfa0c6a849eaafe6bdc" alt=""
- Add details to the code
Send doProcess of oReduceRating
data:image/s3,"s3://crabby-images/66b23/66b233e396ac97f3a0515dcc882ff56fb292f046" alt=""
- To properly see the results of the procedure…
- Open the ‘Table Explorer’ on the left.
- Right click ‘Recipe,’ and select ‘View Table’ to the see the recipes and their ratings.
data:image/s3,"s3://crabby-images/d472d/d472d7998aeddd3d9dcb361ddb88c8c8b75937cd" alt=""
data:image/s3,"s3://crabby-images/5da99/5da99a89fd101c298f436111e03389d7bdeec387" alt=""
- Select the ‘Run’ icon from the top toolbar to launch the application.
- Select ‘Reduce Ratings’ from the application’s top menu. A status window will quickly show the process being run.
data:image/s3,"s3://crabby-images/d636a/d636a54a536aa5d8f63c959bc26852e5ef98520b" alt=""
- Return to the ‘Recipe [Table Viewer]’ in the Studio, and select the ‘refresh’ icon to see that the ratings have been reduced.
data:image/s3,"s3://crabby-images/e2778/e2778b05794c154f16a3e8ad256660661c4d987f" alt=""