pctused(percent used)与pctfree(percent free)

本文介绍了Oracle数据库中pctused和pctfree参数的作用及其对性能的影响。解释了freelists的概念,以及如何合理设置这些参数以达到高效的空间利用与性能平衡。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

【IT168 技术文档】pctused(percent used)与pctfree(percent free)是Oracle的两个与性能相关的块级存储参数。虽然我很少修改它们,但是相应的概念还是比较重要的,所以强化一下。

    概念:

    pctused:一个块的使用水位的百分比,这个水位将使该块返回到可用列表中去等待更多的插入操作。
    pctfree:用来为一个块保留的空间百分比,以防止在今后的更新操作中增加一列或多列值的长度。
    freelist:可用列表是表中的一组可插入数据的可用块。
    行连接:指一行存储在多个块中的情况,这是因为该行的长度超过了一个块的可用空间大小,即行链接是跨越多块的行。
    行迁移:指一个数据行不适合放入当前块而被重新定位到另一个块(那里有充足的空间)中,但在原始块中保留一个指针的情形。原始块中的指针是必需的,因为索引的ROWID项仍然指向原始位置。

    计算公式:

    PCTFREE=(Average Row Size-Initial Row Size)*100/Average Row Size
    PCTUSED=(100-PCTFREE) -Average Row Size * 100/Availabe Data Space

    Oracle的其中一个优点时它可以管理每个表空间中的自由空间。Oracle负责处理表和索引的空间管理,这样就可以让我们无需懂得Oracle的表和索引的内部运作。不过,对于有经验的Oracle调优专家来说,他需要懂得Oracle是如何管理表的extent和空闲的数据块。对于调整拥有高的insert或者update的系统来说,这是非常重要的。

    要精通对象的调整,你需要懂得freelists和freelist组的行为,它们和pctfree及pctused参数的值有关。这些知识对于企业资源计划(ERP)的应用是特别重要的,因为在这些应用中,不正确的表设置通常是DML语句执行慢的原因。

    对于初学者来说,最常见的错误是认为默认的Oracle参数对于所有的对象都是最佳的。除非磁盘的消耗不是一个问题,否则在设置表的pctfree和pctused参数时,就必须考虑平均的行长和数据库的块大小,这样空的块才会被有效地放到freelists中。当这些设置不正确时,那些得到的freelists也是"dead"块,因为它们没有足够的空间来存储一行,这样将会导致明显的处理延迟。

    Freelists对于有效地重新使用Oracle表空间中的空间是很重要的,它和pctfree及pctused这两个存储参数的设置直接相关。如果将pctused设置为一个高的值,这时数据库就会尽快地重新使用块。不过,高性能和有效地重新使用表的块是对立的。在调整Oracle的表格和索引时,需要认真考虑究竟需要高性能还是有效的空间重用,并且据此来设置表的参数。以下我们来看一下这些freelists是如何影响Oracle的性能的。

    当有一个请求需要插入一行到表格中时,Oracle就会到freelist中寻找一个有足够的空间来容纳一行的块。你也许知道,freelist串是放在表格或者索引的第一个块中,这个块也被称为段头(segment header)。pctfree和pctused 参数的唯一目的就是为了控制块如何在freelists中进出。虽然freelist link和 unlink是简单的Oracle功能,不过设置freelist link (pctused) 和unlink (pctfree) 对Oracle的性能确实有影响。

    由DBA的基本知识知道,pctfree参数是控制freelist un-links的(即将块由freelists中移除)。设置pctfree=10 意味着每个块都保留10%的空间用作行扩展。pctused参数是控制freelist re-links的。设置pctused=40意味着只有在块的使用低于40%时才会回到表格的freelists中。

    许多新手对于一个块重新回到freelists后的处理都有些误解。其实,一旦由于一个删除的操作而令块被重新加入到freelist中,它将会一直保留在freelist中即使空间的使用超过了60%,只有在到达pctfree时才会将数据块由freelist中移走。

    表格和索引存储参数设置的要求总结

    以下的一些规则是用来设置freelists, freelist groups, pctfree和pctused存储参数的。你也知道,pctused和pctfree的值是可以很容易地通过alter table命令修改的,一个好的DBA应该知道如何设置这些参数的最佳值。

    有效地使用空间和高性能之间是有矛盾的,而表格的存储参数就是控制这个方面的矛盾:

    . 对于需要有效地重新使用空间,可以设置一个高的pctused值,不过副作用是需要额外的I/O。一个高的pctused值意味着相对满的块都会放到freelist中。因此,这些块在再次满之前只可以接受几行记录,从而导致更多的I/O。

    . 追求高性能的话,可以将pctused设置为一个低的值,这意味着Oracle不会将数据块放到freelists中直到它几乎是空的。那么块将可以在满之前接收更多的行,因此可以减少插入操作的I/O。要记住Oracle扩展新块的性能要比重新使用现有的块高。对于Oracle来说,扩展一个表比管理freelists消耗更少的资源。

    让我们来回顾一下设置对象存储参数的一些常见规则:

    .经常将pctused设置为可以接收一条新行。对于不能接受一行的free blocks对于我们来说是没有用的。如果这样做,将会令Oracle的性能变慢,因为Oracle将在扩展表来得到一个空的块之前,企图读取5个"dead"的free block。

    .表格中chained rows的出现意味着pctfree太低或者是db_block_size太少。在很多情况下,RAW和LONG RAW列都很巨大,以至超过了Oracle的最大块的大小,这时chained rows是不可以避免的。

    .如果一个表有同时插入的SQL语句,那么它需要有同时删除的语句。运行单一个一个清除的工作将会把全部的空闲块放到一个freelist中,而没有其它包含有任何空闲块的freelists出现。

    .freelist参数应该设置为表格同时更新的最大值。例如,如果在任何时候,某个表最多有20个用户执行插入的操作,那么该表的参数应该设置为freelists=20。

    应记住的是freelist groups参数的值只是对于Oracle Parallel Server和Real Application Clusters才是有用的。对于这类Oracle,freelist groups应该设置为访问该表格的Oracle Parallel Server实例的数目。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10113559/viewspace-617039/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/10113559/viewspace-617039/

-- XINSPADM.SP_PO_DETL definition CREATE TABLE "XMC_PO_DETL" ( "POITEM_ID" NUMBER(*,0), "PO_ID" NUMBER(*,0), "PO_NO" VARCHAR2(10), "PO_ITEM" VARCHAR2(10), "PLANT" VARCHAR2(30), "MAT_GRP" VARCHAR2(20), "MC_NO" VARCHAR2(18), "MC_DESC" VARCHAR2(40), "ITEM_QTY" NUMBER(16,3), "UNIT" VARCHAR2(4), "UNIT_PRICE" NUMBER(23,4), "TOTAL_AMOUT" NUMBER(23,4), "INFO_REC" VARCHAR2(20), "VEND_MAT" VARCHAR2(35), "TAX_CODE" VARCHAR2(2), "DELIV_COMPL_FLAG" VARCHAR2(3) DEFAULT 'NO', "DELIV_DATE" DATE, "ITEM_CAT" VARCHAR2(1), "PR_NO" VARCHAR2(10), "PR_ITEM" VARCHAR2(10), "ACCT_ASSCAT" VARCHAR2(1), "GR_FLAG" VARCHAR2(3) DEFAULT 'NO', "GR_BY" VARCHAR2(10), "DEL_FLAG" VARCHAR2(3) DEFAULT 'NO', "PO_REF_NO" VARCHAR2(10), "REMAIN_BALANCE_FLAG" VARCHAR2(3) DEFAULT 'NO', "SAP_UDATE" DATE, "FORECAST_DELIV_DATE" DATE, "RECEIVE_QTY" NUMBER(16,3) DEFAULT 0, "RECEIVE_PERCENT" NUMBER(10,4) DEFAULT 0, "EQ_SEQ_ID" VARCHAR2(10), "MANUFACTURER" VARCHAR2(60), "EQ_MAKER_PART_NO" VARCHAR2(30), "GL_ACCT" VARCHAR2(10), "TAX_FREE_ENG" VARCHAR2(92), "TAX_FREE_CHI" VARCHAR2(92), "DRAW_DOC" VARCHAR2(22), "DOC_VEND_MAT" VARCHAR2(60), "ORIGINAL_MC_NO" VARCHAR2(20), "PRICE_UNIT" NUMBER(*,0), "REQUISITIONER" VARCHAR2(20), "FINAL_INVOICE_FLAG" VARCHAR2(3) DEFAULT 'NO', "FREE_FLAG" VARCHAR2(3) DEFAULT 'NO', "IR_QTY" NUMBER(16,3), "IR_AMOUNT" NUMBER(16,3), "INVOICE_PLAN_FLAG" VARCHAR2(3) DEFAULT 'NO', "GR_NOVALUE_FLAG" VARCHAR2(3) DEFAULT 'NO', "UNLOAD_POINT" VARCHAR2(20), "ASSET_NO" VARCHAR2(50), "ASSET_SUBNO" VARCHAR2(20), "COST_CENTER" VARCHAR2(20), "COAREA" VARCHAR2(30), "COMMIT_ITEM" VARCHAR2(20), "FUND_YEAR" VARCHAR2(10), "FUND_CENTER" VARCHAR2(20), "CDATE" DATE, "UDATE" DATE, "SHIP_QTY" NUMBER(16,3) DEFAULT 0, "SHIP_AMOUNT" NUMBER(23,4) DEFAULT 0, "AUTO_ACTION" VARCHAR2(10), "REM_SHELF_LIFE" NUMBER(16,4), "RFQ_NO" VARCHAR2(10), "RFQ_ITEM" VARCHAR2(6), "INFOUPDATE_FLAG" VARCHAR2(3), "FACILITY_PO_STATUS" VARCHAR2(20), "TMP_DEL" VARCHAR2(3), "PRICE_PRIORITY" VARCHAR2(255), "BUDGET_CODE" VARCHAR2(20), "COST_CATEGORY" VARCHAR2(30), "ECCN" VARCHAR2(80), "COSTDOWN_BASE" NUMBER(23,4), PRIMARY KEY ("POITEM_ID") USING INDEX PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "SUPPLY_DATA" ENABLE, CONSTRAINT "FK_PO_DETL_POID" FOREIGN KEY ("PO_ID") REFERENCES "XINSPADM"."SP_PO_MAST" ("PO_ID") ENABLE ) SEGMENT CREATION IMMEDIATE PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING STORAGE(INITIAL 65536 NEXT 8192 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "SUPPLY_DATA" ; CREATE OR REPLACE TRIGGER "XINSPADM"."TRI_SET_EQUIPMENTKEY3" BEFORE INSERT OR UPDATE ON XINSPADM.SP_PO_DETL FOR EACH ROW declare -- local variables here equipmentID sp_po_detl.eq_seq_id%type; begin begin select eq_seq_id into equipmentID from ems_eq_id_view where eq_id=:new.eq_seq_id; :new.eq_seq_id := equipmentID; exception when no_data_found then null; end; end; / ALTER TRIGGER "XINSPADM"."TRI_SET_EQUIPMENTKEY3" DISABLE; CREATE OR REPLACE TRIGGER "XINSPADM"."TRI_SET_FORECASTDELIVYDATE2" BEFORE INSERT ON XINSPADM.SP_PO_DETL FOR EACH ROW begin :new.forecast_deliv_date:=:new.deliv_date; end; / ALTER TRIGGER "XINSPADM"."TRI_SET_FORECASTDELIVYDATE2" ENABLE; CREATE INDEX "XINSPADM"."INX_SP_PO_DETL_EQ_SEQ_ID" ON "XINSPADM"."SP_PO_DETL" ("EQ_SEQ_ID") PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "SUPPLY_DATA" ; CREATE INDEX "XINSPADM"."INX_SP_PO_DETL_ITEMCAT" ON "XINSPADM"."SP_PO_DETL" ("ITEM_CAT") PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "SUPPLY_DATA" ; CREATE INDEX "XINSPADM"."INX_SP_PO_DETL_POID" ON "XINSPADM"."SP_PO_DETL" ("PO_ID") PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "SUPPLY_DATA" ; CREATE INDEX "XINSPADM"."INX_SP_PO_DETL_POITEM" ON "XINSPADM"."SP_PO_DETL" ("PO_NO", "PO_ITEM") PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "SUPPLY_DATA" ; CREATE INDEX "XINSPADM"."INX_SP_PO_DETL_PONO" ON "XINSPADM"."SP_PO_DETL" ("PO_NO") PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "SUPPLY_DATA" ; CREATE INDEX "XINSPADM"."INX_SP_PO_DETL_POREFNO" ON "XINSPADM"."SP_PO_DETL" ("PO_REF_NO") PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "SUPPLY_DATA" ; CREATE INDEX "XINSPADM"."INX_SP_PO_DETL_PRITEM" ON "XINSPADM"."SP_PO_DETL" ("PR_NO", "PR_ITEM") PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "SUPPLY_DATA" ; CREATE INDEX "XINSPADM"."INX_SP_PO_DETL_PRNO" ON "XINSPADM"."SP_PO_DETL" ("PR_NO") PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "SUPPLY_DATA" ; CREATE UNIQUE INDEX "XINSPADM"."SYS_C0021337" ON "XINSPADM"."SP_PO_DETL" ("POITEM_ID") PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "SUPPLY_DATA" ; GRANT SELECT ON "XINSPADM"."SP_PO_DETL" TO "OEREAD"; GRANT SELECT ON "XINSPADM"."SP_PO_DETL" TO "XINSPREAD";这个也一样
08-23
CREATE TABLE “XINSPADM”.“SP_PO_MAST” ( “PO_ID” NUMBER(,0), “PO_NO” VARCHAR2(10), “PO_CAT” VARCHAR2(1), “PO_TYPE” VARCHAR2(10), “PMNT_TERM” VARCHAR2(20), “VENDOR_CODE” VARCHAR2(10), “CURRENCY” VARCHAR2(5), “INCO_TERMS1” VARCHAR2(3), “INCO_TERMS2” VARCHAR2(30), “CONTRACT_START_DATE” DATE, “CONTRACT_END_DATE” DATE, “TARGET_VAL” NUMBER(23,4), “REL_GROUP” VARCHAR2(2), “REL_FLAG” VARCHAR2(3) DEFAULT ‘NO’, “REL_DATE” DATE, “DEL_FLAG” VARCHAR2(3) DEFAULT ‘NO’, “COMPANY_CODE” VARCHAR2(10), “PUR_GROUP” VARCHAR2(5), “PURCH_ORG” VARCHAR2(10), “EPO_FLAG” VARCHAR2(3) DEFAULT ‘NO’, “MATN_MAN” VARCHAR2(20), “SAP_CDATE” DATE, “BUYER” VARCHAR2(20), “CUR_REL_CODE” VARCHAR2(2), “SALES_PERSON” VARCHAR2(30), “PUR_GROUP_CONTACT” VARCHAR2(50), “PUR_GROUP_TEL” VARCHAR2(30), “PR_NO” VARCHAR2(20), “USERID” VARCHAR2(20), “VALIDITY_START” DATE, “VALIDITY_END” DATE, “MODIFIER” VARCHAR2(20), “WORKFLOW_STATUS” VARCHAR2(255), “STREET” VARCHAR2(100), “HOUSE_NUMBER” VARCHAR2(50), “POST_CODE” VARCHAR2(20), “CITY” VARCHAR2(200), “COUNTRY_CODE” VARCHAR2(100), “TEL” VARCHAR2(30), “TEL_EXT” VARCHAR2(30), “FAX” VARCHAR2(30), “FAX_EXT” VARCHAR2(30), “STOCK_TYPE” VARCHAR2(10), “CDATE” DATE, “UDATE” DATE, “WORKFLOW_ID” NUMBER(19,0), “FLOW_TYPE” VARCHAR2(255), “WORKFLOW_START_DATE” DATE, “WORKFLOW_FINISH_DATE” DATE, “WARRANTY_PERIOD” NUMBER(,0), “WARRANTY_METHOD” VARCHAR2(20), “HEAD_CAT” VARCHAR2(1), “HEAD_TAX” VARCHAR2(2), “CATEGORY” VARCHAR2(1), “MAX_ORG_LEVEL” VARCHAR2(20), “MAX_ORG_GRADE” NUMBER(18,0), CONSTRAINT "UQ_PO_MAST_PONO" UNIQUE ("PO_NO") DISABLE, PRIMARY KEY ("PO_ID") USING INDEX PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ENABLE ) SEGMENT CREATION IMMEDIATE PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING STORAGE(INITIAL 65536 NEXT 8192 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; CREATE INDEX “XINSPADM”.“INX_SP_PO_MAST_PONO” ON “XINSPADM”.“SP_PO_MAST” (“PO_NO”) PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; CREATE INDEX “XINSPADM”.“INX_SP_PO_MAST_PRNO” ON “XINSPADM”.“SP_PO_MAST” (“PR_NO”) PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; CREATE INDEX “XINSPADM”.“INX_SP_PO_MAST_VCODE” ON “XINSPADM”.“SP_PO_MAST” (“VENDOR_CODE”) PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; CREATE INDEX “XINSPADM”.“SP_PO_MAST_IDX1” ON “XINSPADM”.“SP_PO_MAST” (“PMNT_TERM”) PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; CREATE UNIQUE INDEX “XINSPADM”.“SYS_C0012217” ON “XINSPADM”.“SP_PO_MAST” (“PO_ID”) PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; GRANT SELECT ON “XINSPADM”.“SP_PO_MAST” TO “OEREAD”; GRANT SELECT ON “XINSPADM”.“SP_PO_MAST” TO “XINSPREAD”;-- XINSPADM.SP_PO_DETL definition CREATE TABLE “XINSPADM”.“SP_PO_DETL” ( “POITEM_ID” NUMBER(,0), “PO_ID” NUMBER(,0), “PO_NO” VARCHAR2(10), “PO_ITEM” VARCHAR2(10), “PLANT” VARCHAR2(30), “MAT_GRP” VARCHAR2(20), “MC_NO” VARCHAR2(18), “MC_DESC” VARCHAR2(40), “ITEM_QTY” NUMBER(16,3), “UNIT” VARCHAR2(4), “UNIT_PRICE” NUMBER(23,4), “TOTAL_AMOUT” NUMBER(23,4), “INFO_REC” VARCHAR2(20), “VEND_MAT” VARCHAR2(35), “TAX_CODE” VARCHAR2(2), “DELIV_COMPL_FLAG” VARCHAR2(3) DEFAULT ‘NO’, “DELIV_DATE” DATE, “ITEM_CAT” VARCHAR2(1), “PR_NO” VARCHAR2(10), “PR_ITEM” VARCHAR2(10), “ACCT_ASSCAT” VARCHAR2(1), “GR_FLAG” VARCHAR2(3) DEFAULT ‘NO’, “GR_BY” VARCHAR2(10), “DEL_FLAG” VARCHAR2(3) DEFAULT ‘NO’, “PO_REF_NO” VARCHAR2(10), “REMAIN_BALANCE_FLAG” VARCHAR2(3) DEFAULT ‘NO’, “SAP_UDATE” DATE, “FORECAST_DELIV_DATE” DATE, “RECEIVE_QTY” NUMBER(16,3) DEFAULT 0, “RECEIVE_PERCENT” NUMBER(10,4) DEFAULT 0, “EQ_SEQ_ID” VARCHAR2(10), “MANUFACTURER” VARCHAR2(60), “EQ_MAKER_PART_NO” VARCHAR2(30), “GL_ACCT” VARCHAR2(10), “TAX_FREE_ENG” VARCHAR2(92), “TAX_FREE_CHI” VARCHAR2(92), “DRAW_DOC” VARCHAR2(22), “DOC_VEND_MAT” VARCHAR2(60), “ORIGINAL_MC_NO” VARCHAR2(20), “PRICE_UNIT” NUMBER(*,0), “REQUISITIONER” VARCHAR2(20), “FINAL_INVOICE_FLAG” VARCHAR2(3) DEFAULT ‘NO’, “FREE_FLAG” VARCHAR2(3) DEFAULT ‘NO’, “IR_QTY” NUMBER(16,3), “IR_AMOUNT” NUMBER(16,3), “INVOICE_PLAN_FLAG” VARCHAR2(3) DEFAULT ‘NO’, “GR_NOVALUE_FLAG” VARCHAR2(3) DEFAULT ‘NO’, “UNLOAD_POINT” VARCHAR2(20), “ASSET_NO” VARCHAR2(50), “ASSET_SUBNO” VARCHAR2(20), “COST_CENTER” VARCHAR2(20), “COAREA” VARCHAR2(30), “COMMIT_ITEM” VARCHAR2(20), “FUND_YEAR” VARCHAR2(10), “FUND_CENTER” VARCHAR2(20), “CDATE” DATE, “UDATE” DATE, “SHIP_QTY” NUMBER(16,3) DEFAULT 0, “SHIP_AMOUNT” NUMBER(23,4) DEFAULT 0, “AUTO_ACTION” VARCHAR2(10), “REM_SHELF_LIFE” NUMBER(16,4), “RFQ_NO” VARCHAR2(10), “RFQ_ITEM” VARCHAR2(6), “INFOUPDATE_FLAG” VARCHAR2(3), “FACILITY_PO_STATUS” VARCHAR2(20), “TMP_DEL” VARCHAR2(3), PRIMARY KEY ("POITEM_ID") USING INDEX PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ENABLE, CONSTRAINT “FK_PO_DETL_POID” FOREIGN KEY (“PO_ID”) REFERENCES “XINSPADM”.“SP_PO_MAST” (“PO_ID”) ENABLE ) SEGMENT CREATION IMMEDIATE PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING STORAGE(INITIAL 65536 NEXT 8192 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; CREATE OR REPLACE TRIGGER “XINSPADM”.“TRI_SET_EQUIPMENTKEY3” BEFORE INSERT OR UPDATE ON XINSPADM.SP_PO_DETL FOR EACH ROW declare – local variables here equipmentID sp_po_detl.eq_seq_id%type; begin begin select eq_seq_id into equipmentID from ems_eq_id_view where eq_id=:new.eq_seq_id; :new.eq_seq_id := equipmentID; exception when no_data_found then null; end; end; / ALTER TRIGGER “XINSPADM”.“TRI_SET_EQUIPMENTKEY3” DISABLE; CREATE OR REPLACE TRIGGER “XINSPADM”.“TRI_SET_FORECASTDELIVYDATE2” BEFORE INSERT ON XINSPADM.SP_PO_DETL FOR EACH ROW begin :new.forecast_deliv_date:=:new.deliv_date; end; / ALTER TRIGGER “XINSPADM”.“TRI_SET_FORECASTDELIVYDATE2” ENABLE; CREATE INDEX “XINSPADM”.“INX_SP_PO_DETL_EQ_SEQ_ID” ON “XINSPADM”.“SP_PO_DETL” (“EQ_SEQ_ID”) PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; CREATE INDEX “XINSPADM”.“INX_SP_PO_DETL_ITEMCAT” ON “XINSPADM”.“SP_PO_DETL” (“ITEM_CAT”) PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; CREATE INDEX “XINSPADM”.“INX_SP_PO_DETL_POID” ON “XINSPADM”.“SP_PO_DETL” (“PO_ID”) PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; CREATE INDEX “XINSPADM”.“INX_SP_PO_DETL_POITEM” ON “XINSPADM”.“SP_PO_DETL” (“PO_NO”, “PO_ITEM”) PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; CREATE INDEX “XINSPADM”.“INX_SP_PO_DETL_PONO” ON “XINSPADM”.“SP_PO_DETL” (“PO_NO”) PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; CREATE INDEX “XINSPADM”.“INX_SP_PO_DETL_POREFNO” ON “XINSPADM”.“SP_PO_DETL” (“PO_REF_NO”) PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; CREATE INDEX “XINSPADM”.“INX_SP_PO_DETL_PRITEM” ON “XINSPADM”.“SP_PO_DETL” (“PR_NO”, “PR_ITEM”) PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; CREATE INDEX “XINSPADM”.“INX_SP_PO_DETL_PRNO” ON “XINSPADM”.“SP_PO_DETL” (“PR_NO”) PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; CREATE UNIQUE INDEX “XINSPADM”.“SYS_C0021337” ON “XINSPADM”.“SP_PO_DETL” (“POITEM_ID”) PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE “SUPPLY_DATA” ; GRANT SELECT ON “XINSPADM”.“SP_PO_DETL” TO “OEREAD”; GRANT SELECT ON “XINSPADM”.“SP_PO_DETL” TO “XINSPREAD”; 根据这两个表写一个接口文档 我需要po是主 SP_PO_DETL是子 然后只需要关键一点的信息 字段全一点
08-21
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值