EXAMPLE6.C

/*example6.c */ 
/*
** This example illustrates opening a data file, inserting data
** from the file into a newly created table containing several
** SQL Server datatypes, and updating the table using browse mode
** techniques.
*/

#if defined(DBNTWIN32)
#include <windows.h>
#endif

#include <stdio.h>
#include <sqlfront.h>
#include <sqldb.h>

#define BUFLEN 2048

/* Forward declarations of the error-handling and message-handing
functions. */
int err_handler(DBPROCESS*, int, int, int, char*, char*);
int msg_handler(DBPROCESS*, DBINT, int, int, char*);

main()
{
LOGINREC*login;
DBPROCESS*q_dbproc;/* This DBPROCESS is used to
* query the database.
*/
DBPROCESS*u_dbproc;/* This DBPROCESS is used to
* simultaneously update the database.
*/
const char *qualptr;/* This points to the WHERE clause
* appropriate for updating q_dbproc's
* current data row.
*/
RETCODEreturn_code;
DBTINYINTage;
static charcmdbuf[BUFLEN];
FILE*infile;

dbinit();/* initialize dblib */

/* Install the user-supplied error-handling and message-handling
* functions. They are defined at the bottom of this source file.
*/
dbmsghandle((DBMSGHANDLE_PROC)msg_handler);
dberrhandle((DBERRHANDLE_PROC)err_handler);

/* Allocate and initialize the LOGINREC structure to be used
* to open a connection to SQL Server.
*/

login = dblogin();

DBSETLUSER(login, "user");
DBSETLPWD(login, "my_passwd");
DBSETLAPP(login, "example6");
DBSETLVERSION(login, DBVER60);

q_dbproc = dbopen(login, "my_server");
u_dbproc = dbopen(login, "my_server");

printf("Creating the 'alltypes' table.\n");

/* Create a table that contains several SQL Server datatypes. */
dbcmd(q_dbproc,"if exists(select name from sysobjects where name='alltypes') drop table alltypes ");

dbcmd(q_dbproc,"create table alltypes ");
dbcmd(q_dbproc,"(age tinyint,");
dbcmd(q_dbproc,"userid smallint,");
dbcmd(q_dbproc,"royalty int,");
dbcmd(q_dbproc,"name char(25),");
dbcmd(q_dbproc,"title_id varbinary(20),");
dbcmd(q_dbproc,"us_citizen bit,");
dbcmd(q_dbproc,"account float,");
dbcmd(q_dbproc,"title varchar(20),");
dbcmd(q_dbproc,"manager char(25),");
dbcmd(q_dbproc,"sales decimal(10,2),");
dbcmd(q_dbproc,"timestamp)");

dbcmd(q_dbproc, "create unique index index1 on alltypes(userid)");

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

/* Insert rows of data into the newly created table "alltypes".
* We will read in the contents of the file and form an
* INSERT statement.
*/

if ((infile=fopen("datafile","r")) == NULL)
{
printf("Unable to open file 'datafile'.\n");
return(STDEXIT);
}

printf("Inserting rows into the 'alltypes' table...\n");

while ((fgets(cmdbuf,BUFLEN,infile)) != NULL)
{
dbfcmd(q_dbproc,"insert into alltypes \n");
dbfcmd(q_dbproc,"values(%s, null) \n",cmdbuf);
}

dbsqlexec(q_dbproc);

/* Process the results of each of the INSERT statements. */

while ((return_code = dbresults(q_dbproc)) != NO_MORE_RESULTS)
{
if (return_code == FAIL)
printf("One of the insert statements failed.\n");
}

/* Using DB-LIBRARY's browse mode facilities, we'll increment
* the age of every person in the table.
*/

printf("Updating rows in the 'alltypes' table...\n");

dbcmd(q_dbproc,"select * from alltypes for browse");
dbsqlexec(q_dbproc);

while ((return_code = dbresults(q_dbproc)) != NO_MORE_RESULTS)
{
if (return_code == SUCCEED)
{
while (dbnextrow(q_dbproc) != NO_MORE_ROWS)
{
age = *((DBTINYINT *)(dbdata(q_dbproc, 1)));
qualptr = dbqual(q_dbproc, -1, "alltypes");
dbcmd(u_dbproc, "update alltypes");
dbfcmd
(u_dbproc, " set age = %d %s", age+1, qualptr);
dbsqlexec(u_dbproc);
dbresults(u_dbproc);
dbfreequal(qualptr);
}
}
}

/* Now, we'll look at the updated contents of the table to
* verify that the ages were properly incremented.
*/
printf("Selecting rows from the 'alltypes' table:\n");
dbcmd(q_dbproc, "select * from alltypes");
dbsqlexec(q_dbproc);
dbresults(q_dbproc);
dbprrow(q_dbproc);

printf("Dropping 'alltypes' table:\n");
dbcmd(q_dbproc, "drop table alltypes");
dbsqlexec(q_dbproc);
dbresults(q_dbproc);

dbexit();
return(STDEXIT);
}

int err_handler(dbproc, severity, dberr, oserr, dberrstr, oserrstr)
DBPROCESS*dbproc;
intseverity;
intdberr;
intoserr;
char*dberrstr;
char*oserrstr;
{
printf("DB-LIBRARY error:\n\t%s\n", dberrstr);

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

if ((dbproc == NULL) || (DBDEAD(dbproc)))
return(INT_EXIT);

return(INT_CANCEL);
}

int msg_handler(dbproc, msgno, msgstate, severity, msgtext)
DBPROCESS*dbproc;
DBINTmsgno;
intmsgstate;
intseverity;
char*msgtext;
{
printf
("SQL Server message %ld, state %d, severity %d:\n\t%s\n",
msgno, msgstate, severity, msgtext);
return(0);
}