string instanceName = @".\SQLEXPRESS";
string databaseName = "Tfs_DefaultCollection";
string outDirPath = "Output";string commandText = "select [name] from sys.tables order by [name]";
string connectionString = string.Format("Data Source={0};Initial Catalog={1};Integrated Security=True",
instanceName, databaseName);DataTable dt = new DataTable();
using (SqlDataAdapter da = new SqlDataAdapter(commandText, connectionString))
{
da.Fill(dt);
}Directory.CreateDirectory(outDirPath);
foreach (DataRow dr in dt.Rows)
{
Process.Start("bcp", string.Format(@"[{2}].[dbo].[{0}] out {3}\{0}.csv -S {1} -T -w -t ,",
(string)dr[0], instanceName, databaseName, outDirPath));
}
$instanceName = ".\SQLEXPRESS"
$databaseName = "Tfs_DefaultCollection"
$outDirPath = "Output"$commandText = "select [name] from sys.tables order by [name]"
$connectionString = [String]::Format("Data Source={0};Initial Catalog={1};Integrated Security=True", $instanceName, $databaseName)$dt = New-Object System.Data.DataTable
$da = New-Object System.Data.SqlClient.SqlDataAdapter($commandText, $connectionString)
[void]$da.Fill($dt)
$da.Dispose()if (-! (Test-Path $outDirPath))
{
New-Item $outDirPath -type directory
}$dt.Rows | ForEach-Object { bcp ([String]::Format("[{0}].[dbo].[{1}]", $databaseName, $_[0])) out ([String]::Format("{0}\{1}.csv", $outDirPath, $_[0])) -S $instanceName -T -w -t "," }
Set-ExecutionPolicy RemoteSigned
select [ct].[name] as [ChildTableName], [pt].[name] as [ParentTableName]from sys.foreign_keys as [f]inner join sys.tables as [ct] on [f].[parent_object_id] = [ct].[object_id]inner join sys.tables as [pt] on [f].[referenced_object_id] = [pt].[object_id]