193 Lotus blogs updated hourly. Who will post next? Home | Blogs | Search | About 
 
Latest 7 Posts
Chile ändert mit Wirkung zum 15.05.2016 seine Zeitzone
Thu, May 26th 2016 6
Chile ändert mit Wirkung zum 15.05.2016 seine Zeitzone
Mon, May 2nd 2016 9
Cloud Extender zur Steuerung eines Notes Traveler Servers
Sat, Jan 16th 2016 7
Cloud Extender erfordert keinen lokalen Notes Client
Sat, Jan 16th 2016 8
Traveler Task start nicht
Sat, Jan 16th 2016 5
Kein debugging von LotusScript Agent möglich
Sun, Apr 26th 2015 0
Wie finde ich aktuelle Notes / Domino 9.0.1 FixPacks?
Sun, Apr 26th 2015 8
Top 10
Verwendung der iNotes Active-X Controls in restriktiven Arbeitsplatzumgebungen
Sun, Sep 28th 2014 9
Abwesenheitsbenachrichtigung auf dem iPhone aktivieren
Wed, Jul 27th 2011 9
Wie kann ich die Mailsignatur meines iPhone ändern?
Fri, Jun 3rd 2011 9
Chile ändert mit Wirkung zum 15.05.2016 seine Zeitzone
Mon, May 2nd 2016 9
Wie kann ich programmatisch private Gestaltungselemente auf Aktualität prüfen?
Fri, Dec 28th 2012 8
Wie finde ich aktuelle Notes / Domino 9.0.1 FixPacks?
Sun, Apr 26th 2015 8
Cloud Extender erfordert keinen lokalen Notes Client
Sat, Jan 16th 2016 8
Cloud Extender zur Steuerung eines Notes Traveler Servers
Sat, Jan 16th 2016 7
Warum sollte ich private Ansichten oder Ordner verwenden?
Thu, Oct 18th 2012 6
Zusätzliche Wörterbücher für den Lotus Notes Standard-Client installieren
Thu, Sep 16th 2010 6


Wie kann ich programmatisch private Gestaltungselemente auf Aktualität prüfen?
Twitter Google+ Facebook LinkedIn Addthis Email Gmail Flipboard Reddit Tumblr WhatsApp StumbleUpon Yammer Evernote Delicious
Manfred Meise    

Wir setzen eine Anwendung mit privaten Ansichten und Ordnern ein, die regelmäßig weiterentwickelt wird und produktive Datenbanken durch Schalonenaktualisierung anpasst. Hierbei werden die privaten Kopien der Ansichten und Ordner nicht automatisch aktualisiert. Bei der Konzeption einer "selbstgestrikten" Aktualisierungslogik stößt man schnell auf die Frage: "Wie kann ich erkennen, ob die private Kopie des Gestaltungselementes aktuell ist?"

Vergleich von Zeitstempeln


a) Einsatz von NotesView

Die Idee:
Man öffnet die Ansicht und hat Zeitstempel (Erstelldatum; letzte Änderung) des jeweiligen gemeinsamen Gestaltungselementes und der privaten Kopie.. Klingt gut, ist es aber nicht!

So erhält man mit
 
Dim view as NotesView
set view = db.getView ("Meine Ansicht")


jeweils die gemeinsame Ansichtsvorlage, wenn die private Kopie nicht existiert, jedoch die private Kopie des Ansicht, wenn diese exisiert. Somit kann man im Regelfall (wenn die private Kopie NICHT existiert) nicht auf die gemeinsame Vorlage zu Vergleichszwecken zugreifen.

Ergebnis:
Nicht praktikabel !

b) Einsatz von NotesDatabase.Views

Die Idee:
Man arbeitet alle Ansichten (gemeinsame Vorlagen und private Kopien) einer Datenbank ab und muss die jeweiligen Exemplare (Vorlage  / Kopie) einander zuordnen, um sie zu vergleichen.. Das muß doch gehen!

So durchsucht folgendes Skript die Datenbank nach Ordnern mit dem AliasNamen "F2-DE" und listet jeweils die Universal-ID der Gestaltungselemente auf:
 
Sub
Initialize

Dim
s                         As New NotesSession
Dim
db                         As NotesDatabase
Dim
view                 As NotesView
Dim
vViewNames        As Variant

Set
db = s.Currentdatabase

ForAll
v In db.Views
      Set view = v
      vViewNames = view.Aliases
      If Not IsEmpty (vViewNames) then
              If vViewNames(0) = "F2-DE" Then    
                      If Not IsEmpty (view.Readers) Then
                              MessageBox |Private Kopie des Ordners "F2" gefunden: | & view.Universalid
                      Else
                              MessageBox |Gemeinsame Vorlage des Ordner "F2" gefunden: | & view.Universalid
                      End If
              End If
      End If
End
ForAll
End
Sub


Interessant und noch nicht vollständig erforscht: Dieses Skript findet sogar private Kopien von Ordnern (in Datenbank gespeichert), welche der Domino Designer nicht anzeigt! Nach anfänglicher Begeisterung über diesen Lösungsansatz, habe ich dieses Skript gegen eine große produktive Datenbank laufen lassen und musste feststellen, dass jeweils beim Zugriff auf ein Ansichtsobjekt die Ansichtsindizes aktualisiert werden, um nur auf unwesentliche Merkmale der Ansicht zuzugreifen. Ein echter Performance-Killer, wollte ich diese Logik in einem Datenbank-Script beim Öffnen der Datenbank einsetzen. In meinen Testfällen habe ich teilweise 15 Sekunden warten müssen, bevor ich mein Ergebnis hatte.

Hinweis:
Es ist darauf zu achten, NICHT auf die gemeinsame Vorlage der Ansicht/des Ordners zuzugreifen, da dieses einen Laufzeitfehler 4005 "Index is not to be generated on server" verursacht. Somit ist stets z.B. mit isEmpty(view.Readers) zu prüfen, dass auf eine private Kopie zugegriffen wird (die Prüfung anderer Attribute ist nicht möglich).

Ergebnis:
Zu langsam für den Produktionsbetrieb!

b) Einsatz von NotesNoteCollection>

Die Idee:
Man kann doch die Gestaltungselemente sammeln und auf diese als NotesDocument zugreifen!. So erhalte ich Informationen zum Gestaltungselement, ohne den Indexer zu triggern!

Schon häufig habe ich mit der NotesNoteCollection Klasse auf Gestaltungslemente (Ansichten, Felder, Agenten, Teilmasken) zugegriffen und hierfür u.A. auch eine Selektionsformel einsetzen können, nach Elementen mit speziellen Attributen zu suchen. So würde ich mit den Werten des "$Flags" Items auf bestimmte Ansichts-/Ordner-Typen zugreifen und mit Auswertung des "$Readers" Felders den Eigentümer einer privaten Kopie identifizieren können.

siehe dieses Codebeispiel ...

Beim Einsatz dieses Skriptes gegen eine große produktive Datenbank ist dieses schneller als das zuvor, jedoch immer noch zu langsam, da eine Datenbanksuche angestoßen wird.. Ein echter Performance-Killer, wollte ich diese Logik in einem Datenbank-Script beim Öffnen der Datenbank einsetzen.

Ergebnis:
Besser, doch noch zu langsam für den Produktionsbetrieb! Vorteil: Ich kann die Namen der Ansichten/Ordner ermitteln, die ich behandeln möchte.


Einsatz eines Namensschemas


Nach intensiven Tests habe ich alle oben beschriebenen Lösungsansätze verworfen und mich für die Variante entschieden (welche in diesem Beitrag nicht näher beschrieben ist):
  • Ich führe ein Namensschema (speziell für Ansichten, die lokal statt in der Datenbank gespeichert werden) ein und ändere die Namen der Gestaltungselemente, wenn ich diese aktualisiere
  • Ich akzeptiere, durch Einführung eines Versionskennzeichens für die gesamte Anwendung, dass ich ggf. Elementen aktualisiere, deren Gestaltung sich zur Vorversion nicht geändert haben

Ergebnis:
Sehr performant, da keinerlei Prüfungen

Dieser Artikel ist Teil der Artikelserie
:  Gestaltungsaktualisierung privater Ansichten und Ordner stellt eine echte Herausforderung dar

---------------------
http://www.mmi-consult.de/FAQ/dx/wie-kann-ich-programmatisch-private-gestaltungselemente-auf-aktualität-prüfen.htm
Dec 28, 2012
9 hits



Recent Blog Posts
6
Chile ändert mit Wirkung zum 15.05.2016 seine Zeitzone
Thu, May 26th 2016 11:45a   Manfred Meise
Auch dieses Jahr hat sich das chileische Energieministerium entschieden, einen Wechsel der Zeitzone und damit Wiedereinführung der Sommer- und Winterzeit zu machen. Allerdings wissen Politiker wohl nicht, welche Aufwand sie in der Industrie (wie z.B. der IT) sie damit verursachen. Ab dem Stichtag wird die Rückkehr zur Zeitzone von bisher UTC-3 (nur Normalzeit) zu UTC-4 (mit Sommer-/Winterzeit) wirksam. Dieses muss in System technisch nachgezogen werden (besonders wenn System mit zentraler,
9
Chile ändert mit Wirkung zum 15.05.2016 seine Zeitzone
Mon, May 2nd 2016 11:45a   Manfred Meise
Auch dieses Jahr hat sich das chileische Energieministerium entschieden, einen Wechsel der Zeitzone und damit Wiedereinführung der Sommer- und Winterzeit zu machen. Allerdings wissen Politiker wohl nicht, welche Aufwand sie in der Industrie (wie z.B. der IT) sie damit verursachen. Ab dem Stichtag wird die Rückkehr zur Zeitzone von bisher UTC-3 (nur Normalzeit) zu UTC-4 (mit Sommer-/Winterzeit) wirksam. Dieses muss in System technisch nachgezogen werden (besonders wenn System mit zentraler,




Created and Maintained by Yancy Lent - About - Planet Lotus Blog - Advertising - Mobile Edition