Я использую этот (упрощенный) фрагмент кода для извлечения набора таблиц из SQL Server с BCP .
$OutputDirectory = "c:\junk\"
$ServerOption = "-SServerName"
$TargetDatabase = "Content.dbo."
$ExtractTables = @(
"Page"
, "ChecklistItemCategory"
, "ChecklistItem"
)
for ($i=0; $i -le $ExtractTables.Length – 1; $i++) {
$InputFullTableName = "$TargetDatabase$($ExtractTables[$i])"
$OutputFullFileName = "$OutputDirectory$($ExtractTables[$i])"
bcp $InputFullTableName out $OutputFullFileName -T -c $ServerOption
}
Он отлично работает, но теперь некоторые таблицы нужно извлекать через представления, а некоторые нет. Итак, мне нужна такая структура данных:
"Page" "vExtractPage"
, "ChecklistItemCategory" "ChecklistItemCategory"
, "ChecklistItem" "vExtractChecklistItem"
Я смотрел хеши, но не нашел ничего о том, как их перебирать. Что было бы правильным здесь сделать? Возможно, просто использовать массив, но с обоими значениями, разделенными пробелом?
Или я упускаю что-то очевидное?