BSEG和BSIS、BSAS、BSID、BSAD、BSIK、BSAK 六个表的关系
BSEG和BSIS、BSAS、BSID、BSAD、BSIK、BSAK六个表的关系
1、数据关系:
BSAS+BSIS+BSAK+BSIK+BSAD+BSID = BSEG
2、六个表说明:
cleared |
opened |
|
BSAS |
BSIS |
==>all GL documents |
BSAK |
BSIK |
==>all AP documents |
BSAD |
BSID |
==>all AR documents |
BSAS:总帐明细(已清帐)总账
BSIS:总帐明细(未清帐)总账
BSAD:应收明细(已清帐)客户
BSID:应收明细(未清帐)客户
BSAK:应付明细(已清帐)供应商
BSIK:应付明细(未清帐)供应商
3、表关系:
BSEG主要通过“凭证号”“会计年度”“行号”和这六张表关联
BUKRS ( Company code )
BELNR ( Document No )
GJAHR ( Fiscal Year )
BUZEI ( Line Item )
BKPF 是财务凭证抬头,BSEG 是财务凭证行项目。在财务凭证记账的时候,数据被插入 BKPF 和 BSEG,如果有必要,数据同时插入以上六张表中的一个未清表。
做清帐的时候,数据从六张表中的一个未清表删除,同时插入对应的已清表。一般情况下一笔业务产生的凭证都是未清的,那么:如果该业务行是客户相关的,则被记录到BSID;如果该业务行是供应商相关的,则被记录到BSIK;无论和客户相关还是和供应商相关,都是和总帐相关,所以也会有记录到BSIS;但是如果这笔业务被清帐了,则相应的记录会从BSI*转移到BSA*
一般情况下:应收账款、预收账款、其他应收款、应收汇票等科目既和客户相关,又和未清项管理的总帐科目相关;应付账款、预付账款、其他应付款、应付汇票等科目既和供应商相关,又和未清项管理的总帐科目相关;
其他总帐科目一般不启用未清项管理,所以记录一般都放在BSIS中。
4、BSEG特点:
BSEG本身是一个 Cluster Table(簇表),BSEG就是由上述的六大表的集成,当要读取”BSEG”Table时就等于去读取那六个表,这样你可以想像它读起来会就多慢。对於簇表或Pool Table,都是SAP系统本身在使用的,因此簇表本身是不存在资料库实体的,虽然是可以在ABAP使用,不过还是有一些限制:
- 不能使用select distinct or group by语法
- 不能使用Native SQL
- 不能使用specify field names after the order by clause
- 不能在建立次索引
- 查询时一定要用KEY FIELD
PS:在簇表里抽取数据效率很低,可以按照不同的科目,在其他六张表取对象数据!!!!!
---------------------------------------------------------------------------------
原文: http://skewen.iteye.com/blog/1478241
一张会计凭证的明细部分可以包含复数个行项目,这些复数个行项目在存入BSEG等簇表的同时,也会根据行项目的状态存入以下六个财务数据表中。
一般情况下刚开始都是未清凭证,
如果该行项目是与客户相关的,则被记录到BSID;
如果该行项目是与供应商相关的,则被记录到BSIK;
无论和客户相关还是和供应商相关,都是和总帐相关,所以同时也记录到BSIS。
随后当这笔业务被清帐时,
如果该行项目是与客户相关的,则相应的记录会从BSID转移到BSAD;
如果该行项目是与客户相关的,则相应的记录会从BSIK转移到BSAK;
无论和客户相关还是和供应商相关,都是和总帐相关,所以同时相应的记录也会从BSIS转移到BSAS。
一般情况下:
预收帐款、应收帐款、其他应收款、应收汇票等科目既和客户相关,又和未清项管理的总帐科目相关;
预付帐款、应付帐款、其他应付款、应付汇票等科目既和供应商相关,又和未清项管理的总帐科目相关;
其他总帐科目一般不启用未清项管理,所以记录一般都放在BSIS中。
除了上述6个会计凭证表外还有一个物料凭证表,因为凭证中有的时候还会出现与物料相关的行项目,但是与物料相关的行项目不需要作未清帐处理,所以只有一个物料凭证表相对应。
BSIM:
第二级指数,商品凭证
Secondary Index,
Documents for Material
这里有个概念需要注意:
存入BSEG等簇表时是以binary
save的形式将一张凭证的明细部分的所有行项目信息编辑成一个长文本,再存入表簇RFBLG中的vardata项目中。
存入7个相应的透明表时则是根据上述行项目的性质,分别存入相应的透明表,表中每条记录只记载一条行项目信息。
有了上述的知识,我们不难理解,
使用T-code:FB03查看凭证的明细信息时,实际是读取BSEG等簇表的信息。
使用T-code:FBL1N, FBL3N, FBL5N 分别查看供应商,总账,客户的未清和已清项信息时,实际上读取BSIK