Chinaunix首页 | 论坛 | 博客
  • 博客访问: 106900016
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900017
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900018
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900020
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900021
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900022
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900023
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900024
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900025
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900026
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900027
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900028
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900019
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900030
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900031
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900032
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900033
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900034
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900035
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900036
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900038
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900039
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900040
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900041
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900042
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900043
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900034
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900045
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900046
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900047
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900048
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900049
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900050
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900051
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900052
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900053
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900054
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900055
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900056
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900057
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900058
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900049
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900060
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900061
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900062
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900063
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900064
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900065
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900066
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900067
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900068
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks

DB2 9 应用开发(733 考试)认证指南,第 4 部分: 嵌入式 SQL 编程(5)-sdccf-ChinaUnix博客
  • 博客访问: 106900069
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类:

2008-05-31 23:29:48

构建与 DB2 进行交互的应用程序

developerWorks



创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210729) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210728) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210727) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210726) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210725) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210724) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210723) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210722) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210721) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210720) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210719) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210718) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210717) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210716) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210715) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210714) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210713) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210712) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210711) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210710) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210709) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210708) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210707) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210706) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210705) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210704) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210703) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210702) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210701) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210700) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210699) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210698) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210697) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210696) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210695) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210694) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210693) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210692) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210691) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210690) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210689) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210688) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210687) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210686) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210685) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210684) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210683) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210682) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210681) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210680) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210679) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~


创建可执行的应用程序

到目前为止,我们已经讨论了在高级编程语言源代码文件中嵌入 SQL 语句的基本步骤,但是还没有详细讨论如何将包含嵌入式 SQL 语句的源代码文件转换成可执行的应用程序。一旦编写好源代码文件,在创建与 DB2 数据库进行交互的应用程序之前,必须按所示次序执行下列步骤:

  1. 必须对所有包含嵌入式 SQL 语句的源代码文件进行预编译。在预编译过程中,包含嵌入式 SQL 语句的源代码文件被转换为完全由高级编程语言语句组成的源代码文件 —— 嵌入式 SQL 语句本身被注释掉,并将相应的 DB2 特定的函数调用放在它们的位置上。

    同时,创建一个相应的包,其中包含用来处理源代码文件中嵌入的每个静态 SQL 语句的访问计划(还包含其他内容)。(访问计划包含 DB2 Database Manager 用来执行 SQL 语句的优化的信息;静态 SQL 语句的访问计划是在预编译时产生的,而动态 SQL 语句的访问计划是在应用程序运行时产生的。)SQL 预编译器产生的包可以在生成它们时存储在预编译器所使用的数据库中,也可以将它们写入一个外部绑定文件,以后可以将该文件绑定到任何有效的 DB2 数据库中(将包存储到适当数据库中的过程称为绑定)。如果没有另外指定,SQL 预编译器还会负责检查静态 SQL 语句中引用的所有数据库对象(比如表和列)是否实际存在,以及应用程序中使用的所有数据类型是否与数据库中的数据类型兼容。(这就是在运行 SQL 预编译器时必须连接到数据库的原因。)

  2. 包含嵌入式 SQL 语句的源代码文件一旦经由 SQL 预编译器处理,就必须用高级编程语言编译器来编译所产生的源代码文件(以及所需的其他源代码文件)。这个编译器负责将源代码文件转换成目标模块,链接器(linker)可以使用这些目标模块来创建可执行的程序。

  3. 当成功编译了构建应用程序所需的所有源代码文件之后,必须将产生的目标模块与高级编程语言库以及 DB2 库链接起来,生成可执行的程序。在大多数情况下,产生的程序以可执行应用程序的形式存在。然而,它也可以以共享库或动态链接库(DLL)的形式存在,其他可执行应用程序可以加载和执行这些库。

  4. 如果由 SQL 预编译器处理的文件的包没有绑定到适当的数据库上,就必须使用在预编译过程中产生的绑定文件来绑定它们。使用称为 DB2 Binder(或简称为 Binder)的工具完成绑定过程。

图 1 说明了在使用延迟绑定时,将嵌入式 SQL 源代码文件转换为可执行应用程序的基本过程。



构建过程
阅读(210678) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~