java - 为什么这个字符串 : javax. sql.rowset.serial.SerialClob 包含在输出文件中而不是实际值中

标签 java sql-server-2012 mirth

我正在使用 Mirth 3.1.0.x 从 Sql Server 2012 数据库中提取数据并将结果集写入平面文件。

代码在添加新列之前有效。

这是 Mirth Channel 目的地的转换器脚本中的代码:

var dbConn = DatabaseConnectionFactory.createDatabaseConnection('net.sourceforge.jtds.jdbc.Driver','jdbc:jtds:sqlserver://10.10.1.74:1433/rRIS_California','rRIS_California','rRIS_California');    
var result1 = dbConn.executeCachedQuery("exec [z_SelectChannelData] 'AAI'");   

while(result1.next())
{         
   tmp.row += <row>
                      <LastName>"{result1.getString('LastName')}"</LastName>
                      <FirstName>"{result1.getString('FirstName')}"</FirstName>
                      <HomePhone>"{result1.getString('HomePhone')}"</HomePhone>
                      <MRN>"{result1.getString('MRN')}"</MRN>
                      <EncounterID>"{result1.getString('EncounterID')}"</EncounterID>
                      <Accession>"{result1.getString('Accession')}"</Accession>
                      <Modality>"{result1.getString('Modality')}"</Modality>
                      <Procedure>"{result1.getString('ProcedureCode')}"</Procedure>
                      <Location>"{result1.getString('Location')}"</Location>                         
                      <PreferredLanguage>"{result1.getString('PreferredLanguage')}"</PreferredLanguage>
                      <Gender>"{result1.getString('Gender')}"</Gender>
                      <EmailAddress>"{result1.getString('EmailAddress')}"</EmailAddress>
                      <MobilePhoneNumber>"{result1.getString('MobilePhoneNumber')}"</MobilePhoneNumber>
                      <Room>"{result1.getString('Room')}"</Room>                                  
                      <billing_code>"{result1.getString('billing_code')}"</billing_code>
                      <copay>"{result1.getString('copay')}"</copay>
                 </row>; 
}    
dbConn.close();

在输出文件中,最后一列不是由实际值填充,而是由以下字符串填充:

“共付额”

“javax.sql.rowset.serial.SerialClob@1b795929”

“javax.sql.rowset.serial.SerialClob@5693cfb7”

下面是最后一列的 T-SQL:

Select    
CASE WHEN v.copay is null THEN '' WHEN v.copay =0 THEN '' ELSE cast(v.copay as varchar(max)) END as copay
FROM <table> as v

最佳答案

你可以尝试这样的事情。

var clob = result1.getClob("copay");
var result = clob.getSubString(1,clob.length());

然后将结果放入copay标签内。

关于java - 为什么这个字符串 : javax. sql.rowset.serial.SerialClob 包含在输出文件中而不是实际值中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29607586/

相关文章:

java - Mirth 自定义 Web 服务方法

java - Java 中的 MySQL 事务

sql-server - SQL Server - 不使用别名创建计划指南

java - 使用 Java EE API 替换已弃用的 JPMS 模块

sql - T/SQL - 时间相关计算

sql-server - Weblogic 12C + SQL Server 2012

java - Mirth:使用客户端证书调用 SSL SOAP Web 服务

Mirth 中的 Json 解析或 Mirth 中的 Json 或 Mirth 中的 HL7 到 JSON

java - 如何将 'jump' 发送到 Java 中的方法而不链接回调用它的位置?

java - Vaadin 8 - 对 ComboBox<Integer> 中的项目进行排序