User bio
404 bio not found
Member since Oct 24, 2022
Posts:
Replies:
Here it is (implemented as Mixin):
Class MyNamespace.Pooled Extends Ens.Host [ Abstract ]
{
Property PoolIndex As %Integer [ Calculated ];
Method PoolIndexGet() As %Integer
{
#Dim cn as %String
Set cn = ..%ConfigName
#Dim statement as %SQL.Statement
Set statement = ##class(%SQL.Statement).%New()
Set status = statement.%PrepareClassQuery("Ens.Job","Enumerate")
$$$ThrowOnError(status)
#Dim rs as %SQL.StatementResult
Set rs = statement.%Execute()
#Dim i as %Integer = -1
While (rs.%Next())
{
#Dim jobId as %String
Set jobId = rs.%Get("Job")
If (rs.%Get("ConfigName") = cn)
{
Set i = i + 1
If (jobId = $JOB)
{
Kill rs
Return i
}
}
}
Kill rs
Return i
}
Property PoolSize As %Integer [Calculated];
Method PoolSizeGet() As %Integer
{
#Dim cn as %String
Set cn = ..%ConfigName
#Dim statement as %SQL.Statement
Set statement = ##class(%SQL.Statement).%New()
Set status = statement.%PrepareClassQuery("Ens.Job","Enumerate")
$$$ThrowOnError(status)
#Dim rs as %SQL.StatementResult
Set rs = statement.%Execute()
#Dim i as %Integer = 0
While (rs.%Next())
{
If (rs.%Get("ConfigName") = cn)
{
Set i = i + 1
}
}
Kill rs
Return i
}
}
I faced similar issues with Postgres linked tables because of different SQL syntax and also poorly implemented translation from IRIS dialect to your linked server dialect. The workaround is to add an instance of EnsLib.SQL.Operation.GenericOperation to your production and to execute SQL queries via ODBC/JDBC bypassing IRIS, something like:
Set operation = ##class(EnsLib.SQL.Operation.GenericOperation).%New("NameOfYourProductionComponent")
#Dim rs as EnsLib.SQL.GatewayResultSet
Set status = operation.Adapter.ExecuteQuery(.rs, "select 1", .args)
While (rs.Next()) {
...
}
Do rs.Close()
Certifications & Credly badges:
Dmitrii has no Certifications & Credly badges yet.
Global Masters badges:
Dmitrii has no Global Masters badges yet.
Followers:
Dmitrii has no followers yet.
Following:
Dmitrii has not followed anybody yet.
The most popular OpenEHR GitHub repositories have 200-300 stars... No one uses it and no one needs it