Building “New” Rows with SQL Business Rules

Labels
AJAX(112) App Studio(8) Apple(1) Application Builder(245) Application Factory(207) ASP.NET(95) ASP.NET 3.5(45) ASP.NET Code Generator(72) ASP.NET Membership(28) Azure(18) Barcode(2) Barcodes(3) BLOB(18) Business Rules(1) Business Rules/Logic(140) BYOD(13) Caching(2) Calendar(5) Charts(29) Cloud(14) Cloud On Time(2) Cloud On Time for Windows 7(2) Code Generator(54) Collaboration(11) command line(1) Conflict Detection(1) Content Management System(12) COT Tools for Excel(26) CRUD(1) Custom Actions(1) Data Aquarium Framework(122) Data Sheet(9) Data Sources(22) Database Lookups(50) Deployment(22) Designer(177) Device(1) DotNetNuke(12) EASE(20) Email(6) Features(101) Firebird(1) Form Builder(14) Globalization and Localization(6) How To(1) Hypermedia(2) Inline Editing(1) Installation(5) JavaScript(20) Kiosk(1) Low Code(3) Mac(1) Many-To-Many(4) Maps(6) Master/Detail(36) Microservices(4) Mobile(63) Mode Builder(3) Model Builder(3) MySQL(10) Native Apps(5) News(18) OAuth(9) OAuth Scopes(1) OAuth2(13) Offline(20) Offline Apps(4) Offline Sync(5) Oracle(11) PKCE(2) Postgre SQL(1) PostgreSQL(2) PWA(2) QR codes(2) Rapid Application Development(5) Reading Pane(2) Release Notes(184) Reports(48) REST(29) RESTful(29) RESTful Workshop(15) RFID tags(1) SaaS(7) Security(81) SharePoint(12) SPA(6) SQL Anywhere(3) SQL Server(26) SSO(1) Stored Procedure(4) Teamwork(15) Tips and Tricks(87) Tools for Excel(2) Touch UI(93) Transactions(5) Tutorials(183) Universal Windows Platform(3) User Interface(338) Video Tutorial(37) Web 2.0(100) Web App Generator(101) Web Application Generator(607) Web Form Builder(40) Web.Config(9) Workflow(28)
Archive
Blog
Monday, May 14, 2012PrintSubscribe
Building “New” Rows with SQL Business Rules

Session variables provide a context for the current user activities. The common use for session variables is to perform automatic data filtering and to facilitate data input.

The Session and URL Variables example explains how to store an ID of  a supplier in a session variable. The stored Supplier ID is used for product filtering.

It is easy to use the same session variable to assign a supplier when a new product is entered.

Add a new SQL Business Rule to the Products data controller and enter its properties as follows.

Property Value
Command Name New
Type SQL
Phase Execute
Script
-- assign the Supplier ID
set @SupplierID = @Session_SupplierID
-- assign default values to other fields
select 
    @SupplierCompanyName = CompanyName, -- Supplier alias field
    @UnitsOnOrder = 0,                  -- Unit On Order
    @Discontinued = 0                   -- "Discontinued" flag
from Suppliers
where SupplierID = @SupplierID
-- assign default Reorder Level as the maximum reorder level  
-- for the products of this supplier
select @ReorderLevel = max(ReorderLevel)
from Products
where SupplierID = @SupplierID

Click OK button to save the business rule.

The script definition uses the value stored in the session variable SupplierID to assign the initial values to the lookup field SupplierID and its alias SupplierCompanyName when a new product record is created. It also figures ReorderLevel as a maximum reorder level of supplier products. The script assigns default values to the fields UnitsOnOrder and Discontinued.

The hierarchy of Products data controller will look as shown in the picture.

The selected business rule is executed when a new data row is created by the data controller before it is rendered in the user interface in the web browser

Click Browse to generate the app. Navigate to Suppliers page and choose Show Supplier Products in the context of any data row.

Select a custom 'SQL' action to store the SupplierID in the user session variable

The supplier ID will be stored in the session variable and the web browser will redirect to Products page.

Start creating a new product. The default supplier field values will be automatically entered in the new data record.

The application framework executes business rules that match the New command name. It returns all changed “field” parameter values as the values of a new data row to the web browser. The client library renders a new data row in a presentation view.

The session variable SupplierID is used to assign default values to the fields SupplierID, SupplierCompanyName, and ReorderLevel

You can visit other application pages. The value of the session variable SessionID will remain the same. If you arrive to Products page directly without choosing another supplier, then the same supplier stored in the session variable will be assigned to the new product record.