It's been almost 9 years @Eduard Lebedyuk :-) Have ever figured out how to call a linked procedure when running a select for data from a linked table?
When I execute a select statement with only the call to the linked stored procedure, all works ok:
select CRMBI.getPlanningRate(11,2023)
Expression_1 |
---|
0.94 |
1 row(s) affected
But if I try to make that same call within a query to another table in that same package, I get errors:
select ISCurrencyID, CRMBI.getPlanningRate(ISCurrencyID,2024) from CRMBI.CurrencyRate
[SQLCODE: <-223>:<Gateway query Prepare() failed>] [%msg: <Connection 'CRMBILINKTABLES': Prepare(select T1.ISCurrencyID AS C1,(T1.ISCurrencyID...): SQLState: (42000) NativeError: [1] Message: [Iris ODBC][State : 42000][Native Code 1] [c:\intersystems\iris2021v1\bin\irisdb.exe] [SQLCODE: <-1>:<Invalid SQL statement>] [Location: <Prepare>] [%msg: < ) expected, , found ^SELECT T1 . ISCurrencyID AS C1 , ( T1 . ISCurrencyID ,>] >]
Other queries to the linked table, without the stored procedure, also works just fine:
select ISCurrencyID, USDRate, effectiveDate from CRMBI.CurrencyRate where ISCurrencyID = 11 and effectiveDate > '2022-12-31' and effectiveDate < '2023-01-31'
ISCurrencyID | USDRate | effectiveDate |
---|---|---|
11 | 0.9392000 | 2023-01-01 |
1 row(s) affected
Might be user error or a later message to the WRC, but thanks in advance if you have any ideas.
Thank you Dmitry; I confirmed it works when the dynamic arrays are stored in variables:
%SYS>w $zv IRIS for Windows (x86-64) 2024.1.1 (Build 347U) Thu Jul 18 2024 17:35:51 EDT %SYS>set arr1 = [1,2,3] %SYS>set arr2 = [6,5,4] %SYS>zw arr1.addAll(arr2) [1,2,3,6,5,4] ; <DYNAMIC ARRAY> %SYS>do arr1.addAll(arr2) %SYS>zw arr1 arr1=[1,2,3,6,5,4,6,5,4] ; <DYNAMIC ARRAY>
data:image/s3,"s3://crabby-images/ed8f0/ed8f0beef0eb81fca4954ab8215c4602ac7dc522" alt="InterSystems CCR Technical Implementation Specialist"
data:image/s3,"s3://crabby-images/3d60e/3d60e544e7a8ad2e4dd41ddefb0e6cf3f0aeb8de" alt="Open Sesame!"
data:image/s3,"s3://crabby-images/4b61a/4b61a1276169a7fbcb09c5c9063036ced6cea11d" alt="1,000 Points"
data:image/s3,"s3://crabby-images/7a4a8/7a4a8648f0292119025809a0c41fd007a5fa1297" alt="Challenge Starter"
data:image/s3,"s3://crabby-images/8141a/8141a8895995b9ce7ef1ab0ddf39157b3198a8a9" alt="DC Author"
data:image/s3,"s3://crabby-images/2c8d9/2c8d94971a70cff8ba90800b14d816dc9818d1a3" alt="DC Commenter"
data:image/s3,"s3://crabby-images/8d2bf/8d2bfb88f5369a41a816c658e3c041456559050f" alt="DC Problem Solver"
data:image/s3,"s3://crabby-images/40b16/40b166d7db76c38aa27bb6072724f231d60e3b2d" alt="InterSystems Researcher"
Try concatenating the new item as follows:
set mylist = "" for i = 1:1:5 { set item = "item"_i set mylist = mylist_$ListBuild(item) }
The output is:
zw mylist mylist=$lb("item1","item2","item3","item4","item5")