{
EXEC SQL CREATE TABLE PIOPLE
(FIRSTNAME VARCHAR(9) NOT NULL,
LASTNAME CHAR(11) NOT NULL,
ADDRESS VARCHAR(12) NOT NULL,
PHONE CHAR(7) NOT NULL UNIQUE,
DATETIME TIMESTAMP DEFAULT,
SALARY INTEGER NOT NULL,
IDENTIFIER SMALLINT NOT NULL,
CONSTRAINT CHECK_PHONE
CHECK(PHONE BETWEEN '210____' AND '299____'));
if (sqlca.sqlcode != 0)
{
::printf("ERROR - SQL code returned non-zero for "
"creation of PIOPLE, received %d\n",sqlca.sqlcode);
::exit(-1);
}
EXEC SQL CREATE UNIQUE INDEX PHONEX
ON PIOPLE(PHONE);
if (sqlca.sqlcode != 0)
{
::printf("ERROR - SQL code returned non-zero for "
"create unique index, received %d\n",sqlca.sqlcode);
::exit(-1);
}
EXEC SQL ALTER TABLE PIOPLE
PRIMARY KEY(PHONE);
if (sqlca.sqlcode != 0)
{
::printf("ERROR - SQL code returned non-zero for "
"alter table PIOPLE, received %d\n",sqlca.sqlcode);
::exit(-1);
}
}
void WORK::add(void)
{
::printf("\nFirstname? "); ::gets(firstname);
::printf("Lastname? "); ::gets(lastname);
::printf("Address? "); ::gets(address);
::printf("Phone? "); ::gets(phone);
::printf("Salary? "); ::gets(s); salary=::atoi(s);
::printf("Identifier? "); ::gets(s); identifier=::atoi(s);
EXEC SQL INSERT INTO PIOPLE
(FIRSTNAME,LASTNAME,ADDRESS,PHONE,SALARY,IDENTIFIER)
VALUES
(:firstname,:lastname,:address,:phone,:salary,:identifier);
if (sqlca.sqlcode != 0)
{
::printf("ERROR - SQL code returned non-zero for "
"insert into PIOPLE, received %d\n",sqlca.sqlcode);
return;
}
}
void WORK::print(void)
{
EXEC SQL DECLARE CUR1 CURSOR
FOR SELECT
FIRSTNAME,LASTNAME,ADDRESS,PHONE,DATETIME,SALARY,IDENTIFIER
FROM PIOPLE;
if (sqlca.sqlcode != 0)
{
::printf("ERROR - SQL code returned non-zero for "
"declare cursor CUR1, received %d\n",sqlca.sqlcode);
return;
}
EXEC SQL OPEN CUR1;
EXEC SQL WHENEVER NOT FOUND GO TO CLOSE_CUR1;
if (sqlca.sqlcode != 0)
{
::printf("ERROR - SQL code returned non-zero for "
"open CUR1, received %d\n",sqlca.sqlcode);
return;
}
::printf("\nFirstname Lastname Address "
"Phone Datetime Salary Ident");
::printf("\n========= =========== ============ "
"======= ====================== ====== =====\n");
while(1)
{
EXEC SQL FETCH CUR1
INTO
:firstname,:lastname,:address,:phone,:datetime,:salary,:identifier;
if (sqlca.sqlcode != 0)
{
::printf("ERROR - SQL code returned non-zero for "
"fetch CUR1, received %d\n",sqlca.sqlcode);
return;
}
::printf("%-9s %-11s %-12s %-7s %-22s %-6d %-5d\n"
"",firstname,lastname,address,phone,datetime,salary,identifier);
}
EXEC SQL WHENEVER NOT FOUND CONTINUE;
CLOSE_CUR1:
EXEC SQL CLOSE CUR1;
if (sqlca.sqlcode != 0)
{
::printf("ERROR - SQL code returned non-zero for "
"close CUR1, received %d\n",sqlca.sqlcode);
return;
}
}
void WORK::AVG_salary(void)
{
EXEC SQL BEGIN DECLARE SECTION;
long int avg;
EXEC SQL END DECLARE SECTION;
EXEC SQL SELECT AVG(SALARY) INTO :avg
FROM PIOPLE;
if (sqlca.sqlcode != 0)
{
::printf("ERROR - SQL code returned non-zero for "
"select AVG(SALARY), received %d\n",sqlca.sqlcode);
return;
}
::printf("\nAVG_salary=%d\n",avg);
}
WORK::~WORK()
{
EXEC SQL DROP TABLE PIOPLE;
if (sqlca.sqlcode != 0)
{
::printf("ERROR - SQL code returned non-zero for "
"drop of PIOPLE received %d??\n",sqlca.sqlcode);
::exit(-1);
}
EXEC SQL COMMIT;
}
int main(void)
{
WORK a;
for(int i;;)
{printf("\n\n1: add\n");
printf("2: print\n");
Уважаемый посетитель!
Чтобы распечатать файл, скачайте его (в формате Word).
Ссылка на скачивание - внизу страницы.