Archiv des Intrexx Live! Forums

Hier sehen Sie die Foreneinträge aus dem Intrexx Live! Forum. Bis November 2016 war es das Forum für alle Fragen rund um die Software Intrexx von United Planet.
Seit November 2016 gibt es ein neues moderiertes Forum, das Intrexx Community Forum. Nutzen Sie bitte unbedingt dieses für aktuelle Fragen, Antworten und Informationen.

Wichtig: Dieses Forum dient als Archiv. Die Einträge beziehen sich oft auf ältere Versionen von Intrexx und entsprechen nicht mehr den aktuellen technischen Gegebenheiten.
Daher sollten alle Inhalte ausschließlich von Experten genutzt werden. Bei unsachgemäßer Anwendung kann es zu zeitaufwändigen Problemen oder Datenverlust kommen.
Übersicht > Intrexx Professional: Programming > goovy: zugriff auf Daten aus Referenz

goovy: zugriff auf Daten aus Referenz

Hallo,

ich habe in einer Datengruppe Refernzen auf andere eingebaut. Alles was ich an der Maske damit zusammenklicke funktioniert tatellos. Nun möchte ich auf den Wert im aktuellen Datensatz mit groovy zugreifen.

auf die normalen Felder funktioniert der Zugriff problemlos
nval=g_record["CF770AE31887028B15716F79E328457DCE5D3359"].value


Der Zugriff auf die Daten aus der Referenz funktioniert so leider nicht. Ich habe es mit der guid des Feldes aus der Referenz versucht, und habe auch die guid der Referenz selbst versucht. Ich erhalte jedes Mal einen Null-Wert...



Ich hoffe, ich konnte mich verständlich ausdrücken... huh
22.03.2016 08:37 von Frank Illner
das sollte schon so gehen, die Guid ist die aus dem Feld in der Referenz wie eigentlich aus dem Bild zu erkennen.
Das einzige was es sein kann, ist dass dieses Feld auch auf der Seite benutzt werden muss, damit das geht, d.h. zur not einfach in den verstecken Bereich schieben.
22.03.2016 09:02 von falkh
hmm, läuft leider nicht... Sowohl im Datensatz, den ich auslese als auch in g_record stehen die alten Werte drin. Beim Datensatz ist das ok.. huh Dann muss es erstmal ohne gehen.
23.03.2016 07:02 von Frank Illner
Was Heißt denn "stehen die alten Werte drin", ich dachte du kommst an den Wert nicht ran?
23.03.2016 07:58 von falkh
Wann, wo und wie wird das Groovy-Skript denn ausgeführt?
Was für eine Art Datengruppe ist das auf welcher das ausgeführt wird?

Ich kenne das Verhalten von Fremddatengruppen die auf SAP zugreifen.
23.03.2016 08:18 von MartinW
Ich bin jetzt mal wieder an dem Thema dran; danke erstmal für eure Bemühungen.

Ich schreibe automatisiert die Historie zu Datensätzen. Dazu lese ich über den Event-Handler "processBefore" der Eingabeseite die Werte aus der Datenbank und vergleiche die mit den Werted des aktuellen Datensatzes (g_record). Das funktioniert gut für die Felder, die direkt in der Tabelle stehen. Mit den Refenzen tue ich mich schwer. Da ich nur an die IDs komme brauache ich eine gesonderte Abfrage (ab Zeile 40). Es funktioniert zumindest...


import de.uplanet.scripting.groovy.util.Safely

def conn = g_dbConnections.systemConnection
def stmt = null
def rs = null

def isCanged = false
def infoText = ""
def strStatus = ""
def strStatusNeu = ""
def intStatus = 0
def anzDs = 0
try
{

//alte daten werden aus DB-View gelesen, bei Umstellung muss diese angepasst werden
def sql="SELECT st.STR_BEZ_E0CA959C, anf.REF_E8DEF5E6 FROM DATAGROUP('A659C166F3BC077AEE84295271B1D92BAD25A975') as anf,DATAGROUP('253F510E700E6037833F50FA99F240011E7249D6') as st WHERE anf.REF_E8DEF5E6=st.LID and anf.LID = ?"
stmt = g_dbQuery.prepare(conn, sql)
stmt.setInt(1, Integer.parseInt(g_record.getRecId()))
rs = stmt.executeQuery()

while (rs.next())
{
strStatus =rs.getStringValue(1)
intStatus =rs.getIntValue(2)
anzDs++
}

rs = Safely.close(rs)
stmt = Safely.close(stmt)

//ausführung nicht für neue DS
if(anzDs>0) {

nval="xx"
guid="2DA375EE0D082E04394010B52D9E73A7F15ABB0F"
if(g_record[guid]) {nval=g_record[guid].value}
if(nval && nval!="null" && intStatus != nval) {
//abfragen Statustext
sql="select STR_BEZ_E0CA959C from DATAGROUP('253F510E700E6037833F50FA99F240011E7249D6') where LID = ?"
stmt = g_dbQuery.prepare(conn, sql)
stmt.setInt(1, nval)
rs = stmt.executeQuery()

while (rs.next())
{
strStatusNeu=rs.getStringValue(1)
}

rs = Safely.close(rs)
stmt = Safely.close(stmt)

isCanged = true
infoText += "\nStatusänderung: [alt: ${intStatus}-${strStatus} -> neu: ${nval}-${strStatusNeu}]"
}
}

}
finally
{
rs = Safely.close(rs)
stmt = Safely.close(stmt)
}

//schreibe die Werte in die Shared Variablen um sie mit dem Prozess abzugreifen
//bearbeitender Prozess: KEY_WRT_History


g_sharedState.KEYisCanged = isCanged
g_sharedState.KEYinfoText = infoText


26.04.2016 11:06 von Frank Illner
Ja anders als mit einer weiteren SELECT Anweisung geht es nicht, da du wie erwähnt ja nur die ID in der DB hast.
ich hatte das selbe Problem und habe das auch so gemacht, sieh hier
https://www.unitedplanet.com/forum/index.php?page=Thread&postID=37778#post37778
26.04.2016 11:15 von falkh
bin mal wieder dran, danke für die Info. Ich werd's mal testen...
07.06.2016 09:50 von Frank Illner
Zurück | Alles über Intrexx | Impressum | Datenschutzerklärung

Über United Planet
© 2019 United Planet GmbH
Schnewlinstraße 2
79098 Freiburg