当前位置: 首页 > news >正文

专业网站建站公司软件外包企业排名

专业网站建站公司,软件外包企业排名,wordpress高并发,怎么做接口网站遇到有LONG数据类型的表,要插入一条数据量很大的行,一次插入的缓冲区会不够大,这时需要一部分一部分的插入LONG数据,这就用到了在执行语句时动态提供数据的机制。在ODBC中要动态提供数据需要几个步骤。 1. 在绑定输入参数时&…

遇到有LONG数据类型的表,要插入一条数据量很大的行,一次插入的缓冲区会不够大,这时需要一部分一部分的插入LONG数据,这就用到了在执行语句时动态提供数据的机制。在ODBC中要动态提供数据需要几个步骤。

1. 在绑定输入参数时,要在SQLBindParameter()函数中指定数据长度时,使用SQL_LEN_DATA_AT_EXEC()宏得到数据长度,告诉应用程序数据在执行语句时才提供,使用的数据类型要用SQL_LONGVARCHAR或SQL_LONGBINARY。同时数据指针要提供一个数值,标记这个字段,为了区分多个动态插入的字段,这个数值在后面调用SQLParamData()函数时会返回,这样应用程序就知道现在是哪个字段需要提供数据。

2. 执行SQLExecute()或SQLExecDirect()函数,因为语句中有动态字段,所以函数会返回SQL_NEED_DATA的返回值。

3. 调用SQLParamData()函数,返回标识字段的数值,这时就知道是为哪个字段插入数据。函数返回SQL_NEED_DATA,这时需要提供数据。

4. 循环调用SQLPutData()函数,为字段提供动态数据,直到插入的数据完毕。

5. 再次调用SQLParamData()函数,看看是否还有下一个动态插入的字段需要操作,函数返回SQL_NEED_DATA,说明需要为新字段提供数据,重复步骤4的操作。如果返回SQL_SUCCESS,说明没有要提供数据的字段了,把上一个动态插入数据的系列操作结束。

举一个例子,在test_long1表中插入LONG数据,字段叫summary,插入10000个字符。SQLBindParameter()函数的StrLen_or_IndPtr参数设置为SQL_LEN_DATA_AT_EXEC(10000),ParameterType设置为SQL_LONGVARCHAR,ParameterValuePtr设置为参数的编号,比如编号为3,那么函数设置如下。

len_ind3 = SQL_LEN_DATA_AT_EXEC(10000);
SQLBindParameter(stmth, 3, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_LONGVARCHAR, 10000, 0, (void *)3, 0, &len_ind3);
下面我们看一个实际的例子,在test_long1表中插入一条数据,绑定三个参数,后面两个参数都使用动态提供数据,主要看看SQLParamData()函数和SQLPutData()函数的用法,以及如何动态提供数据。代码如下。

#include "stdio.h"
#include "stdlib.h"
#include "string.h"
#include "sql.h"
#include "sqlext.h"
#include "sqltypes.h"SQLHANDLE       envh;           /* env handle */
SQLHANDLE       dbch;           /* connect handle */
SQLHANDLE       stmth;          /* statement handle */int main(int argc, char *argv[])
{int         conn = 0;SQLRETURN   rc;SQLLEN      len_ind1;SQLLEN      len_ind2;SQLLEN      len_ind3;SQLLEN      total_amt;SQLLEN      once_amt;SQLINTEGER  id;SQLPOINTER  param_id;char        dsn_str[32];char        usrname[32];char        passwd[32];char        sqltxt[512];char        data[4096];if (argc < 3) {fprintf(stderr, "usage: %s dsn username password\n", argv[0]);return (-1);}strncpy(dsn_str, argv[1], 32);dsn_str[31] = '\0';strncpy(usrname, argv[2], 32);usrname[31] = '\0';strncpy(passwd, argv[3], 32);passwd[31] = '\0';rc = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &envh);if (rc != SQL_SUCCESS) {fprintf(stderr, "Allocate environment handle error.\n");return (-1);}rc = SQLSetEnvAttr(envh, SQL_ATTR_ODBC_VERSION, (void *)SQL_OV_ODBC3, 0);if (rc != SQL_SUCCESS) {fprintf(stderr, "Set ODBC version error.\n");goto free_exit;}rc = SQLAllocHandle(SQL_HANDLE_DBC, envh, &dbch);if (rc != SQL_SUCCESS) {fprintf(stderr, "Allocate DB connection handle error.\n");goto free_exit;}rc = SQLSetConnectAttr(dbch, SQL_ATTR_LOGIN_TIMEOUT, (SQLPOINTER)10, 0);if (rc != SQL_SUCCESS) {fprintf(stderr, "Set connection timeout value error.\n");goto free_exit;}rc = SQLConnect(dbch, (SQLCHAR *)dsn_str, SQL_NTS, (SQLCHAR *)usrname, SQL_NTS,(SQLCHAR *)passwd, SQL_NTS);if (rc != SQL_SUCCESS) {fprintf(stderr, "Connect to DB error.\n");goto free_exit;}conn = 1;fprintf(stdout, "connect DB ok ......\n");rc = SQLAllocHandle(SQL_HANDLE_STMT, dbch, &stmth);if (rc != SQL_SUCCESS) {fprintf(stderr, "Allocate statment handle error.\n");goto free_exit;}/* 插入一条数据,输入三个参数,note和summary动态提供数据 */sprintf(sqltxt, "insert into test_long1 (id, name, addr, note, summary) values (?, 'AAAAAAAA', 'BBBBBBBBBB', ?, ?)");rc = SQLPrepare(stmth, (SQLCHAR *)sqltxt, SQL_NTS);if (rc != SQL_SUCCESS) {fprintf(stderr, "Prepare statment error.\n");goto free_exit;}/* ID字段的插入值为10 */id = 10;/* ID正常插入,在绑定时提供数值* NOTE在执行时动态提供数据,长度为40,数据为40个'C'字符,一次提供完毕* SUMMARY在执行是动态提供数据,长度为10000,数据为10000个'D'字符,分多次提供* NOTE和SUMMARY字段使用SQL_LEN_DATA_AT_EXEC()宏计算长度*/len_ind1 = 0;len_ind2 = SQL_LEN_DATA_AT_EXEC(40);len_ind3 = SQL_LEN_DATA_AT_EXEC(10000);/* 绑定变量id */rc = SQLBindParameter(stmth, 1, SQL_PARAM_INPUT, SQL_C_SLONG, SQL_INTEGER,0, 0, &id, 0, &len_ind1);if (rc != SQL_SUCCESS) {fprintf(stderr, "Bind column 1 error.\n");goto free_exit;}/* 参数类型为SQL_LONGVARCHAR,数据指针指向参数编号2 */rc = SQLBindParameter(stmth, 2, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_LONGVARCHAR,2000, 0, (void *)2, 0, &len_ind2);if (rc != SQL_SUCCESS) {fprintf(stderr, "Bind column 2 error.\n");goto free_exit;}/* 参数类型为SQL_LONGVARCHAR,数据指针指向参数编号3 */rc = SQLBindParameter(stmth, 3, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_LONGVARCHAR,10000, 0, (void *)3, 0, &len_ind3);if (rc != SQL_SUCCESS) {fprintf(stderr, "Bind column 3 error.\n");goto free_exit;}/* 执行插入语句,这时函数返回SQL_NEED_DATA */rc = SQLExecute(stmth);if ((rc != SQL_SUCCESS) && (rc != SQL_NEED_DATA)) {fprintf(stderr, "Execute statment error.\n");goto free_exit;}/* 循环检查动态提供数据的字段 */while (1) {/* 调用SQLParamData()函数,parma_id返回绑定时指定的参数编号 */rc = SQLParamData(stmth, &param_id);if ((rc == SQL_SUCCESS) || (rc == SQL_SUCCESS_WITH_INFO))/* 返回SQL_SUCCESS说明所有动态提供数据的字段都操作完成了,退出循环 */break;if (rc != SQL_NEED_DATA) {/* 这里如果返回值不为SQL_NEED_DATA说明函数调用出错了 */fprintf(stderr, "Call SQLParamData() error.\n");goto free_exit;}if (param_id == (SQLPOINTER)2) {/* param_id等于2,说明要为第二个参数提供数据,提供40个'C'字符 */memset(data, 'C', 40);data[40] = '\0';len_ind2 = 40;/* 调用SQLPutData()函数,为参数2提供数据 */rc = SQLPutData(stmth, (SQLPOINTER)data, len_ind2);if ((rc != SQL_SUCCESS) && (rc != SQL_SUCCESS_WITH_INFO)) {fprintf(stderr, "Call SQLPutData() error.\n");goto free_exit;}} else if (param_id == (SQLPOINTER)3) {/* param_id等于3,说明要为第三个参数提供数据,提供10000个'D'字符* 每次提供4000字符,分三次提供完毕*/once_amt = 4000;total_amt = 10000;memset(data, 'D', 4000);data[4000] = '\0';while (total_amt > once_amt) {/* 每次提供4000字符 */rc = SQLPutData(stmth, (SQLPOINTER)data, once_amt);if ((rc != SQL_SUCCESS) && (rc != SQL_SUCCESS_WITH_INFO)) {fprintf(stderr, "Call SQLPutData() error.\n");goto free_exit;}total_amt -= once_amt;}if (total_amt > 0) {/* 提供最后的2000字符 */rc = SQLPutData(stmth, (SQLPOINTER)data, total_amt);if ((rc != SQL_SUCCESS) && (rc != SQL_SUCCESS_WITH_INFO)) {fprintf(stderr, "Call SQLPutData() error.\n");goto free_exit;}}} else {fprintf(stderr, "Invalid parameter number.\n");goto free_exit;}}/* 提交改变的数据 */rc = SQLEndTran(SQL_HANDLE_DBC, dbch, SQL_COMMIT);if (rc != SQL_SUCCESS) {fprintf(stderr, "End Transaction error.\n");goto free_exit;}fprintf(stdout, "Insert data successed ......\n");SQLFreeHandle(SQL_HANDLE_STMT, stmth);SQLDisconnect(dbch);SQLFreeHandle(SQL_HANDLE_DBC, dbch);SQLFreeHandle(SQL_HANDLE_ENV, envh);return (0);free_exit:if (stmth != NULL) {SQLFreeHandle(SQL_HANDLE_STMT, stmth);}if (conn) {SQLDisconnect(dbch);}if (dbch != NULL) {SQLFreeHandle(SQL_HANDLE_DBC, dbch);}if (envh != NULL) {SQLFreeHandle(SQL_HANDLE_ENV, envh);}return (-1);
}

访问www.tomcoding.com网站,学习Oracle内部数据结构,详细文档说明,下载Oracle的exp/imp,DUL,logminer,ASM工具的源代码,学习高技术含量的内容。

http://www.dt0577.cn/news/17496.html

相关文章:

  • 甘肃省住房城乡建设厅网站营销策划公司排名
  • 做系统下载网站建设网站模板之家官网
  • 焦作网站建设哪家公司好网络销售平台
  • 无锡公司建立网站网络培训心得体会
  • 网站如何运营免费seo公司
  • 宝和网站建设搜索引擎营销sem包括
  • 做网站的群深圳百度快照优化
  • 网站建设什么公司好互联网培训
  • 备案不关闭网站的方法杭州seo
  • 200做网站宣传软文是什么
  • 盐亭做网站交换链接名词解释
  • 网络推广企业网站推广策划书seo网站关键词优化排名
  • 电脑建站软件seo站内优化
  • 大连网站设计公司排名百度如何免费打广告
  • 网站建设合作合同模板下载网站的优化与推广分析
  • 怎么让别人访问我建的网站百度app免费下载安装最新版
  • 全球最好的设计网站成都seo优化排名公司
  • 王色网站浙江企业网站建设
  • 毕设做网站可以得高分吗博客seo怎么做
  • 网站icp备案有效时间清远网站seo
  • 丽水做网站的公司整站优化快速排名
  • 官方网站建设 磐石网络多少费用省委副书记
  • 要做未来科技的网站怎么做网址网域ip地址查询
  • 做电影海报在哪个网站好小说网站排名人气
  • 宝塔管理wordpress合肥百度seo排名
  • 做加盟的网站建设网络营销的一般流程
  • 如何更换wordpress域名百度刷排名seo
  • php网站开发技术题目3d建模培训班一般多少钱
  • 怎么注册网自己的网站吗怎么找需要推广的商家
  • 网站流量查询网站汕头seo收费