bcp_writefmt
Aplica-se a: SQL Server Banco de Dados SQL do Azure Instância Gerenciada de SQL do Azure PDW (Sistema de Plataforma de Análise) do Azure Synapse Analytics
Cria um arquivo de formato que contém uma descrição do formato do arquivo de dados de cópia em massa atual.
Sintaxe
RETCODE bcp_writefmt (
HDBC hdbc,
LPCTSTR szFormatFile);
Argumentos
hdbc
É o identificador de conexão ODBC habilitado para cópia em massa.
szFormatFile
É o caminho e o nome do arquivo de usuário que receberá valores de formato para o arquivo de dados.
Devoluções
SUCCEED ou FAIL.
Comentários
O arquivo de formato especifica o formato de dados de um arquivo de dados criado por cópia em massa. Chamadas para bcp_columns e bcp_colfmt definem o formato do arquivo de dados. bcp_writefmt salva essa definição no arquivo referenciado por szFormatFile. Para obter mais informações, consulte bcp_init.
Para obter mais informações sobre a estrutura de arquivos de formato de dados bcp, consulte Importar e exportar dados em massa usando o utilitário bcp (SQL Server).
Para carregar um arquivo de formato salvo, use bcp_readfmt.
Observação
O arquivo de formato produzido pelo bcp_writefmt tem suporte apenas por versões do utilitário bcp distribuídas com o SQL Server versão 7.0 e posterior.
Exemplo
// Variables like henv not specified.
HDBC hdbc;
DBINT nRowsProcessed;
// Application initiation, get an ODBC environment handle, allocate the
// hdbc, and so on.
...
// Enable bulk copy prior to connecting on allocated hdbc.
SQLSetConnectAttr(hdbc, SQL_COPT_SS_BCP, (SQLPOINTER) SQL_BCP_ON,
SQL_IS_INTEGER);
// Connect to the data source, return on error.
if (!SQL_SUCCEEDED(SQLConnect(hdbc, _T("myDSN"), SQL_NTS,
_T("myUser"), SQL_NTS, _T("myPwd"), SQL_NTS)))
{
// Raise error and return.
return;
}
// Initialize bulk copy.
if (bcp_init(hdbc, _T("myTable"), _T("myData.csv"),
_T("myErrors"), DB_OUT) == FAIL)
{
// Raise error and return.
return;
}
if (bcp_columns(hdbc, 3) == FAIL)
{
// Raise error and return.
return;
}
bcp_colfmt(hdbc, 1, SQLCHARACTER, 0, SQL_VARLEN_DATA, '\t', 1, 1);
bcp_colfmt(hdbc, 2, SQLCHARACTER, 0, SQL_VARLEN_DATA, '\t', 1, 2);
bcp_colfmt(hdbc, 3, SQLCHARACTER, 0, SQL_VARLEN_DATA, '\t', 1, 3);
if (bcp_writefmt(hdbc, _T("myFmtFile.fmt")) == FAIL)
{
// Raise error and return.
return;
}
if (bcp_exec(hdbc, &nRowsProcessed) == SUCCEED)
{
printf_s("%ld rows copied from SQL Server\n", nRowsProcessed);
}
// Carry on.