免费注册 查看新帖 |

Chinaunix

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

怎么把一个asc码转成字符?ORACLE里是chr函数,informix好像没有类似的函数 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-07-07 09:44 |只看该作者 |倒序浏览
ORACLE语法:
    select ascii('a') from dual;
      返回97
    select chr(97) from dual;
      返回'a'


INformix语法:
    select ascii('a') from dual;
      返回97
    select chr(97) from dual;
      粗体红色部分应该用什么函数替换?

论坛徽章:
0
2 [报告]
发表于 2010-07-07 12:04 |只看该作者
写个datablade实现

论坛徽章:
11
金牛座
日期:2015-03-19 16:56:22数据库技术版块每日发帖之星
日期:2016-08-02 06:20:00数据库技术版块每日发帖之星
日期:2016-04-24 06:20:00数据库技术版块每日发帖之星
日期:2016-04-13 06:20:00IT运维版块每日发帖之星
日期:2016-04-13 06:20:00数据库技术版块每日发帖之星
日期:2016-02-03 06:20:00数据库技术版块每日发帖之星
日期:2015-08-06 06:20:00季节之章:春
日期:2015-03-27 15:54:57羊年新春福章
日期:2015-03-27 15:54:37戌狗
日期:2015-03-19 16:56:41数据库技术版块每日发帖之星
日期:2016-08-18 06:20:00
3 [报告]
发表于 2010-07-07 12:21 |只看该作者
在11中引入了ascii(),似乎没有这个反向的函数..

论坛徽章:
0
4 [报告]
发表于 2010-07-07 15:30 |只看该作者
请问二楼,datablade怎么写,能不能帮忙贴一个例子,谢谢了

论坛徽章:
0
5 [报告]
发表于 2010-07-07 15:44 |只看该作者
  1. chr.c


  2. #include "mi.h"


  3. mi_lvarchar * chr(mi_int1  val )
  4. {
  5.    mi_string s[2];
  6.    mi_lvarchar * lvs;
  7.    s[0]=val;
  8.    s[1]='\0';
  9.    lvs=mi_string_to_lvarchar(s);
  10.    return lvs;

  11. }
复制代码


  1. 把这个chr.c 编译成.so
  2. dbaccess 里运行 chr.sql

  3. create function chr ( smallint ) returning lvarchar
  4. with (not variant)
  5. external name '/home/test/wlq/blade/chr.so(chr)'
  6. language c;
  7. execute function chr(65);
复制代码
我在AIX里IDS9.30测试通过。

论坛徽章:
0
6 [报告]
发表于 2010-07-09 10:15 |只看该作者
多谢二楼
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP