Tuxedo数据buffer基本类型介绍

2024-03-04 00:08

本文主要是介绍Tuxedo数据buffer基本类型介绍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Tuxedo数据buffer基本类型介绍

一、 课程目标

通过本课程学习,你可以掌握如下知识:
  • 掌握tuxedo中STRING类型buffer的用途
  • 掌握tuxedo中CARRAY类型buffer的用途
  • 掌握tuxedo中FML(FML32)类型buffer的用途
  • 掌握tuxedo中VIEW(VIEW32)类型buffer的用途
    注:后续的课程将介绍Tuxedo新增的数据类型:EFML(Embedded Record in FML)、XML Buffer

    二、 String类型buffer介绍
    (1)STRING类型buffer简介
    STRING类型buffer是主要用于面向行、变长度的文本信息类型buffer。STRING类型buffer要求必须以NULL作为结束符的。如果系统采用STRING类型,那么在配置ubbconfig文件时,必须在*MACHINE部分配置TYPE,指明buffer类型为STRING类型。在两种不同类型架构的机器进行buffer传输时候,TUXEDO对STRING类型buffer进行加码、解码过程。无论系统申请了多少长度的buffer,系统自动按着NULL所在的位置决定STRING类型的buffer长度。
    (2)STRING类型buffer如何申请
    char *SndBuf;
    SndBuf = (char *) tpalloc("STRING",NULL,1024)
    (3)STRING类型使用方法和调用方法
    strcpy(SndBuf,"Bea Tuxedo");
    tpcall("TOUPPER",SndBuf,0,&RcvBuf,&len,0);

    三、 CARRAY类型buffer介绍
    (1)CARRAY类型buffer简介
    CARRAY类型buffer是一种独立于机器的buffer类型。用户在使用时必须指定CARRAY类型数据的长度,CARRAY类型数据可以包含NULL字符。CARRAY类型数据不需要加、解码过程。CARRAY类型数据可以用来传输汉字、二进制数据、文件、图形等。CARRAY类型可以作为FML(FML32)、VIEW(VIEW32)的数据类型子项buffer。
    (2)CARRAY类型buffer如何申请
    tpalloc("CARRAY",NULL,1024*2)
    (3)CARRAY类型使用方法和调用方法

    四、 VIEW(VIEW32)类型buffer介绍
    (1)VIEW类型buffer简介
    Tuxedo使用VIEW类型buffer处理类似C语言的结构等数据类型复杂数据。使用VIEW类型buffer可以将各数据元素与一种结构数据类型结合,通过结构就可以访问各数据元素。VIEW类型数据即使没有没有数据也占用空间,结构发生变化,需要重新编译程序。
    注明:(VIEW类型buffer是16位寻址的,VIEW32是32位寻址的.)

    (2)VIEW类型buffer使用方法
    使用VIEW类型数据步骤:

  • 建立VIEW文件
  • 设置环境变量
  • 编译VIEW文件
  • 在代码中包含VIEW头文件,在程序中使用VIEW结构及API函数
  • 编译程序
  • 运行程序
    (1)建立VIEW文件

    VIEW user

    $ /* VIEW structure for user information */

    #type   cname   fbname count flag size null

    long    count COUNT 1      -    - “”    0

    float   sumfee SUMFEE   1      -    -     0.0

    string usrname USRNAME 1      -    80   “”

    short   num      NUM      1      -    -     0

    END

      


    (2)设置环境变量
    /* view文件存放路径,使用冒号分割(NT用分号)*/
    VIEWDIR=$APPDIR/inc
    /* 用逗号分割的二进制view文件 */
    VIEWFILES=user.V
    export VIEWDIR VIEWFILES

    (3)编译VIEW文件

  • 使用viewc(viewc32)编译view文件
    $viewc -n user.v
  • view命令简介:
    viewc [-n] [-d viewdir] viewfile [viewfile ...]
    或者:
    viewc32 [-n] [-d viewdir] viewfile [viewfile ...]
    [-d viewdir]:指定输出文件的路径(默认在当前目录下)
    [-n]:指定在编译view结构类型数据不产生FML buffer数据结构

    (4)view编译后生成的头文件

    struct user {

    /* VIEW structure for user information */

        long      count;

        float     sumfee;

        char      usrname[80];

        short  num;

    };



    (5)VIEW类型buffer的使用
    struct user *pszUser;
    pszUser=(struct user *)tpalloc("VIEW"," user",sizeof(user));
    …………………
    pszUser ->count = 1680;
    pszUser ->sumfee = 198.96;
    strcpy(pszUser->usrname,"Wsy");
    pszUser->num = 160;
    …………………
    tpcall("PSVC",(char *)pszUser,0,(char **)&pszUser,&rcvlen,0);
    …………………

    五、 FML(FML32)类型buffer介绍
    (1)VIEW类型buffer简介
    FML类型buffer允许存取多个命名的字段。例如:(NAME: "BEA",ADDRESS "China Beijing",PHONE "010-85281188")。每一个命名的字段可以在buffer中存放零个或更多个(occurrences)的值.
    注明:(FML类型buffer是16位寻址的,FML32是32位寻址的.)


    (2)FML支持的数据类型:
  • Short
  • Char
  • Long
  • Float
  • Double
  • String
  • Carray
    (3)FML类型buffer使用方法
    使用FML类型数据步骤:
  • 建立FML文件
  • 设置环境变量
  • 编译FML文件
  • 在代码中包含FML头文件,在程序中使用FML API函数
  • 编译程序
  • 运行程序
    (1)建立FML Field Table文件

    *base 1000

    # name   number type flags comments

    COUNT    1        long    -   -

    SUMFEE   2        float   - -

    USRNAME 3        string -   -

    NUM       4        short  -   -


    (2)设置环境变量
    set FLDTBLDIR32="c:\tuxedo\wsy"
    set FIELDTBLS32=user.fld
    其中:
    FLDTBLDIR(FLDTBLDIR32):指明Field Table文件的名字,多个用逗号分割
    FIELDTBLS (FIELDTBLS32):Filed Table文件的所在路径,多个用冒号分割,在WinNT系统中使用分号分割.
    (3)编译FML Field Table文件
  • 使用mkfldhdr(mkfldhdr32)编译Field Table文件
    $mkfldhdr32 user.fld
    (4)FML Field Table编译后生成的头文件

    /*  fname   fldid            */

    /*  -----   -----            */

    #define COUNT   ((FLDID32)33555433) /* number: 1001 type: long */

    #define SUMFEE  ((FLDID32)100664298)/* number: 1002 type: float */

    #define USRNAME ((FLDID32)167773163)/* number: 1003 type: string */

    #define NUM ((FLDID32)1004) /* number: 1004 type: short */



    (5)FML类型buffer的使用
    FBFR32 *SndBuf;
    SndBuf = (FBFR32 *)tpalloc("FML32",NULL,1024);
    …………………
    lCount = 1680;
    Fchg32(SndBuf, COUNT,0,(char *)&lCount ,0);
    fSumFee = 198.96;
    Fchg32(SndBuf, SUMFEE, (char *)&fSumFee,0);
    Strcpy(sUsrName , "wsy");
    Fchg32(SndBuf, USRNAME, (char *)sUsrName,0);
    iNum = 160;
    Fchg32(SndBuf, SUMFEE, (char *)&iNum,0);
    …………………
    tpcall("PSVC",(char *) SndBuf,0,(char **)& SndBuf,&rcvlen,0);
    Fget32(SndBuf, COUNT,0, (char *)&lCount ,0);
    Fget32(SndBuf, USRNAME,0, (char *)sUsrName,0);
    …………………
    注:FML和VIEW类型buffer的API函数在后续的文章有详细的介绍和代码分析.

这篇关于Tuxedo数据buffer基本类型介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/771373

相关文章

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

Redis 中的热点键和数据倾斜示例详解

《Redis中的热点键和数据倾斜示例详解》热点键是指在Redis中被频繁访问的特定键,这些键由于其高访问频率,可能导致Redis服务器的性能问题,尤其是在高并发场景下,本文给大家介绍Redis中的热... 目录Redis 中的热点键和数据倾斜热点键(Hot Key)定义特点应对策略示例数据倾斜(Data S

MySQL中慢SQL优化的不同方式介绍

《MySQL中慢SQL优化的不同方式介绍》慢SQL的优化,主要从两个方面考虑,SQL语句本身的优化,以及数据库设计的优化,下面小编就来给大家介绍一下有哪些方式可以优化慢SQL吧... 目录避免不必要的列分页优化索引优化JOIN 的优化排序优化UNION 优化慢 SQL 的优化,主要从两个方面考虑,SQL 语

Python实现将MySQL中所有表的数据都导出为CSV文件并压缩

《Python实现将MySQL中所有表的数据都导出为CSV文件并压缩》这篇文章主要为大家详细介绍了如何使用Python将MySQL数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到... python将mysql数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到另一个