Как вернуть имена всех столбцов?

Вы можете использовать цикл For Each, как только вы предоставите корневую папку.

Пример:

Создать экземпляр FileSystemObject

Set objFSO = CreateObject("Scripting.FileSystemObject")

Получить объект папки

Set objFolder = objFSO.GetFolder("C:\Temp")

проходит через каждую папку в каталоге

For Each objSubFolder In objFolder.subfolders
    **Handle Code Goes Here**
Next objSubFolder

Итак, теперь у вас есть каждая подпапка корневой папки, которую вы предоставили (C: \ Temp) в этом случае вы можете сделать что-то подобное, чтобы получить информацию:

String1 = objSubFolder.Path 
String 2 = objSubFolder.Name
0
задан Igor Henriques 19 January 2019 в 17:29
поделиться

1 ответ

Вы можете использовать метод соединения GetSchema для получения информации о столбце. Я использую следующий код для вставки информации, которую мой собственный класс TableColumn здесь не показывает:

string[] restrictions = new string[] { null, null, tableName };

using (DataTable columns = conn.GetSchema("Columns", restrictions)) {
    int nameIndex = columns.Columns.IndexOf("COLUMN_NAME");
    int ordinalPosIndex = columns.Columns.IndexOf("ORDINAL_POSITION");
    int isNullableIndex = columns.Columns.IndexOf("IS_NULLABLE");
    int maxLengthIndex = columns.Columns.IndexOf("CHARACTER_MAXIMUM_LENGTH");
    int dataTypeIndex = columns.Columns.IndexOf("DATA_TYPE");
    int isPrimaryKeyIndex = columns.Columns.IndexOf("PRIMARY_KEY");
    int hasDefaultIndex = columns.Columns.IndexOf("COLUMN_HASDEFAULT");
    int defaultValueIndex = columns.Columns.IndexOf("COLUMN_DEFAULT");

    foreach (DataRow row in columns.Rows) {
        var col = new TableColumn {
            ColumnName = (string)row[nameIndex]
        };
        try {
            col.ColumnNameForMapping = prepareColumnNameForMapping(col.ColumnName);
        } catch (Exception ex) {
            throw new UnimatrixExecutionException("Error in delegate 'prepareColumnNameForMapping'", ex);
        }
        col.ColumnOrdinalPosition = (int)row[ordinalPosIndex];
        col.ColumnAllowsDBNull = (bool)row[isNullableIndex];
        col.ColumnMaxLength = (int)row[maxLengthIndex];

        string explicitDataType = ((string)row[dataTypeIndex]).ToLowerInvariant();
        col.ColumnDbType = GetColumnDbType(explicitDataType);
        col.ColumnIsPrimaryKey = (bool)row[isPrimaryKeyIndex];
        col.ColumnIsIdentity = explicitDataType == "integer" && col.ColumnIsPrimaryKey;
        col.ColumnIsReadOnly = col.ColumnIsIdentity;

        if ((bool)row[hasDefaultIndex]) {
            col.ColumnDefaultValue = GetDefaultValue(col.ColumnDbType, (string)row[defaultValueIndex]);
            if (col.ColumnDefaultValue == null) { // Default value could not be determined. Probably expression.
                col.AutoAction = ColumnAction.RetrieveAfterInsert;
            }
        }
        tableSchema.ColumnSchema.Add(col);
    }
}

Вы можете значительно упростить этот код, если вам нужны только имена столбцов.

0
ответ дан Olivier Jacot-Descombes 19 January 2019 в 17:29
поделиться
Другие вопросы по тегам:

Похожие вопросы: