关于cluster table(簇表)BSEG
来源:互联网 发布:围棋软件形势判断 编辑:程序博客网 时间:2024/04/30 15:12
关于cluster table(簇表)BSEG
BSAD:应收明细(已清帐)
BSID:应收明细(未清帐)
BSAS:总帐明细(已清帐)
BSIS:总帐明细(未清帐)
BSAK:应付明细(已清帐)
BSIK:应付明细(未清帐)
BSEG主要通过“凭证号”“会计年度”“行号”和这六张表关联
一般情况下一笔业务产生的凭证都是未清的,那么:如果该业务行是客户相关的,则被记录到BSID;
如果该业务行是供应商相关的,则被记录到BSIK;
无论和客户相关还是和供应商相关,都是和总帐相关,所以也会有记录到BSIS;
但是如果这笔业务被清帐了,则相应的记录会从BSIS转移到BSAS
一般情况下:应收账款、预收账款、其他应收款、应收汇票等科目既和客户相关,又和未清项管理的总帐科目相关;
应付账款、预付账款、其他应付款、应付汇票等科目既和供应商相关,又和未清项管理的总帐科目相关;
其他总帐科目一般不启用未清项管理,所以记录一般都放在BSIS中。
BSEG本身是一个 Cluster Table(簇表),BSEG就是由上述的六大表的集成,当要读取”BSEG”Table时就等于去读取那六个表,这样你可以想像它读起来会就多慢。对於簇表或Pool Table,都是SAP系统本身在使用的,因此簇表本身是不存在资料库实体的,虽然是可以在ABAP使用,不过还是有一些限制: 1.不能使用select distinct or group by语法 2.不能使用Native SQL 3.不能使用specify field names after the order by clause 4.不能在建立次索引 5.查询时一定要用KEY FIELD
刚刚看到一份数据表资料的提示信息如下:
AVOID USING BSEG!!!
Use BSID, BSIK, and/or BSIS for open items
and BSAD, BSAK, and/or BSAS for cleared items
猜想一下,如果要select table 应该从这六个表里取数据,而不应该从BSEG里取了吧,呵呵,有点灵感了
Cluster Table本身是一個Key Field集合的Table,他在DB中實體的Table name是RFBLG,用SE11查一下你會發現它只有幾個Key Field,跟BSEG差了一堆,所以BSEG是SAP的東西,他本身是FITable的集合體,意思就是說當你每查一筆BSEG的ROW ,DB就要同步去把 RFBLG的cluster table MAP table都找出來組成一筆記錄回傳給SAP。
Cluster Table 本來就是SAP的應用系統在使用,主要是加快處理效能這跟Oracle 的Cluster table有些類似
所以ABAP在使用Cluster & Pool Table本來就有些限制的,如果去了解一下Cluster table的定義你就會知道,在Query中如果沒有小心使用這個Table,那你的PRD 系統會付出一定的代價的,用ST04 去查一下這個Table的大小你會嚇一跳的
我記的沒錯的話,在21天學會ABAP中有一節是專門在講Cluster table,另外在 www.sapfans.com中去search 一下,你會發現有一堆文章都在討論 Cluster Table,小心的使用它會很好用的
一般來說要從Cluster出發的話,除了基本的限制外,一定要從Key Field下手,如果一次處理量大於500筆,最好分次處理
(摘自SAP之家论坛)
BSEG是一个CLUSTER TABLE(簇表)。CLUSTER TABLE和POOL TABLE在SAP中形式是TABLE CLUSTER(表簇)和TABLE POOL(表池),这两种表实际是由若干表组成的。一般CLUSTER TABLE是由若干大的表(如财务凭证数据等业务数据表)组成的,而POOL TABLE是由许多小的表组成的。所以,在INNER JOIN的时候,由于不是和一个表JOIN所以找不到连接的KEY。如果真要用INNER JOIN的话,可以使用这类表的索引表。如BSEG的索引表有:BASAS,BASIS,BSAK,BSIK,BSAD,BSID
(摘自http://www.erp.org.tw/talk/content.asp?discuss_no=3&content_no=4054)
1) pooled table:這是用來放置一些控制程式流程參數資料的TABLE。包括SCREEN流程.程式參數.暫存資料等
(2)cluster table:用來放置連續性的相關資料(如transaction document)這是一個值得你特別注意的TABLE,因為它通常很大,若您直接access cluster table,效率會很差,像bseg就是,所以請盡量避免access該table,您應該可以找到其他的table來取代.
- 关于cluster table(簇表)BSEG
- 关于cluster table(簇表)BSEG
- 关于cluster table(簇表)BSEG
- 关于cluster table(簇表)BSEG
- SAP簇表(cluster table)BSEG使用方法
- 【DDIC】关于Cluster table以及Table Cluster
- 关于BSEG表
- CLUSTER TABLE
- Cluster Table
- BSEG
- 簇表BSEG及其子表
- what is cluster table?
- 表簇(table cluster)
- postgresql cluster table
- Transprant table / Pooled table / Cluster table
- What is a cluster table?
- PostgreSQL cluster table using index
- Table Pool / Table Cluster 中的参数含义
- EBS多OU和多帐套客户化总结
- hibernate中使用hilo生成主键的原理
- NSClassFromString returns nil的问题
- Oracle X$ table 参考手册
- Evernote超效率数字笔记术
- 关于cluster table(簇表)BSEG
- 71道经典Android面试题
- Effective C++ 学记之11 在operator=中处理“自我赋值“
- 【WPF】binding的使用
- Oracle DBA--查看表空间的使用情况SQL语句
- ZOJ 3230 Solving the Problems
- 应用之星:在线手机应用开发平台 不用搭建环境
- 设计模式之模板方法
- 免费试用Windows Azure云平台(无须提供信用卡)