免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2952 | 回复: 7
打印 上一主题 下一主题

[C] oci 中select出的时间怎么转换? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-07-21 00:04 |只看该作者 |倒序浏览
在oci中select 出的时间显示为: 5日-12月-2007年 。。。 ,我想让oci输入为 20071205000000 ,这样的时间格式,不知道该怎么做到?
因为是select * from table 来取的数据,所以不可能用 select to_char(sysdate,'yyyymmddhh24miss') 这样的方法来做到。我记得在shell中可以在sqlplus中用set设置时间格式,但是oci不知道该怎么做了。

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
2 [报告]
发表于 2008-07-21 00:24 |只看该作者
怎么不可以?
select to_char( date_field, "..." ) as date_field_ok, * from table
就可以了。
多一列数据而已。

论坛徽章:
0
3 [报告]
发表于 2008-07-21 00:48 |只看该作者
ls的同学,我做的是一个出库的小程序,并不知道表的内容,和表的结构,只能用select *
另外今天想到是不是可以在oci中用OCIATTRSet来设置alter session set NLS_DATE_FORMAT 来设置时间,不过都失败了。。。

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
4 [报告]
发表于 2008-07-21 00:52 |只看该作者
那你就在绑定列的时候处理一下嘛。
当然如果有现成的接口更好,你先找找看。

论坛徽章:
0
5 [报告]
发表于 2008-07-21 10:35 |只看该作者
都select出来了,为什么还不能处理呢??

论坛徽章:
7
酉鸡
日期:2013-10-30 17:17:51水瓶座
日期:2014-01-25 14:47:21天秤座
日期:2014-02-20 09:49:50处女座
日期:2014-11-04 17:44:082015年亚洲杯之中国
日期:2015-03-09 17:21:312015亚冠之北京国安
日期:2015-06-01 16:58:552015亚冠之山东鲁能
日期:2015-06-19 11:30:08
6 [报告]
发表于 2008-07-21 13:15 |只看该作者

回复 #1 pumk 的帖子

/* initialize svchp, stmhp, errhp, rowoff, iters, snap_in, snap_out */
/* set the execution mode to OCI_DESCRIBE_ONLY. Note that setting the mode to
OCI_DEFAULT does an implicit describe of the statement in addition to executing
the statement */
OCIParam *colhd; /* column handle */
checkerr(errhp, OCIStmtExecute(svchp, stmhp, errhp, iters, rowoff, snap_in, snap_out, OCI_DESCRIBE_ONLY);
/* Get the number of columns in the query */
checkerr(errhp, OCIAttrGet(stmhp, OCI_HTYPE_STMT, &numcols, 0, OCI_ATTR_PARAM_COUNT, errh));
/* go through the column list and retrieve the data type of each column. We
start from pos = 1 */
for (i = 1; i <= numcols; i++)
{
    /* get parameter for column i */
    checkerr(errhp, OCIParamGet(stmhp, OCI_HTYPE_STMT, errh, &colhd, i));
    /* get data-type of column i */
    checkerr(errhp, OCIAttrGet(colhd, OCI_DTYPE_PARAM,  &type[i - 1], 0, OCI_ATTR_DATA_TYPE, errh));
}

论坛徽章:
0
7 [报告]
发表于 2008-07-23 10:17 |只看该作者
ok,解决了。

论坛徽章:
0
8 [报告]
发表于 2008-07-23 10:21 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP