vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Erstellen von dynamischen Kontextmen?s - wann immer Sie sie brauchen!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

VB Skript (VBS)
VBScripts in CUB Files für Validierung von MSI Files.. 
Autor: Hammel
Datum: 04.06.08 14:02

Hallo,

vielleicht kann jamand meinen code überprüfen und endeckt den klitze kleinen Fehler, den ich übersehe.

Wenn die SQL Select Anweisung nicht mit den Werten in der DB Tabelle übereinstimmen, soll die fest definierte Message weiter gegeben werden...

Vielen Dank

Function zice32()
On Error Resume Next
 
	Set recInfo=Installer.CreateRecord(1)
	If Err <> 0 Then
		zice32 = 1
		Exit Function
	End If
 
	'Give description of test
	recInfo.StringData(0)="zice32" & Chr(9) & "3" & Chr(9) & "zice32 - Confirms" & _
  "that keys and foreign keys are the same type/size"
	Message &h03000000, recInfo
 
	'Give creation data
	recInfo.StringData(0)="zice32" & Chr(9) & "3" & Chr(9) & "Created 07/30/98." & _
  "Last Modified 10/08/98."
	Message &h03000000, recInfo
 
	Set msiDB = Session.Database
    Set msiTablesView = msiDB.OpenView("SELECT * FROM `CustomAction` WHERE" & _
      "`Action` = 'Call_EditRightFile'")
    msiTablesView.Execute
	If Err <> 0 Then
		recInfo.StringData(0)="zice32" & Chr(9) & "0" & Chr(9) & "view.Execute_1 API" & _
  "Error: " & Err
		Message &h03000000, recInfo
		zice32=1
		Exit Function
	End If 
    Set msiTablesRecord = msiTablesView.Fetch
    Do Until msiTablesRecord Is Nothing
        sThisTable = msiTablesRecord.StringData(1)
        sThisColumn = msiTablesRecord.StringData(2)
        sKeyTables = msiTablesRecord.StringData(6)
 
	    'Is this table in the database?
		iStat = Database.TablePersistent(sThisTable)
		If 1 = iStat Then
			If Len(sKeyTables) > 0 Then
				iKeyColumn = msiTablesRecord.IntegerData(7)
				Set msiForeignView = msiDB.OpenView("SELECT `" & sThisColumn & "` FROM `" & _
  sThisTable & "`")
					msiForeignView.Execute
					Set msiForeignInfo = msiForeignView.ColumnInfo(1)
				iDelim = InStr(sKeyTables & ";", ";")
				sKeyTable = Left(sKeyTables & ";", iDelim - 1)
				While Len(sKeyTable) > 0
 
					'Is this table in the database?
					iStat = Database.TablePersistent(sKeyTable)
					If 1 <> iStat Then
						recInfo.StringData(0)="zice32" & Chr(9) & "3" & Chr(9) & sKeyTable & "" & _
  "table is not in database, but is listed in the CustomAction table as a" & _
  "foreign key of " & sThisTable & "." & sThisColumn & Chr(9) & "" & Chr(9) & _
  "CustomAction"
						Message &h03000000, recInfo
					Else
						Set msiKeyView = msiDB.OpenView("SELECT * FROM `" & sKeyTable & "`")
						msiKeyView.Execute
						If Err <> 0 Then
							recInfo.StringData(0)="zice32" & Chr(9) & "0" & Chr(9) & "view.Execute_2" & _
  "API Error in table " & sKeyTable & " Error: " & _
  Installer.LastErrorRecord.StringData(1)
							Message &h03000000, recInfo
							zice32=1
							Exit Function
						End If 
						Set msiKeyInfo = msiKeyView.ColumnInfo(1)
						If LCase(msiKeyInfo.StringData(iKeyColumn)) <> LCase( _
  msiForeignInfo.StringData(1)) Then
							recInfo.StringData(0) = "zice32" & Chr(9) & "1" & Chr(9) & "Possible" & _
"Mis-Aligned Foreign Keys" & Chr(10) & _
								   sKeyTable & "." & iKeyColumn & " = " & _
								   msiKeyInfo.StringData(iKeyColumn) & Chr(10) & _
								   sThisTable & "." & sThisColumn & " = " & _
								   msiForeignInfo.StringData(1) & Chr(9) & "" & Chr(9) & "CustomAction"
							Message &h03000000, recInfo
    						bDifference = True
						End If
					End If
 
					iDelim = InStr(sKeyTables, ";")
					If iDelim > 0 Then
						sKeyTables = Mid(sKeyTables, iDelim + 1)
						iDelim = InStr(sKeyTables & ";", ";")
						sKeyTable = Left(sKeyTables & ";", iDelim - 1)
					Else
						sKeyTable = ""
					End If
				Wend
			End If
		End If
		Set msiTablesRecord = msiTablesView.Fetch
    Loop
 
	recInfo.StringData(0) = "zice32" & Chr(9) & "3" & Chr(9) & "Differences found" & _
  "= " & UCase(CStr(bDifference))
	Message &h03000000, recInfo
 
	'Return iesSuccess  
	zice32 = 1
	Exit Function
 
 
End Function
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
VBScripts in CUB Files für Validierung von MSI Files..1.947Hammel04.06.08 14:02
Re: VBScripts in CUB Files für Validierung von MSI Files..1.200Elwood04.06.08 15:04
Re: VBScripts in CUB Files für Validierung von MSI Files..1.200Elwood04.06.08 15:09
Re: VBScripts in CUB Files für Validierung von MSI Files..1.268Hammel04.06.08 15:17
Bei welcher Anweisung wird hat Err den Wert 424??? (oT)1.203Elwood04.06.08 15:23
Re: Bei welcher Anweisung wird hat Err den Wert 424??? (oT)1.350Hammel04.06.08 15:27
Re: Bei welcher Anweisung wird hat Err den Wert 424??? (oT)1.204Hammel04.06.08 15:29
Re: VBScripts in CUB Files für Validierung von MSI Files..1.297Elwood04.06.08 15:40
Re: VBScripts in CUB Files für Validierung von MSI Files..1.159Hammel04.06.08 15:57
Re: VBScripts in CUB Files für Validierung von MSI Files..1.170Elwood04.06.08 16:08
Re: VBScripts in CUB Files für Validierung von MSI Files..1.205Hammel04.06.08 16:11
Re: VBScripts in CUB Files für Validierung von MSI Files..1.196Hammel04.06.08 16:17
das glaube ich nicht...1.279Elwood04.06.08 16:27
Re: das glaube ich nicht...1.235Hammel04.06.08 16:48

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2024 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel