test1.pgc
上传用户:blenddy
上传日期:2007-01-07
资源大小:6495k
文件大小:3k
源码类别:

数据库系统

开发平台:

Unix_Linux

  1. exec sql whenever sqlerror sqlprint;
  2. exec sql include sqlca;
  3. /* comment */
  4. exec sql define AMOUNT 4;
  5. exec sql type intarray is int[AMOUNT];
  6. exec sql type string is char(8); 
  7. typedef int intarray[AMOUNT];
  8. int
  9. main ()
  10. {
  11. exec sql begin declare section;
  12.         intarray amount;
  13. int increment=100;
  14.         char name[AMOUNT][8];
  15. char letter[AMOUNT][1];
  16. char command[128];
  17. exec sql end declare section;
  18. exec sql var name is string(AMOUNT);
  19. char msg[128];
  20.         FILE *dbgs;
  21.         int i,j;
  22. if ((dbgs = fopen("log", "w")) != NULL)
  23.                 ECPGdebug(1, dbgs);
  24. strcpy(msg, "connect");
  25. exec sql connect to mm as main;
  26. strcpy(msg, "connect");
  27.         exec sql connect to pm;
  28. strcpy(msg, "create");
  29. exec sql at main create table test(name char(8), amount int, letter char(1));
  30. exec sql create table test(name char(8), amount int, letter char(1));
  31. strcpy(msg, "commit");
  32. exec sql at main commit;
  33. exec sql commit;
  34. strcpy(msg, "set connection");
  35. exec sql set connection to main;
  36. strcpy(msg, "execute insert 1");
  37.         sprintf(command, "insert into test(name, amount, letter) values ('db: ''mm''', 1, 'f')");
  38.         exec sql execute immediate :command;
  39.         sprintf(command, "insert into test(name, amount, letter) values ('db: ''mm''', 2, 't')");
  40.         exec sql execute immediate :command;
  41.         strcpy(msg, "execute insert 2");
  42.         sprintf(command, "insert into test(name, amount, letter) values ('db: ''pm''', 1, 'f')");
  43.         exec sql at pm execute immediate :command;
  44.         strcpy(msg, "execute insert 3");
  45.         sprintf(command, "insert into test(name, amount, letter) select name, amount+10, letter from test");
  46.         exec sql execute immediate :command;
  47.         
  48. printf("Inserted %d tuples via execute immediaten", sqlca.sqlerrd[2]);
  49.         strcpy(msg, "execute insert 4");
  50.         sprintf(command, "insert into test(name, amount, letter) select name, amount+?, letter from test");
  51. exec sql prepare I from :command;
  52.         exec sql at pm execute I using :increment;
  53.         
  54. printf("Inserted %d tuples via prepared executen", sqlca.sqlerrd[2]);
  55. strcpy(msg, "commit");
  56. exec sql commit;
  57. /* Stop automatic transactioning for connection pm. */
  58. exec sql at pm set autocommit to off;
  59.         strcpy(msg, "select");
  60.         exec sql select name, amount, letter into :name, :amount, :letter from test;
  61.         for (i=0, j=sqlca.sqlerrd[2]; i<j; i++)
  62.             printf("name[%d]=%8.8stamount[%d]=%dtletter[%d]=%cn", i, name[i], i, amount[i],i, letter[i][0]);
  63.         exec sql at pm select name, amount, letter into :name, :amount, :letter from test;
  64.         for (i=0, j=sqlca.sqlerrd[2]; i<j; i++)
  65.             printf("name[%d]=%8.8stamount[%d]=%dtletter[%d]=%cn", i, name[i], i, amount[i],i, letter[i][0]);
  66.         
  67. strcpy(msg, "drop");
  68. exec sql drop table test;
  69. exec sql at pm drop table test;
  70. strcpy(msg, "commit");
  71. exec sql commit;
  72. exec sql at pm commit;
  73. strcpy(msg, "disconnect"); 
  74.         exec sql disconnect all;
  75.         
  76. if (dbgs != NULL)
  77.                 fclose(dbgs);
  78. return (0);
  79. }