1

mst + .msi 表信息。

我创建了以下函数来读取 msi 表

// This method returns all rows and columns of a Table specified by Name
    public DataTable ReadMsiTableByName(string msiFile, string tableName)
    {
        DataTable msiTable = new DataTable(tableName);
        Database database = null;
        View view = null;

        try
        {
            using (database = new Database(msiFile, DatabaseOpenMode.ReadOnly))
            {
                string sqlQuery = String.Format("SELECT * FROM {0}", tableName);

                view = database.OpenView(sqlQuery);
                view.Execute(null);
                Record record = view.Fetch();

                ColumnCollection columnCollection = view.Columns;

                for (int i = 0; i < columnCollection.Count; i++)
                {
                    string columnName = columnCollection[i].Name.ToString();
                    System.Type columnType = columnCollection[i].Type;

                    msiTable.Columns.Add(columnName, columnType.UnderlyingSystemType);
                }

                while (record != null)
                {
                    DataRow row = msiTable.NewRow();
                    for (int i = 0; i < columnCollection.Count; i++)
                    {
                        string type = columnCollection[i].Type.ToString();

                        if (type == "System.String")
                        {
                            row[columnCollection[i].Name.ToString()] = record.GetString(columnCollection[i].Name.ToString());
                        }
                        else if (type == "System.Int16")
                        {
                            row[columnCollection[i].Name.ToString()] = record.GetInteger(columnCollection[i].Name.ToString());
                        }
                        else if (type == "System.Int32")
                        {
                            row[columnCollection[i].Name.ToString()] = record.GetInteger(columnCollection[i].Name.ToString());
                        }
                        else if (type == "System.IO.Stream")
                        {
                            System.IO.Stream stream;
                            stream = record.GetStream(columnCollection[i].Name.ToString());
                            row[columnCollection[i].Name.ToString()] = stream;
                        }
                    }
                    msiTable.Rows.Add(row);
                    record = view.Fetch();
                }
            }
        }

        catch (Exception ex)
        {
            CommonFn.CreateLog(ex.ToString());
        }

        finally
        {
            if (database != null)
                database.Close();

            if (view != null)
                view.Close();
        }
        return msiTable;
    }

但是我无法使用此功能读取 .mst。我读到您需要对其使用 msi 转换,但我不想更改 msi 或 mst 的内容,我只需要阅读所有表格。请指出我正确的方向。提前致谢 :)

4

2 回答 2

3

根据定义,MST 是一种变换。它仅包含基本 MSI 的增量。

数据库类有一个名为 ViewTransform 的方法。如果 MST 与 MSI 兼容,它将成功并且更改将显示在 _TransformView 表中。

或者,如果您不想查看发生了什么变化但想查看最终状态,则可以将 MSI 复制到临时 MSI 并使用 ApplyTransform 方法应用转换然后提交。现在您可以使用已有的代码查询它。

于 2013-05-27T16:33:06.770 回答
0

为我工作:

msiDatabase = new Database(@"Foo.msi", DatabaseOpenMode.ReadOnly);
msiDatabase.ApplyTransform(@"Foo.mst");
于 2013-11-26T16:29:35.653 回答