⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 bulkcopy.c

📁 在SCO UNIX5.05
💻 C
字号:
/*
** Confidential property of Sybase, Inc.
** (c) Copyright Sybase, Inc. 1992 to ???
** All rights reserved.
*/

/*
** %M%:      %I%      %G%      %U%
**  
**  
*/
#if USE_SCCSID
static char Sccsid[] = {"%Z% %M% %I% %G%"};
#endif /* USE_SCCSID */

/*
**	bulkcopy.c
**
** This example uses the bulk copy (bcp) routines to copy the
** data from a host file into a newly-created table containing several
** SQL Server datatypes.
**
*/

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

#include <sybfront.h>
#include <sybdb.h>
#include "sybdbex.h"

#define BUFLEN      2048
#define PLEN        25 

/*
** Forward declarations
*/
CS_VOID		  doexit PROTOTYPE((int));


main(argc,argv)
int           argc;
char          *argv[];
{

	LOGINREC        *login;
	DBPROCESS       *dbproc;

	/* Variables for host file data to be copied to database. */
	DBCHAR           age[PLEN+1];
	DBCHAR           userid[PLEN+1];
	DBCHAR           royalty[PLEN+1];
	DBCHAR           name[PLEN+1];
	DBCHAR           title_id[PLEN+1];
	DBCHAR           us_citizen[PLEN+1];
	DBCHAR           account[PLEN+1];
	DBCHAR           title[PLEN+1];
	DBCHAR           manager[PLEN+1];
	FILE             *infile;

	printf("Demo of the bulk copy routines in DB Library\n\n");
	fflush(stdout);

	/* Initialize DB-Library. */
	if (dbinit() == FAIL)
		exit(ERREXIT);

	/* Install the user-supplied error-handling and message-handling
	** routines. They are defined at the bottom of this source file.
	*/
	dberrhandle(err_handler);
	dbmsghandle(msg_handler);
	
	/* Allocate and initialize the LOGINREC structure to be used
	** to open a connection to SQL Server.
	*/
	login = dblogin();
	DBSETLUSER(login, USER);
	DBSETLPWD(login, PASSWORD);
	DBSETLAPP(login, "example_bcp");

	/* Enable bulk copy for this connection. */
	BCP_SETL(login, TRUE);
	
	/*
	** Get a connection to the database.
	*/
	if ((dbproc = dbopen(login, NULL)) == (DBPROCESS *) NULL)
	{
		fprintf(stderr, "Can't connect to server.\n");
		doexit(ERREXIT);
	}

	/*
	** Create the database and turn on the option to allow bulkcopy.
	*/
	printf("Creating the 'example_bcp' database.\n");

	/* Create the database. */
	dbcmd(dbproc,"create database example_bcp ");
	dbsqlexec(dbproc);
	while (dbresults(dbproc) != NO_MORE_RESULTS)
		continue;

	/*
	** Create a table that contains several SQL Server datatypes.
	*/
	printf("Creating the 'alltypes' table.\n");
	dbuse(dbproc, "example_bcp");
	dbcmd(dbproc,"create table alltypes ");
	dbcmd(dbproc,"(age tinyint,");
	dbcmd(dbproc,"userid smallint,");
	dbcmd(dbproc,"royalty int,");
	dbcmd(dbproc,"name char(25),");
	dbcmd(dbproc,"title_id varbinary(20),"); 
	dbcmd(dbproc,"us_citizen bit,");
	dbcmd(dbproc,"account float,");
	dbcmd(dbproc,"title varchar(20),");
	dbcmd(dbproc,"manager char(25))");

	dbsqlexec(dbproc);
	while (dbresults(dbproc) != NO_MORE_RESULTS)
		continue;

	/* Turn on option to allow bulk copy */
	dbuse(dbproc, "master");
	dbcmd(dbproc, "execute sp_dboption example_bcp, 'bulk', true");
	dbsqlexec(dbproc);
	while (dbresults(dbproc) != NO_MORE_RESULTS)
		continue;
	dbuse(dbproc, "example_bcp");
	dbcmd(dbproc, "checkpoint");
	dbsqlexec(dbproc);
	while (dbresults(dbproc) != NO_MORE_RESULTS)
		continue;


	/* Insert rows of data into the newly created table "alltypes".
	** We will use the bulk copy routines to read in the data from
	** a host file.
	*/

	/*
	** We first need to initialize the bulk copy routines by
	** naming the table and host file to be copied. Although
	** we could use have the data copied directly from the
	** host file into the database table, that's not very
	** interesting for demonstration purposes.  Instead we'll
	** read the data from the host file ourselves and then
	** use the bulk copy routines to take the data from our
	** program variables.
	*/
	if (bcp_init(dbproc, "example_bcp..alltypes", NULL,
		"bcp.errors", DB_IN) != SUCCEED)
			doexit(ERREXIT);

	/*
	** We now tell bcp which program variables will contain the
	** data to be copied in.  For each column, we give the variable
	** address, its program datatype, its column position,
	** length information, and terminator information.
	*/

	/*
	** args: dbproc; program variable address; prefix length, if any;
	**	 program variable length; terminator, if any; terminator length;
	**	 program variable type; column number
	**
	** Because we're going to read all the data into program variables
	** that are character arrays, we can have the bcp bind routine
	** automatically do the conversion to the correct table column
	** datatype.
	*/
	bcp_bind(dbproc, (BYTE *)age, 0, -1, (BYTE *)"", 1, SYBCHAR, 1);
	bcp_bind(dbproc, (BYTE *)userid, 0, -1, (BYTE *)"", 1, SYBCHAR, 2);
	bcp_bind(dbproc, (BYTE *)royalty, 0, -1, (BYTE *)"", 1, SYBCHAR, 3);
	bcp_bind(dbproc, (BYTE *)name, 0, -1, (BYTE *)"", 1, SYBCHAR, 4);
	bcp_bind(dbproc, (BYTE *)title_id, 0, -1, (BYTE *)"", 1, SYBCHAR, 5);
	bcp_bind(dbproc, (BYTE *)us_citizen, 0, -1, (BYTE *)"", 1, SYBCHAR, 6);
	bcp_bind(dbproc, (BYTE *)account, 0, -1, (BYTE *)"", 1, SYBCHAR, 7);
	bcp_bind(dbproc, (BYTE *)title, 0, -1, (BYTE *)"", 1, SYBCHAR, 8);
	bcp_bind(dbproc, (BYTE *)manager, 0, -1, (BYTE *)"", 1, SYBCHAR, 9);

	/*
	** Now we'll open the data file, read the data into our program
	** variables. As we read in each row, we'll have bcp move it
	** into the database table.
	*/
	if ((infile=fopen("bcpdata.in","r")) == NULL)
	{
		fprintf(stderr, "Unable to open file 'bcpdata.in'.\n");
		doexit(ERREXIT);
	}

	/* Read the data in from the host file. */
	fprintf(stdout, "Moving data from host file to database.\n");
	while (fscanf(infile, "%s %s %s %s %s %s %s %s %s",
		age, userid, royalty, name, title_id, us_citizen,
		account, title, manager) != EOF)

			/* Bulk copy it into the database */
			bcp_sendrow(dbproc);

	/*
	** Close the bulk copy process so all the changes are committed
	** to the database.
	*/
	bcp_done(dbproc);

	doexit(STDEXIT);
}


CS_VOID doexit(value)
int value;
{
    dbexit();            /* always call dbexit before returning to OS */
    exit(value);
}


int err_handler(dbproc, severity, dberr, oserr, dberrstr, oserrstr)
DBPROCESS       *dbproc;
int             severity;
int             dberr;
int             oserr;
char            *dberrstr;
char            *oserrstr;
{
	if ((dbproc == NULL) || (DBDEAD(dbproc)))
		return(INT_EXIT);
	else 
	{
		printf("DB-Library error:\n\t%s\n", dberrstr);

		if (oserr != DBNOERR)
			printf("Operating-system error:\n\t%s\n", oserrstr);

		return(INT_CANCEL);
	}
}

int msg_handler(dbproc, msgno, msgstate, severity, msgtext, 
                srvname, procname, line)

DBPROCESS       *dbproc;
DBINT           msgno;
int             msgstate;
int             severity;
char            *msgtext;
char            *srvname;
char            *procname;
DBUSMALLINT     line;

{
	/*
	** If it's a database change message, we'll ignore it.
	** Also ignore language change message.
	*/
	if (msgno == 5701 || msgno == 5703)
		return(0);

	printf ("Msg %ld, Level %d, State %d\n", 
	        msgno, severity, msgstate);

	if (strlen(srvname) > 0)
		printf ("Server '%s', ", srvname);
	if (strlen(procname) > 0)
		printf ("Procedure '%s', ", procname);
	if (line > 0)
		printf ("Line %d", line);

	printf("\n\t%s\n", msgtext);

	return(0);
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -