- 1. Example: Create SELECT-query from Orders Table
- 2. Example: Create INSERT-query for Orders Table
- 3. Example: Create UPDATE-query for Orders Table
- 4. Example: Create DELETE-query for Orders Table
- 5. Example: Execute Stored Procedure with input parameter
- 6. Example: Execute Stored Procedure with input and local parameters
- 7. Example: Execute Stored Procedure with input and output parameters
- 8. System variables
- 9. Supported SQL datatypes
1. Example: Create SELECT-query from Orders Table #
1.1 Open Microsoft SQL Server Management Studio and right click on Table Orders, and select path as shown below
data:image/s3,"s3://crabby-images/bd54d/bd54d4dd0a0f616b7749169d69d10fc6b7f6b409" alt=""
1.2 This automatically gives you an SQL query that selects all columns and all records in Orders table, see below.
data:image/s3,"s3://crabby-images/af070/af0707d67885e44cbc93f5c10330ee599f33e957" alt=""
1.3 Click on “Execute” button, and result pane is displayed. See below.
data:image/s3,"s3://crabby-images/334a0/334a002b1333790bcf1212f34c0b572908068f1f" alt=""
1.4 To get these records downloaded to the PLC, it is necessary to use Column alias. See below.
data:image/s3,"s3://crabby-images/f2197/f2197180ea26308935ef93ec0278227688e907b3" alt=""
Note: Notation Bx, Dx, Rx and Sx should be used in SELECT queries
Note: Notation Bx, Dx, Rx and Sx always refers to array element 1 or higher in Record array (DBGW1_DB.Record[1 to n]). Where n=number of records received
Each column datatype specifies whish column alias should be used:
Where n = Record number (1 to n)
Column [ID] datatype is bigint therefore alias Dxx (DINT in PLC) should be used. D0 for DBGW1_DB.Record[n].D[0]
Column [Name] datatype is nvarchar(20) therefore alias Sxx (String in PLC) should be used. S0 for DBGW1_DB.Record[n].S[0]
Column [Description] datatype is nvarchar(30) therefore alias Sxx (String in PLC) should be used. S1 for DBGW1_DB.Record[n].S[1]
Column [Status] datatype is int therefore alias Dxx (DINT in PLC) should be used. D1 for DBGW1_DB.Record[n].D[1]
Column [Released] datatype is bit therefore alias Bxx (Bool in PLC) should be used. B0 for DBGW1_DB.Record[n].B[0]
Column [ProductID] datatype is uniqueidentifier therefore alias Sxx (String in PLC) should be used. S2 for DBGW1_DB.Record[n].S[2]
Column [Amount] datatype is float therefore alias Rxx (REAL in PLC) should be used. R0 for DBGW1_DB.Record[n].R[0]
Column [AmountProduced] datatype is real therefore alias Rxx (REAL in PLC) should be used. R1 for DBGW1_DB.Record[n].R[1]
Column [StartTime] datatype is datetime therefore alias Sxx (String in PLC) should be used. S3 for DBGW1_DB.Record[n].S[3]
Column [DelivaryTime] datatype is datetime therefore alias Sxx (String in PLC) should be used. S4 for DBGW1_DB.Record[n].S[4]
Column [ProductionTime] datatype is real therefore alias Rxx (REAL in PLC) should be used. R2 for DBGW1_DB.Record[n].R[2]
Column [CustomerID] datatype is uniqueidentifier therefore alias Sxx (String in PLC) should be used. S5 for DBGW1_DB.Record[n].S[5]
Column [MachineID] datatype is bigint therefore alias Dxx (DINT in PLC) should be used. D2 for DBGW1_DB.Record[n].D[2]
1.5 Figure below shows the relationship between SQL query result and DBGW Add-On tag array in the PLC
data:image/s3,"s3://crabby-images/5c492/5c4927ea75c0bacb3c442b0c0961c2927738ef78" alt=""
1.6 When SQL query is working as expected, it can be copied directly into your string tag in the PLC. See chapter 3.4
2. Example: Create INSERT-query for Orders Table #
2.1 Open Microsoft SQL Server Management Studio and right click on Table Orders, and select path as shown below:
data:image/s3,"s3://crabby-images/b21de/b21dee5addc213531d419d5da689dc77d153c004" alt=""
2.2 This automatically gives you an SQL query that inserts all columns into Orders table, see below.
data:image/s3,"s3://crabby-images/4bf28/4bf282baa0dd9566bb0d28fa80458a693ea8bd7c" alt=""
2.3 To insert a record into Orders table with values from the PLC, it is necessary to use Column alias. See below.
data:image/s3,"s3://crabby-images/8f601/8f60169e05ad0319438a8b002b952ca002df21d8" alt=""
Note: Notation #Bx#, #Dx#, #Rx# and #Sx# should be used in INSERT and UPDATE queries and WHERE clauses
Note: #Bx#, #Dx#, #Rx# and #Sx# always refers to array element 0 in Record array (DBGW1_DB.Record[0])
Each column datatype specifies whish column alias should be used:
Column [Name] datatype is nvarchar(20) therefore alias #Sxx# (String in PLC) should be used. #S0# for DBGW1_DB.Record[0].S[0]
Column [Description] datatype is nvarchar(30) therefore alias #Sxx# (String in PLC) should be used. #S1# for DBGW1_DB.Record[0].S[1]
Column [Status] datatype is int therefore alias #Dxx# (DINT in PLC) should be used. #D1# for DBGW1_DB.Record[0].D[1]
Column [Released] datatype is bit therefore alias #Bxx# (Bool in PLC) should be used. #B0# for DBGW1_DB.Record[0].B[0]
Column [ProductID] datatype is uniqueidentifier therefore alias #Sxx# (String in PLC) should be used. #S2# for DBGW1_DB.Record[0].S[2]
Column [Amount] datatype is float therefore alias #Rxx# (REAL in PLC) should be used. #R0# for DBGW1_DB.Record[0].R[0]
Column [AmountProduced] datatype is real therefore alias #Rxx# (REAL in PLC) should be used. #R1# for DBGW1_DB.Record[0].R[1]
Column [StartTime] datatype is datetime therefore alias #Sxx# (String in PLC) should be used. #S3# for DBGW1_DB.Record[0].S[3]
Column [DelivaryTime] datatype is datetime therefore alias #Sxx# (String in PLC) should be used. #S4# for DBGW1_DB.Record[0].S[4]
Column [ProductionTime] datatype is real therefore alias #Rxx# (REAL in PLC) should be used. #R2# for DBGW1_DB.Record[0].R[2]
Column [CustomerID] datatype is uniqueidentifier therefore alias #Sxx# (String in PLC) should be used. #S5# for DBGW1_DB.Record[0].S[5]
Column [MachineID] datatype is bigint therefore alias #Dxx# (DINT in PLC) should be used. #D2# for DBGW1_DB.Record[0].D[2]
2.4 Figure below shows the relationship between SQL query and DBGW Add-On tag array in the PLC
data:image/s3,"s3://crabby-images/0b764/0b764dd14724c23cef8186594abb31e6ad359b74" alt=""
2.5 When SQL query is working as expected, it can be copied directly into your string tag in the PLC. See chapter 3.4
3. Example: Create UPDATE-query for Orders Table #
3.1 Open Microsoft SQL Server Management Studio and right click on Table Orders, and select path as shown below:
data:image/s3,"s3://crabby-images/de370/de370129576509d70b098b23acfea84e8ae06be3" alt=""
3.2 This automatically gives you an SQL query that updates all columns into Orders table, see below.
data:image/s3,"s3://crabby-images/14e26/14e26371a4589a8f50231d7d57d4f33e43f1def5" alt=""
3.3 To update a specific record in Orders table, it is necessary to use Column alias. See below.
data:image/s3,"s3://crabby-images/077f1/077f177fff6d1509e10bed3129e74020ab614ead" alt=""
Note: Notation #Bx#, #Dx#, #Rx# and #Sx# should be used in INSERT and UPDATE queries and WHERE clauses
Note: #Bx#, #Dx#, #Rx# and #Sx# always refers to array element 0 in Record array (DBGW1_DB.Record[0])
Each column datatype specifies whish column alias should be used:
Column [Status] datatype is int therefore alias #Dxx# (DINT in PLC) should be used. #D0# for DBGW1_DB.Record[0].D[0]
Column [AmountProduced] datatype is real therefore alias #Rxx# (REAL in PLC) should be used. #R0# for DBGW1_DB.Record[0].R[0]
Column [ProductionTime] datatype is real therefore alias #Rxx# (REAL in PLC) should be used. #R1# for DBGW1_DB.Record[0].R[1]
Column [Name] datatype is nvarchar(20) therefore alias #Sxx# (String in PLC) should be used. #S0# for DBGW1_DB.Record[0].S[0]
3.4 Figure below shows the relationship between SQL query and DBGW Add-On tag array in the PLC
data:image/s3,"s3://crabby-images/cbacc/cbacc31bd3d32535411a6959818479bdd33d6a42" alt=""
3.5 When SQL query is working as expected, it can be copied directly into your string tag in the PLC.
4. Example: Create DELETE-query for Orders Table #
4.1 Open Microsoft SQL Server Management Studio and right click on Table Orders, and select path as shown below:
data:image/s3,"s3://crabby-images/2d5cc/2d5ccef9893d832ac87de81d5f679af14b333430" alt=""
4.2 This automatically gives you an SQL query that deletes all columns in Orders table, see below.
data:image/s3,"s3://crabby-images/56e30/56e308f8111d6a72f331c4ca38ea23194bf41540" alt=""
4.3 To delete a specific record in Orders table, it is necessary to use Column alias. See below.
data:image/s3,"s3://crabby-images/1e81f/1e81fc9609d98c92056784e1b4ef9767b43f72a4" alt=""
Note: Notation #Bx#, #Dx#, #Rx# and #Sx# should be used in INSERT and UPDATE queries and WHERE clauses
Note: #Bx#, #Dx#, #Rx# and #Sx# always refers to array element 0 in Record array (DBGW1_DB.Record[0])
Each column datatype specifies whish column alias should be used:
Column [Name] datatype is nvarchar(20) therefore alias #Sxx# (String in PLC) should be used. #S0# for DBGW1_DB.Record[0].S[0]
4.4 Figure below shows the relationship between SQL query and DBGW Add-On tag array in the PLC
data:image/s3,"s3://crabby-images/9e98b/9e98b2915730ce91e1d0d263fa636918607e6b42" alt=""
4.5 When SQL query is working as expected, it can be copied directly into your string tag in the PLC.
5. Example: Execute Stored Procedure with input parameter #
5.1 Open Microsoft SQL Server Management Studio and open Stored Procedure as shown below:
Stored Procedure with 1 input “@MachineID”
PS! Multiple records can be received
data:image/s3,"s3://crabby-images/db998/db998ace1d8aa7aafcc4b8771260803290a7cb4a" alt=""
5.2 To get executable string for this Stored Procedure, right click on “usr_SelectOrders1” and select “Execute Stored Procedure”
data:image/s3,"s3://crabby-images/bbe63/bbe63a703e31017fc112d5133b6787d6599da9a0" alt=""
Enter a random value into this field and click on “OK”
data:image/s3,"s3://crabby-images/cb23e/cb23e77e29b801b8b804a34fd8b99701ef70982d" alt=""
That gives the following query:
data:image/s3,"s3://crabby-images/7ced7/7ced74ad33ff8b7df18a73e3069eaf0cb87a221f" alt=""
Note: It is not possible to get records from the Stored Procedure and a separat “Return value”. Therefore “@return_Value” should be removed
data:image/s3,"s3://crabby-images/79846/79846c2694739f62eb8a91319eef5f40b5efe723" alt=""
5.3 To execute Stored Procedure with input parameter from the PLC, it is necessary to use Column alias. See below.
data:image/s3,"s3://crabby-images/48124/481243d930af41ddbe28a0b9c2067a8e6921825b" alt=""
Note: Notation #Bx#, #Dx#, #Rx# and #Sx# should be used for input parameters for a Stored Procedure
Note: #Bx#, #Dx#, #Rx# and #Sx# always refers to array element 0 in Record array (DBGW1_DB.Record[0])
Input parameter:
Column [ID] datatype is bigint therefore alias #Dxx# (DINT in PLC) should be used. #D0# for DBGW1_DB.Record[0].D[0]
Note: Column alias for outputs are assigned inside the Stored Procedure, see Stored Procedure above
5.4 Figure below shows the relationship between SQL query and DBGW Add-On tag array in the PLC
data:image/s3,"s3://crabby-images/5c6e1/5c6e164935ae0570d444158f6880af5bf220f866" alt=""
5.5 When SQL query is working as expected, it can be copied directly into your string tag in the PLC.
6. Example: Execute Stored Procedure with input and local parameters #
6.1 Open Microsoft SQL Server Management Studio and open Stored Procedure as shown below:
Stored Procedure with 1 input “@MachineID”
PS! Only 1 record will be received
data:image/s3,"s3://crabby-images/66ed5/66ed56eeca1cb9a561f5d4ca8c42b7c599fa81ca" alt=""
data:image/s3,"s3://crabby-images/a4166/a4166f5b613c3df2cb591435da09b7061fa65177" alt=""
6.2 To get executable string for this Stored Procedure, right click on “usr_SelectOrders2” and select “Execute Stored Procedure”
data:image/s3,"s3://crabby-images/44321/44321a6524e337c4fe82d8a83189ba5b0d4fec81" alt=""
Enter a random value into this field and click on “OK”
data:image/s3,"s3://crabby-images/3e54c/3e54c2d58e7a589353ef55ba74bb0779f5f9baf7" alt=""
That gives the following query:
data:image/s3,"s3://crabby-images/012c5/012c58bd47adfde2a23345534aff70c1b6f3bab6" alt=""
Note: It is not possible to get record(s) from the Stored Procedure and a separat “Return value”. Therefore “@return_value” should be removed
data:image/s3,"s3://crabby-images/0c085/0c085e278be41081c851ce27358bf30d16565f6d" alt=""
6.3 To execute Stored Procedure with input parameters from the PLC, it is necessary to use Column alias. See below.
data:image/s3,"s3://crabby-images/d5103/d51037dee8b8613d2f71c2f4eb8c916cae9396df" alt=""
Note: Notation #Bx#, #Dx#, #Rx# and #Sx# should be used for input parameters for a Stored Procedure
Note: #Bx#, #Dx#, #Rx# and #Sx# always refers to array element 0 in Record array (DBGW1_DB.Record[0])
Input parameter:
Column [ID] datatype is bigint therefore alias #Dxx# (DINT in PLC) should be used. #D0# for DBGW1_DB.Record[0].D[0]
Note: Column alias for outputs are assigned inside the Stored Procedure, see Stored Procedure above
6.4 Figure below shows the relationship between SQL query and DBGW Add-On tag array in the PLC
data:image/s3,"s3://crabby-images/ae26a/ae26a05704e4237a245ca487c04a8235a4506bf2" alt=""
6.5 When SQL query is working as expected, it can be copied directly into your string tag in the PLC.
7. Example: Execute Stored Procedure with input and output parameters #
7.1 Open Microsoft SQL Server Management Studio and open Stored Procedure, see below:
Stored Procedure with 1 input and 13 output parameters
PS! Only 1 record will be received
data:image/s3,"s3://crabby-images/85de2/85de2d2c88c299d12b1b9af615649551c5c75e07" alt=""
7.2 To get executable string for this Stored Procedure, right click on “usr_SelectOrders3” and select “Execute Stored Procedure”
data:image/s3,"s3://crabby-images/aab53/aab533d986325253573617ed9bc50ed4375cf646" alt=""
Enter a random value into this field and click on “OK”
data:image/s3,"s3://crabby-images/f778d/f778d7b3884f7398d8befbda51277ca218c6dadf" alt=""
That gives the following query:
data:image/s3,"s3://crabby-images/2d433/2d433f09602d5599cdf897f302d0a81e7ae83aa3" alt=""
Note: It is not possible to get outputs from the Stored Procedure and a separat “Return value”. Therefore “@return_value” should be removed
data:image/s3,"s3://crabby-images/10c0b/10c0be20d2312ff6d06e79a6313d370cf034a4f7" alt=""
7.3 To execute Stored Procedure with input & output parameters to/from the PLC, it is necessary to use Column alias. See below.
data:image/s3,"s3://crabby-images/57a5b/57a5bc9364065e427ded2730da23ad46c39dc133" alt=""
Note: Notation #Bx#, #Dx#, #Rx# and #Sx# should be used for input parameters for a Stored Procedure
Note: #Bx#, #Dx#, #Rx# and #Sx# always refers to array element 0 in Record array (DBGW1_DB.Record[0])
Note: Notation Bx, Dx, Rx and Sx should be used for output parameters for a Stored Procedure
Note: Bx, Dx, Rx and Sx always refers to array element 1 or higher in Record array (DBGW1_DB.Record[1 to n]). Where n = Number of records received
Input parameter:
Column [ID] datatype is bigint therefore alias #Dxx# (DINT in PLC) should be used. #D0# for DBGW1_DB.Record[0].D[0]
Output parameters:
Column [ID] datatype is bigint therefore alias Dxx (DINT in PLC) should be used. D0 for DBGW1_DB.Record[1].D[0]
Column [Name] datatype is nvarchar(20) therefore alias Sxx (String in PLC) should be used. S0 for DBGW1_DB.Record[1].S[0]
Column [Description] datatype is nvarchar(30) therefore alias Sxx (String in PLC) should be used. S1 for DBGW1_DB.Record[1].S[1]
Column [Status] datatype is int therefore alias Dxx (DINT in PLC) should be used. D1 for DBGW1_DB.Record[1].D[1]
Column [Released] datatype is bit therefore alias Bxx (Bool in PLC) should be used. B0 for DBGW1_DB.Record[1].B[0]
Column [ProductID] datatype is uniqueidentifier therefore alias Sxx (String in PLC) should be used. S2 for DBGW1_DB.Record[1].S[2]
Column [Amount] datatype is float therefore alias Rxx (REAL in PLC) should be used. R0 for DBGW1_DB.Record[1].R[0]
Column [AmountProduced] datatype is real therefore alias Rxx (REAL in PLC) should be used. R1 for DBGW1_DB.Record[1].R[1]
Column [StartTime] datatype is datetime therefore alias Sxx (String in PLC) should be used. S3 for DBGW1_DB.Record[1].S[3]
Column [DelivaryTime] datatype is datetime therefore alias Sxx (String in PLC) should be used. S4 for DBGW1_DB.Record[1].S[4]
Column [ProductionTime] datatype is real therefore alias Rxx (REAL in PLC) should be used. R2 for DBGW1_DB.Record[1].R[2]
Column [CustomerID] datatype is uniqueidentifier therefore alias Sxx (String in PLC) should be used. S5 for DBGW1_DB.Record[1].S[5]
Column [MachineID] datatype is bigint therefore alias Dxx (DINT in PLC) should be used. D2 for DBGW1_DB.Record[1].D[2]
7.4 Figure below shows the relationship between SQL query result and DBGW Add-On tag array in the PLC
data:image/s3,"s3://crabby-images/b2e3d/b2e3d3fa0a5e23ae7306179ffcfaee22ef505888" alt=""
7.5 When SQL query is working as expected, it can be copied directly into your string tag in the PLC.
8. System variables #
8.1 Used in queries to make it easier to deal with datetime issues and more.
System variable | Description |
---|---|
@TIMESYNC@ | Used for timesynchronization of PLC clock with SQL-Server time |
@SN@ | Serial number: Will be replaced by PLC’s unique serial number |
@TS@ | Timestamp: Will be replaced by actual datetime on SQL-Server during insert & update |
@TD@ | This Day: Will be replaced by actual date |
@TW@ | This Week: Will be replaced by actual start date for this week |
@TM@ | This Month: Will be replaced by actual start date for this month |
@TY@ | This Year: Will be replaced by actual start date for this year |
@LxxH@ | Last xx Hours: Will be replaced by start datetime xx hours back in time |
@LxxD@ | Last xx Days: Will be replaced by start datetime xx days back in time |
@LxxM@ | Last xx Month: Will be replaced by start datetime xx months back in time |
8.2 Examples
Query for timesynchronization of PLC clock with SQL-Server time
SELECT @TIMESYNC@
Query for using PLC Serial number in Where clause:
SELECT [ID], [Name], [Description], [Status], [Released], [ProductID], [Amount], [AmountProduced], [StartTime], [DelivaryTime], [ProductionTime], [CustomerID]
FROM [DBGW_Test].[dbo].[Orders]
WHERE [MachineID]=@SN@
Query for using this month in Where clause:
SELECT [ID], [Name], [Description], [Status], [Released], [ProductID], [Amount], [AmountProduced], [StartTime], [DelivaryTime], [ProductionTime], [CustomerID]
FROM [DBGW_Test].[dbo].[Orders]
WHERE [MachineID]=@SN@ AND [DelivaryTime]>=@TM@
Query for using last 24 hours in Where clause:
SELECT [ID], [Name], [Description], [Status], [Released], [ProductID], [Amount], [AmountProduced], [StartTime], [DelivaryTime], [ProductionTime], [CustomerID]
FROM [DBGW_Test].[dbo].[Orders]
WHERE [DelivaryTime]>=@L24H@
Query for using last year in Where clause:
SELECT [ID], [Name], [Description], [Status], [Released], [ProductID], [Amount], [AmountProduced], [StartTime], [DelivaryTime], [ProductionTime], [CustomerID]
FROM [DBGW_Test].[dbo].[Orders]
WHERE [DelivaryTime]>=@L12M@
9. Supported SQL datatypes #
9.1 Figure below shows which SQL datatypes that are supported, and the correspondant PLC datatype
SQL Datatype | PLC datatype |
---|---|
Varchar | String |
NVarchar (PLC only supports None Unicode (1 byte characters), Unicode are not supported (2 bytes for special characters) | String |
Char | String |
NChar (PLC only supports None Unicode (1 byte characters), Unicode are not supported (2 bytes for special characters) | String |
Datetime | String |
Uniqueidentifier | String |
TinyInt | DINT |
SmallInt | DINT |
Integer | DINT |
BigInt (PLC only supports from -2147483648 to 2147483647) | DINT |
Float (PLC only supports Single-precision floating-point format, 4 byte) | REAL |
Real (PLC only supports Single-precision floating-point format, 4 byte) | REAL |
Decimal (PLC only supports Single-precision floating-point format, 4 byte) | REAL |
Numeric (PLC only supports Single-precision floating-point format, 4 byte) | REAL |
Money | REAL |
Bit | BOOL |