VSAM - คู่มือฉบับย่อ

Virtual Storage Access Method (VSAM) เป็นวิธีการเข้าถึงที่มีประสิทธิภาพสูงและองค์กรชุดข้อมูลซึ่งจัดระเบียบและดูแลข้อมูลผ่านโครงสร้างแค็ตตาล็อก ใช้แนวคิดการจัดเก็บเสมือนและสามารถปกป้องชุดข้อมูลในระดับต่างๆโดยการให้รหัสผ่าน VSAM สามารถใช้ในโปรแกรม COBOL เช่นไฟล์ลำดับทางกายภาพ VSAM เป็นชุดข้อมูลเชิงตรรกะสำหรับจัดเก็บบันทึก ไฟล์สามารถอ่านตามลำดับและสุ่มใน VSAM เป็นวิธีการจัดเก็บข้อมูลที่ได้รับการปรับปรุงซึ่งเอาชนะข้อ จำกัด บางประการของระบบไฟล์แบบเดิมเช่นไฟล์ลำดับ

ลักษณะของ VSAM

ต่อไปนี้เป็นลักษณะของ VSAM -

  • VSAM ปกป้องข้อมูลจากการเข้าถึงโดยไม่ได้รับอนุญาตโดยใช้รหัสผ่าน

  • VSAM ให้การเข้าถึงชุดข้อมูลที่รวดเร็ว

  • VSAM มีตัวเลือกสำหรับการเพิ่มประสิทธิภาพ

  • VSAM อนุญาตให้แชร์ชุดข้อมูลได้ทั้งในสภาพแวดล้อมแบบแบตช์และออนไลน์

  • VSAM มีโครงสร้างและจัดระเบียบมากขึ้นในการจัดเก็บข้อมูล

  • พื้นที่ว่างจะถูกใช้ซ้ำโดยอัตโนมัติในไฟล์ VSAM

ข้อ จำกัด ของ VSAM

ข้อ จำกัด เพียงประการเดียวของ VSAM คือไม่สามารถจัดเก็บไว้ในโวลุ่ม TAPE จะถูกเก็บไว้ในพื้นที่ DASD เสมอ ต้องใช้กระบอกสูบจำนวนมากในการจัดเก็บข้อมูลซึ่งไม่คุ้มทุน

VSAM ประกอบด้วยส่วนประกอบต่อไปนี้ -

  • VSAM คลัสเตอร์
  • พื้นที่ควบคุม
  • ช่วงควบคุม

VSAM คลัสเตอร์

VSAM เป็นชุดข้อมูลเชิงตรรกะสำหรับจัดเก็บเร็กคอร์ดและเรียกว่าคลัสเตอร์ คลัสเตอร์คือการเชื่อมโยงของดัชนีชุดลำดับและส่วนข้อมูลของชุดข้อมูล พื้นที่ที่ครอบครองโดยคลัสเตอร์ VSAM จะถูกแบ่งในพื้นที่ที่อยู่ติดกันเรียกว่า Control Intervals เราจะพูดถึงช่วงเวลาการควบคุมในโมดูลนี้ในภายหลัง

มีสององค์ประกอบหลักในคลัสเตอร์ VSAM -

  • Index Componentมีส่วนดัชนี ระเบียนดัชนีมีอยู่ในองค์ประกอบดัชนี การใช้ส่วนประกอบดัชนี VSAM สามารถดึงข้อมูลจากส่วนประกอบข้อมูลได้

  • Data Componentมีส่วนข้อมูล บันทึกข้อมูลจริงมีอยู่ในองค์ประกอบข้อมูล

ช่วงควบคุม

Control Intervals (CI) ใน VSAM เทียบเท่ากับบล็อกสำหรับชุดข้อมูลที่ไม่ใช่ VSAM ในวิธีที่ไม่ใช่ VSAM หน่วยของข้อมูลจะถูกกำหนดโดยบล็อก VSAM ทำงานกับพื้นที่ข้อมูลลอจิคัลซึ่งเรียกว่า Control Intervals

Control Intervals เป็นหน่วยที่เล็กที่สุดในการถ่ายโอนระหว่างดิสก์และระบบปฏิบัติการ เมื่อใดก็ตามที่ดึงข้อมูลจากหน่วยเก็บข้อมูลโดยตรง CI ทั้งหมดที่มีเรกคอร์ดจะถูกอ่านลงในบัฟเฟอร์อินพุต - เอาท์พุต VSAM จากนั้นบันทึกที่ต้องการจะถูกโอนไปยังพื้นที่ทำงานจากบัฟเฟอร์ VSAM

Control Interval ประกอบด้วย -

  • บันทึกตรรกะ
  • ฟิลด์ข้อมูลควบคุม
  • ที่ว่าง

เมื่อโหลดชุดข้อมูล VSAM จะมีการสร้างช่วงเวลาควบคุม ขนาดช่วงควบคุมเริ่มต้นคือ 4K ไบต์และสามารถขยายได้ถึง 32K ไบต์

การวิเคราะห์ช่วงเวลาควบคุม

ต่อไปนี้เป็นคำอธิบายคำศัพท์ที่ใช้ในโปรแกรมข้างต้น -

  • R1..R5 - บันทึกที่เก็บไว้ใน Control Interval

  • FS - FS เป็นพื้นที่ว่างซึ่งสามารถใช้เพื่อขยายชุดข้อมูลเพิ่มเติมได้

  • RDF- RDF เรียกว่า Record Definition Fields RDF มีความยาว 3 ไบต์ อธิบายความยาวของระเบียนและบอกจำนวนระเบียนที่อยู่ติดกันที่มีความยาวเท่ากัน

  • CIDF- CIDF เรียกว่าฟิลด์นิยามช่วงเวลาควบคุม CIDF มีความยาว 4 ไบต์และมีข้อมูลเกี่ยวกับ Control Interval

พื้นที่ควบคุม

พื้นที่ควบคุม (CA) เกิดขึ้นจากการรวมช่วงเวลาควบคุมสองช่วงขึ้นไป ชุดข้อมูล VSAM ประกอบด้วยพื้นที่ควบคุมอย่างน้อยหนึ่งพื้นที่ ขนาดของ VSAM เป็นพื้นที่ควบคุมหลายเท่าเสมอ ไฟล์ VSAM ถูกขยายในหน่วยของพื้นที่ควบคุม

ต่อไปนี้เป็นตัวอย่างของพื้นที่ควบคุม -

คลัสเตอร์ VSAM ถูกกำหนดใน JCL. JCL ใช้IDCAMSยูทิลิตี้เพื่อสร้างคลัสเตอร์ IDCAMS เป็นยูทิลิตี้ที่พัฒนาโดย IBM สำหรับบริการวิธีการเข้าถึง ใช้เพื่อกำหนดชุดข้อมูล VSAM เป็นหลัก

การกำหนดคลัสเตอร์

ไวยากรณ์ต่อไปนี้แสดงพารามิเตอร์หลักซึ่งจัดกลุ่มไว้ภายใต้ Define Cluster, Data และ Index.

.DEFINE CLUSTER (NAME(vsam-file-name)      -
BLOCKS(number)                             -
VOLUMES(volume-serial)                     -
[INDEXED / NONINDEXED / NUMBERED / LINEAR] -
RECSZ(average maximum)                     -
[FREESPACE(CI-Percentage,CA-Percentage)]   -
CISZ(number)                               -
[KEYS(length offset)]                      -
[READPW(password)]                         -
[FOR(days)|TO(date)]                       -
[UPDATEPW(password)]                       -
[REUSE / NOREUSE] )                        -
DATA                                       -
   (NAME(vsam-file-name.data))             -
INDEX                                      -
   (NAME(vsam-file-name.index))            -
CATALOG(catalog-name[/password]))

พารามิเตอร์ที่ระดับ CLUSTER ใช้กับคลัสเตอร์ทั้งหมด พารามิเตอร์ที่ระดับ DATA หรือ INDEX ใช้กับส่วนประกอบข้อมูลหรือดัชนีเท่านั้น

เราจะพูดถึงพารามิเตอร์แต่ละตัวโดยละเอียดในตารางต่อไปนี้ -

ซีเนียร์ No พารามิเตอร์พร้อมคำอธิบาย
1

DEFINE CLUSTER

คำสั่ง Define Cluster ใช้เพื่อกำหนดคลัสเตอร์และระบุแอ็ตทริบิวต์พารามิเตอร์สำหรับคลัสเตอร์และคอมโพเนนต์

2

NAME

NAME ระบุชื่อของไฟล์ VSAM ซึ่งเรากำลังกำหนดคลัสเตอร์

3

BLOCKS

บล็อกระบุจำนวนบล็อกที่กำหนดสำหรับคลัสเตอร์

4

VOLUMES

ไดรฟ์ข้อมูลระบุไดรฟ์ข้อมูลอย่างน้อยหนึ่งไดรฟ์ที่จะมีคลัสเตอร์หรือส่วนประกอบ

5

INDEXED / NONINDEXED / NUMBERED / LINEAR

พารามิเตอร์นี้สามารถรับค่าได้สามค่า INDEXED, NONINDEXED หรือ NUMBERED ขึ้นอยู่กับประเภทของชุดข้อมูลที่เรากำลังสร้าง สำหรับไฟล์ลำดับคีย์ (KSDS) ใช้ตัวเลือก INDEXED สำหรับไฟล์ลำดับรายการ (ESDS) จะใช้ตัวเลือก NONINDEXED สำหรับไฟล์ญาติบันทึก (RRDS) จำเป็นต้องมีตัวเลือก NUMBERED สำหรับไฟล์ Linear (LDS) จำเป็นต้องมีตัวเลือก LINEAR ค่าเริ่มต้นของพารามิเตอร์นี้คือ INDEXED เราจะพูดคุยเพิ่มเติมเกี่ยวกับ KSDS, ESDS, RRDS และ LDS ในโมดูลที่กำลังจะมาถึง

6

RECSZ

พารามิเตอร์ Record Size มีสองค่าคือ Average และ Maximum record size ค่าเฉลี่ยระบุความยาวเฉลี่ยของเร็กคอร์ดโลจิคัลในไฟล์และค่าสูงสุดหมายถึงความยาวของเร็กคอร์ด

7

FREESPACE

Freespace ระบุเปอร์เซ็นต์ของพื้นที่ว่างที่จะสำรองสำหรับช่วงเวลาควบคุม (CI) และพื้นที่ควบคุม (CA) ของส่วนประกอบข้อมูล ค่าเริ่มต้นของพารามิเตอร์นี้คือศูนย์เปอร์เซ็นต์

8

CISZ

CISZ เรียกว่าขนาดช่วงควบคุม ระบุขนาดของช่วงเวลาควบคุม

9

KEYS

พารามิเตอร์คีย์ถูกกำหนดในไฟล์ลำดับคีย์ (KSDS) เท่านั้น ระบุความยาวและออฟเซ็ตของคีย์หลักจากคอลัมน์แรก ช่วงของค่าของพารามิเตอร์นี้อยู่ระหว่าง 1 ถึง 255 ไบต์

10

READPW

ค่าในพารามิเตอร์ READPW ระบุรหัสผ่านของระดับการอ่าน

11

FOR/TO

ค่าของพารามิเตอร์นี้ระบุระยะเวลาในรูปแบบของวันที่และวันสำหรับการเก็บรักษาไฟล์ ค่าเริ่มต้นสำหรับพารามิเตอร์นี้คือศูนย์วัน

12

UPDATEPW

ค่าในพารามิเตอร์ UPDATEPW ระบุรหัสผ่านของระดับการอัพเดต

13

REUSE / NOREUSE

พารามิเตอร์ REUSE อนุญาตให้กำหนดคลัสเตอร์ที่อาจถูกรีเซ็ตเป็นสถานะว่างโดยไม่ต้องลบและกำหนดใหม่

14

DATA - NAME

ส่วน DATA ของคลัสเตอร์ประกอบด้วยชื่อชุดข้อมูลซึ่งมีข้อมูลจริงของไฟล์

15

INDEX-NAME

ส่วน INDEX ของคลัสเตอร์ประกอบด้วยคีย์หลักและตัวชี้หน่วยความจำสำหรับบันทึกที่เกี่ยวข้องในส่วนข้อมูล ถูกกำหนดเมื่อใช้คลัสเตอร์ลำดับคีย์

16

CATALOG

พารามิเตอร์แค็ตตาล็อกหมายถึงแค็ตตาล็อกที่ไฟล์จะถูกกำหนด เราจะพูดคุยเกี่ยวกับแคตตาล็อกแยกกันในโมดูลที่กำลังจะมาถึง

ตัวอย่าง

ต่อไปนี้เป็นตัวอย่างพื้นฐานเพื่อแสดงวิธีกำหนดคลัสเตอร์ใน JCL -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1  EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN    DD  *
   DEFINE CLUSTER (NAME(MY.VSAM.KSDSFILE)  -
   INDEXED                                 -
   RECSZ(80 80)                            -
   TRACKS(1,1)                             -
   KEYS(5  0)                              -
   CISZ(4096)                              -                            
   FREESPACE(3 3) )                        -
   DATA (NAME(MY.VSAM.KSDSFILE.DATA))      -
   INDEX (NAME(MY.VSAM.KSDSFILE.INDEX))
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรรันด้วย MAXCC = 0 และจะสร้างไฟล์ MY.VSAM.KSDSFILE VSAM

การลบคลัสเตอร์

ในการลบไฟล์ VSAM คลัสเตอร์ VSAM จะต้องถูกลบโดยใช้ยูทิลิตี้ IDCAMS คำสั่ง DELETE จะลบรายการของคลัสเตอร์ VSAM ออกจากแค็ตตาล็อกและเป็นทางเลือกที่จะลบไฟล์ซึ่งจะช่วยเพิ่มพื้นที่ว่างที่อ็อบเจ็กต์ครอบครอง หากชุดข้อมูล VSAM ยังไม่หมดอายุชุดข้อมูลนั้นจะไม่ถูกลบ หากต้องการลบชุดข้อมูลประเภทดังกล่าวให้ใช้ตัวเลือก PURGE

DELETE data-set-name CLUSTER  
[ERASE / NOERASE] 
[FORCE / NOFORCE] 
[PURGE / NOPURGE] 
[SCRATCH / NOSCRATCH]

ไวยากรณ์ด้านบนแสดงพารามิเตอร์ที่เราสามารถใช้กับคำสั่ง Delete เราจะพูดคุยกันโดยละเอียดในตารางต่อไปนี้ -

ซีเนียร์ No พารามิเตอร์พร้อมคำอธิบาย
1

ERASE / NOERASE

ระบุอ็อพชัน ERASE เพื่อแทนที่แอ็ตทริบิวต์ ERASE ที่ระบุสำหรับอ็อบเจ็กต์ในแค็ตตาล็อก ตัวเลือก NOERASE ถูกใช้โดยค่าเริ่มต้น

2

FORCE / NOFORCE

ระบุตัวเลือก FORCE เพื่อลบ SPACE และ USERCATALOG แม้ว่าจะไม่ว่างเปล่าก็ตาม ตัวเลือก NOFORCE ถูกใช้โดยค่าเริ่มต้น

3

PURGE / NOPURGE

ตัวเลือก PURGE ใช้เพื่อลบชุดข้อมูล VSAM หากชุดข้อมูลยังไม่หมดอายุ ตัวเลือก NOPURGE ถูกใช้โดยค่าเริ่มต้น

4

SCRATCH / NOSCRATCH

ระบุอ็อพชัน SCRATCH เพื่อลบรายการที่เกี่ยวข้องสำหรับอ็อบเจ็กต์ออกจาก Volume Table of Contents ส่วนใหญ่จะใช้สำหรับชุดข้อมูลที่ไม่ใช่ vsam เช่น GDG ตัวเลือก NOSCRATCH ถูกใช้โดยค่าเริ่มต้น

ตัวอย่าง

ต่อไปนี้เป็นตัวอย่างพื้นฐานเพื่อแสดงวิธีการลบคลัสเตอร์ใน JCL -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEPNAME EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN    DD  *
   DELETE MY.VSAM.KSDSFILE CLUSTER
	PURGE
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรรันด้วย MAXCC = 0 และจะลบไฟล์ MY.VSAM.KSDSFILE VSAM

ESDS เรียกว่าชุดข้อมูลตามลำดับรายการ ชุดข้อมูลที่เรียงตามลำดับรายการทำงานเหมือนการจัดระเบียบไฟล์ตามลำดับที่มีคุณลักษณะเพิ่มเติมบางอย่างรวมอยู่ด้วย เราสามารถเข้าถึงบันทึกได้โดยตรงและเพื่อความปลอดภัยเราสามารถใช้รหัสผ่านได้เช่นกัน เราต้องเขียนโค้ดNONINDEXEDภายในคำสั่ง DEFINE CLUSTER สำหรับชุดข้อมูล ESDS ต่อไปนี้เป็นคุณสมบัติหลักของ ESDS -

  • ระเบียนในคลัสเตอร์ ESDS จะถูกจัดเก็บตามลำดับที่แทรกลงในชุดข้อมูล

  • เร็กคอร์ดอ้างอิงโดยที่อยู่จริงซึ่งเรียกว่า Relative Byte Address (RBA). สมมติว่าถ้าในชุดข้อมูล ESDS เรามีระเบียน 80 ไบต์ RBA ของระเบียนแรกจะเป็น 0 RBA สำหรับระเบียนที่สองจะเท่ากับ 80 สำหรับระเบียนที่สามจะเป็น 160 เป็นต้นไป

  • สามารถเข้าถึงบันทึกตามลำดับโดย RBA ซึ่งเรียกว่า addressed access.

  • บันทึกจะจัดเรียงตามลำดับที่แทรก บันทึกใหม่จะถูกแทรกในตอนท้าย

  • ไม่สามารถลบบันทึกได้ในชุดข้อมูล ESDS แต่สามารถทำเครื่องหมายว่าไม่ใช้งานได้

  • บันทึกในชุดข้อมูล ESDS อาจมีความยาวคงที่หรือความยาวผันแปรได้

  • ESDS ไม่ถูกจัดทำดัชนี คีย์ไม่มีอยู่ในชุดข้อมูล ESDS ดังนั้นจึงอาจมีระเบียนที่ซ้ำกัน

  • ESDS สามารถใช้ในโปรแกรม COBOL ได้เช่นเดียวกับไฟล์อื่น ๆ เราจะระบุชื่อไฟล์ใน JCL และเราสามารถใช้ไฟล์ ESDS สำหรับการประมวลผลภายในโปรแกรม ในโปรแกรม COBOL ระบุการจัดระเบียบไฟล์เป็นSequential และโหมดการเข้าถึงเป็น Sequential ด้วยชุดข้อมูล ESDS

การกำหนดคลัสเตอร์ ESDS

ไวยากรณ์ต่อไปนี้แสดงพารามิเตอร์ที่เราสามารถใช้ได้ในขณะสร้างคลัสเตอร์ ESDS คำอธิบายพารามิเตอร์ยังคงเหมือนเดิมตามที่กล่าวไว้ใน VSAM - โมดูลคลัสเตอร์

DEFINE CLUSTER (NAME(esds-file-name)     -
BLOCKS(number)                           -
VOLUMES(volume-serial)                   -
NONINDEXED                               -
RECSZ(average maximum)                   -
[FREESPACE(CI-Percentage,CA-Percentage)] -
CISZ(number)                             -
[READPW(password)]                       -
[FOR(days)|TO(date)]                     -
[UPDATEPW(password)]                     -
[REUSE / NOREUSE])                       -
DATA                                     -
   (NAME(esds-file-name.data))

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงวิธีสร้างคลัสเตอร์ ESDS ใน JCL โดยใช้ยูทิลิตี้ IDCAMS -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1  EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN    DD  *
   DEFINE CLUSTER (NAME(MY.VSAM.ESDSFILE)  -
   NONINDEXED                              -
   RECSZ(80 80)                            -
   TRACKS(1,1)                             -
   CISZ(4096)                              -                            
   FREESPACE(3 3) )                        -
   DATA (NAME(MY.VSAM.ESDSFILE.DATA))      
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรรันด้วย MAXCC = 0 และจะสร้างไฟล์ MY.VSAM.ESDSFILE VSAM

การลบ ESDS Cluster

คลัสเตอร์ ESDS ถูกลบโดยใช้ยูทิลิตี้ IDCAMS คำสั่ง DELETE จะลบรายการของคลัสเตอร์ VSAM ออกจากแค็ตตาล็อกและเป็นทางเลือกที่จะลบไฟล์ซึ่งจะช่วยเพิ่มพื้นที่ว่างที่อ็อบเจ็กต์ครอบครอง

DELETE data-set-name CLUSTER  
[ERASE / NOERASE] 
[FORCE / NOFORCE] 
[PURGE / NOPURGE] 
[SCRATCH / NOSCRATCH]

ไวยากรณ์ด้านบนแสดงพารามิเตอร์ที่เราสามารถใช้ได้ขณะลบคลัสเตอร์ ESDS คำอธิบายพารามิเตอร์ยังคงเหมือนเดิมตามที่กล่าวไว้ใน VSAM - โมดูลคลัสเตอร์

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงวิธีการลบคลัสเตอร์ ESDS ใน JCL โดยใช้ยูทิลิตี้ IDCAMS -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEPNAME EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN    DD  *
   DELETE MY.VSAM.ESDSFILE CLUSTER
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรรันด้วย MAXCC = 0 และจะลบ MY.VSAM.ESDSFILE VSAM Cluster

KSDS เรียกว่าชุดข้อมูลตามลำดับคีย์ ชุดข้อมูลตามลำดับคีย์ (KSDS) มีความซับซ้อนมากกว่า ESDS และ RRDS แต่มีประโยชน์และหลากหลายกว่า เราต้องเขียนโค้ดINDEXEDภายในคำสั่ง DEFINE CLUSTER สำหรับชุดข้อมูล KSDS คลัสเตอร์ KSDS ประกอบด้วยสององค์ประกอบต่อไปนี้ -

  • Index- ส่วนประกอบดัชนีของคลัสเตอร์ KSDS ประกอบด้วยรายการของค่าคีย์สำหรับระเบียนในคลัสเตอร์พร้อมด้วยตัวชี้ไปยังระเบียนที่เกี่ยวข้องในส่วนประกอบข้อมูล ส่วนประกอบดัชนีหมายถึงที่อยู่จริงของระเบียน KSDS สิ่งนี้เกี่ยวข้องกับคีย์ของแต่ละเร็กคอร์ดกับตำแหน่งสัมพัทธ์ของเรกคอร์ดในชุดข้อมูล เมื่อมีการเพิ่มหรือลบระเบียนดัชนีนี้จะได้รับการอัปเดตตามนั้น

  • Data- ส่วนประกอบข้อมูลของคลัสเตอร์ KSDS ประกอบด้วยข้อมูลจริง แต่ละเร็กคอร์ดในส่วนประกอบข้อมูลของคลัสเตอร์ KSDS ประกอบด้วยฟิลด์คีย์ที่มีจำนวนอักขระเท่ากันและเกิดขึ้นในตำแหน่งสัมพัทธ์เดียวกันในแต่ละเร็กคอร์ด

ต่อไปนี้เป็นคุณสมบัติหลักของ KSDS -

  • บันทึกภายในชุดข้อมูล KSDS จะถูกจัดเรียงตามคีย์ฟิลด์เสมอ บันทึกจะถูกจัดเก็บจากน้อยไปหามากเรียงลำดับตามคีย์

  • บันทึกสามารถเข้าถึงได้ตามลำดับและยังสามารถเข้าถึงได้โดยตรง

  • บันทึกถูกระบุโดยใช้คีย์ คีย์ของแต่ละเรกคอร์ดคือฟิลด์ในตำแหน่งที่กำหนดไว้ล่วงหน้าภายในเรกคอร์ด แต่ละคีย์ต้องไม่ซ้ำกันในชุดข้อมูล KSDS ดังนั้นจึงไม่สามารถทำซ้ำบันทึกได้

  • เมื่อใส่เร็กคอร์ดใหม่ลำดับตรรกะของเร็กคอร์ดจะขึ้นอยู่กับลำดับการเรียงของฟิลด์คีย์

  • บันทึกในชุดข้อมูล KSDS อาจมีความยาวคงที่หรือความยาวผันแปรได้

  • KSDS สามารถใช้ในรูปแบบ COBOLโปรแกรมเช่นเดียวกับไฟล์อื่น ๆ เราจะระบุชื่อไฟล์ใน JCL และเราสามารถใช้ไฟล์ KSDS สำหรับการประมวลผลภายในโปรแกรม ในโปรแกรม COBOL ระบุการจัดระเบียบไฟล์เป็นIndexed และคุณสามารถใช้โหมดการเข้าถึงใดก็ได้ (Sequential, Random or Dynamic) ด้วยชุดข้อมูล KSDS

โครงสร้างไฟล์ KSDS

ในการค้นหาระเบียนเฉพาะเราจะให้ค่าคีย์ที่ไม่ซ้ำกัน ค่าคีย์ถูกค้นหาในองค์ประกอบดัชนี เมื่อพบคีย์แล้วที่อยู่หน่วยความจำที่เกี่ยวข้องซึ่งอ้างถึงส่วนประกอบข้อมูลจะถูกดึงออกมา จากที่อยู่หน่วยความจำเราสามารถดึงข้อมูลจริงซึ่งเก็บไว้ในส่วนประกอบข้อมูล ตัวอย่างต่อไปนี้แสดงโครงสร้างพื้นฐานของดัชนีและไฟล์ข้อมูล -

การกำหนด KSDS Cluster

ไวยากรณ์ต่อไปนี้แสดงพารามิเตอร์ที่เราสามารถใช้ได้ในขณะสร้างคลัสเตอร์ KSDS

คำอธิบายพารามิเตอร์ยังคงเหมือนเดิมตามที่กล่าวไว้ใน VSAM - โมดูลคลัสเตอร์

DEFINE CLUSTER (NAME(ksds-file-name)     -
BLOCKS(number)                           -
VOLUMES(volume-serial)                   -
INDEXED                                  -
KEYS(length offset)                      -
RECSZ(average maximum)                   -
[FREESPACE(CI-Percentage,CA-Percentage)] -
CISZ(number)                             -
[READPW(password)]                       -
[FOR(days)|TO(date)]                     -
[UPDATEPW(password)]                     -
[REUSE / NOREUSE])                       -
DATA                                     -
   (NAME(ksds-file-name.data))           -
INDEX                                    -
   (NAME(ksds-file-name.index))

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงวิธีสร้างคลัสเตอร์ KSDS ใน JCL โดยใช้ยูทิลิตี้ IDCAMS -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1  EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN    DD  *
   DEFINE CLUSTER (NAME(MY.VSAM.KSDSFILE)  -
   INDEXED                                 -
   KEYS(6 1)	                           -	
   RECSZ(80 80)                            -
   TRACKS(1,1)                             -
   CISZ(4096)                              -                            
   FREESPACE(3 3) )                        -
   DATA (NAME(MY.VSAM.KSDSFILE.DATA))      -
   INDEX (NAME(MY.VSAM.KSDSFILE.INDEX))    -
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรรันด้วย MAXCC = 0 และจะสร้างไฟล์ MY.VSAM.KSDSFILE VSAM

การลบ KSDS Cluster

คลัสเตอร์ KSDS ถูกลบโดยใช้ยูทิลิตี้ IDCAMS คำสั่ง DELETE จะลบรายการของคลัสเตอร์ VSAM ออกจากแค็ตตาล็อกและเป็นทางเลือกที่จะลบไฟล์ซึ่งจะช่วยเพิ่มพื้นที่ว่างที่อ็อบเจ็กต์ครอบครอง

DELETE data-set-name CLUSTER  
[ERASE / NOERASE] 
[FORCE / NOFORCE] 
[PURGE / NOPURGE] 
[SCRATCH / NOSCRATCH]

ไวยากรณ์ด้านบนแสดงพารามิเตอร์ที่เราสามารถใช้ได้ในขณะที่ลบคลัสเตอร์ KSDS คำอธิบายพารามิเตอร์ยังคงเหมือนเดิมตามที่กล่าวไว้ใน VSAM - โมดูลคลัสเตอร์

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงวิธีการลบคลัสเตอร์ KSDS ใน JCL โดยใช้ยูทิลิตี้ IDCAMS -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEPNAME EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN    DD  *
   DELETE MY.VSAM.KSDSFILE CLUSTER
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรรันด้วย MAXCC = 0 และจะลบ MY.VSAM.KSDSFILE VSAM Cluster

RRDS เรียกว่าชุดข้อมูลบันทึกสัมพัทธ์ คลัสเตอร์ RRDS คล้ายกับคลัสเตอร์ ESDS ข้อแตกต่างเพียงอย่างเดียวคือการเข้าถึงระเบียน RRDS โดยRelative Record Number (RRN)เราต้องเขียนโค้ด NUMBEREDภายในคำสั่ง DEFINE CLUSTER ต่อไปนี้เป็นคุณสมบัติหลักของ RRDS -

  • ชุดข้อมูลเรกคอร์ดสัมพัทธ์มีเรกคอร์ดที่ระบุโดย Relative Record Number (RRN)ซึ่งเป็นหมายเลขลำดับที่สัมพันธ์กับระเบียนแรก

  • RRDS ช่วยให้สามารถเข้าถึงบันทึกตามหมายเลขเช่นบันทึก 1 บันทึก 2 และอื่น ๆ สิ่งนี้ให้การเข้าถึงโดยสุ่มและถือว่าโปรแกรมแอปพลิเคชันมีวิธีรับหมายเลขบันทึกที่ต้องการ

  • เรกคอร์ดในชุดข้อมูล RRDS สามารถเข้าถึงได้ตามลำดับตามลำดับหมายเลขเรกคอร์ดสัมพัทธ์หรือโดยตรงโดยการจัดหาหมายเลขเรกคอร์ดสัมพัทธ์ของเรกคอร์ดที่ต้องการ

  • ระเบียนในชุดข้อมูล RRDS จะถูกเก็บไว้ในช่องความยาวคงที่ แต่ละเร็กคอร์ดอ้างอิงตามจำนวนสล็อตจำนวนอาจแตกต่างกันไปตั้งแต่ 1 ถึงจำนวนสูงสุดของเร็กคอร์ดในชุดข้อมูล

  • บันทึกใน RRDS สามารถเขียนได้โดยการใส่ระเบียนใหม่ลงในช่องว่าง

  • สามารถลบบันทึกจากคลัสเตอร์ RRDS ได้ดังนั้นจึงปล่อยให้ช่องว่าง

  • แอปพลิเคชันที่ใช้ระเบียนที่มีความยาวคงที่หรือหมายเลขระเบียนที่มีความหมายตามบริบทซึ่งสามารถใช้ชุดข้อมูล RRDS ได้

  • สามารถใช้ RRDS ในรูปแบบ COBOLโปรแกรมเช่นเดียวกับไฟล์อื่น ๆ เราจะระบุชื่อไฟล์ใน JCL และเราสามารถใช้ไฟล์ KSDS สำหรับการประมวลผลภายในโปรแกรม ในโปรแกรม COBOL ระบุการจัดระเบียบไฟล์เป็นRELATIVE และคุณสามารถใช้โหมดการเข้าถึงใดก็ได้ (Sequential, Random or Dynamic) ด้วยชุดข้อมูล RRDS

โครงสร้างไฟล์ RRDS

ช่องว่างแบ่งออกเป็นช่องความยาวคงที่ในโครงสร้างไฟล์ RRDS ช่องอาจว่างหรือเต็มก็ได้ ดังนั้นสามารถเพิ่มระเบียนใหม่ลงในช่องว่างและสามารถลบบันทึกที่มีอยู่ออกจากช่องที่เติมได้ เราสามารถเข้าถึงบันทึกใด ๆ ได้โดยตรงโดยการให้ Relative Record Number ตัวอย่างต่อไปนี้แสดงโครงสร้างพื้นฐานของไฟล์ข้อมูล -

ส่วนประกอบข้อมูล

หมายเลขบันทึกญาติ ฟิลด์บันทึก 1 ฟิลด์บันทึก 2
1 บทช่วยสอน จุด
2 Mohtashim ม.
3 ณิชนันท์ มาลิก

การกำหนด RRDS Cluster

ไวยากรณ์ต่อไปนี้แสดงพารามิเตอร์ที่เราสามารถใช้ได้ในขณะสร้างคลัสเตอร์ RRDS

คำอธิบายพารามิเตอร์ยังคงเหมือนเดิมตามที่กล่าวไว้ใน VSAM - โมดูลคลัสเตอร์

DEFINE CLUSTER (NAME(rrds-file-name)     -
BLOCKS(number)                           -
VOLUMES(volume-serial)                   -
NUMBERED                                 -
RECSZ(average maximum)                   -
[FREESPACE(CI-Percentage,CA-Percentage)] -
CISZ(number)                             -
[READPW(password)]                       -
[FOR(days)|TO(date)]                     -
[UPDATEPW(password)]                     -
[REUSE / NOREUSE])                       -
DATA                                     -
   (NAME(rrds-file-name.data))

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงวิธีสร้างคลัสเตอร์ RRDS ใน JCL โดยใช้ยูทิลิตี้ IDCAMS -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1  EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN    DD  *
   DEFINE CLUSTER (NAME(MY.VSAM.RRDSFILE)  -
   NUMBERED                                -
   RECSZ(80 80)                            -
   TRACKS(1,1)                             -
   REUSE                                   - 
   FREESPACE(3 3) )                        -
   DATA (NAME(MY.VSAM.RRDSFILE.DATA))      
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรรันด้วย MAXCC = 0 และจะสร้างไฟล์ MY.VSAM.RRDSFILE VSAM

กำลังลบ RRDS Cluster

คลัสเตอร์ RRDS ถูกลบโดยใช้ยูทิลิตี้ IDCAMS คำสั่ง DELETE จะลบรายการของคลัสเตอร์ VSAM ออกจากแค็ตตาล็อกและเป็นทางเลือกที่จะลบไฟล์ซึ่งจะช่วยเพิ่มพื้นที่ว่างที่อ็อบเจ็กต์ครอบครอง

DELETE data-set-name CLUSTER  
[ERASE / NOERASE] 
[FORCE / NOFORCE] 
[PURGE / NOPURGE] 
[SCRATCH / NOSCRATCH]

ไวยากรณ์ด้านบนแสดงพารามิเตอร์ที่เราสามารถใช้ได้ขณะลบคลัสเตอร์ RRDS คำอธิบายพารามิเตอร์ยังคงเหมือนเดิมตามที่กล่าวไว้ใน VSAM - โมดูลคลัสเตอร์

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงวิธีการลบคลัสเตอร์ RRDS ใน JCL โดยใช้ยูทิลิตี้ IDCAMS -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEPNAME EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN    DD  *
   DELETE MY.VSAM.RRDSFILE CLUSTER
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรรันด้วย MAXCC = 0 และจะลบ MY.VSAM.RRDSFILE VSAM Cluster

LDS เรียกว่าชุดข้อมูลเชิงเส้น Linear dataset เป็นชุดข้อมูลไบต์สตรีมรูปแบบเดียวที่ใช้ในไฟล์ระบบปฏิบัติการแบบเดิม แทบไม่ได้ใช้ชุดข้อมูลเชิงเส้น ต่อไปนี้เป็นคุณสมบัติหลักของ LDS -

  • ชุดข้อมูลเชิงเส้นไม่มี RDF และ CIDF เนื่องจากไม่มีข้อมูลควบคุมใด ๆ ที่ฝังอยู่ใน CI

  • ข้อมูลที่สามารถเข้าถึงได้ในรูปแบบไบต์แอดเดรสสตริงในที่จัดเก็บเสมือนในชุดข้อมูลเชิงเส้น

  • ชุดข้อมูลเชิงเส้นมีขนาดช่วงควบคุม 4KBytes

  • LDS เป็นไฟล์ที่ไม่ใช่ VSAM ที่มีสิ่งอำนวยความสะดวก VSAM บางอย่างเช่นการใช้ IDCAMS และข้อมูลเฉพาะ VSAM ในแคตตาล็อก

  • ปัจจุบัน DB2 เป็นผู้ใช้ชุดข้อมูลเชิงเส้นรายใหญ่ที่สุด

  • IDCAMS ใช้เพื่อกำหนด LDS แต่เข้าถึงได้โดยใช้มาโคร Data-In-Virtual (DIV)

  • ชุดข้อมูลเชิงเส้นไม่มีแนวคิดเกี่ยวกับระเบียน ไบต์ LDS ทั้งหมดเป็นไบต์ข้อมูล

การกำหนดคลัสเตอร์ LDS

ไวยากรณ์ต่อไปนี้แสดงพารามิเตอร์ที่เราสามารถใช้ได้ในขณะสร้างคลัสเตอร์ LDS คำอธิบายพารามิเตอร์ยังคงเหมือนเดิมตามที่กล่าวไว้ใน VSAM - โมดูลคลัสเตอร์

DEFINE CLUSTER (NAME(lds-file-name)      -
BLOCKS(number)                           -
VOLUMES(volume-serial)                   -
LINEAR                                   -
CISZ(number)                             -
[READPW(password)]                       -
[FOR(days)|TO(date)]                     -
[UPDATEPW(password)]                     -
[REUSE / NOREUSE])                       -
DATA                                     -
   (NAME(lds-file-name.data))

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงวิธีสร้างคลัสเตอร์ LDS ใน JCL โดยใช้ยูทิลิตี้ IDCAMS -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1  EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN    DD  *
   DEFINE CLUSTER (NAME(MY.VSAM.LDSFILE)   -
   LINEAR                                  -
   TRACKS(1,1)                             -
   CISZ(4096) )                            -                            
   DATA (NAME(MY.VSAM.LDSFILE.DATA))      
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรรันด้วย MAXCC = 0 และจะสร้างไฟล์ MY.VSAM.LDSFILE VSAM

การลบ LDS Cluster

คลัสเตอร์ LDS ถูกลบโดยใช้ยูทิลิตี้ IDCAMS คำสั่ง DELETE จะลบรายการของคลัสเตอร์ VSAM ออกจากแค็ตตาล็อกและเป็นทางเลือกที่จะลบไฟล์ซึ่งจะช่วยเพิ่มพื้นที่ว่างที่อ็อบเจ็กต์ครอบครอง

DELETE data-set-name CLUSTER  
[ERASE / NOERASE] 
[FORCE / NOFORCE] 
[PURGE / NOPURGE] 
[SCRATCH / NOSCRATCH]

ไวยากรณ์ด้านบนแสดงพารามิเตอร์ที่เราสามารถใช้ได้ในขณะที่ลบคลัสเตอร์ LDS คำอธิบายพารามิเตอร์ยังคงเหมือนเดิมตามที่กล่าวไว้ใน VSAM - โมดูลคลัสเตอร์

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงวิธีการลบคลัสเตอร์ LDS ใน JCL โดยใช้ยูทิลิตี้ IDCAMS -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEPNAME EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN    DD  *
   DELETE MY.VSAM.LDSFILE CLUSTER
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรรันด้วย MAXCC = 0 และจะลบ MY.VSAM.LDSFILE VSAM Cluster

คำสั่ง VSAM ใช้เพื่อดำเนินการบางอย่างกับชุดข้อมูล VSAM ต่อไปนี้เป็นคำสั่ง VSAM ที่มีประโยชน์ที่สุด -

  • Alter
  • Repro
  • Listcat
  • Examine
  • Verify

เปลี่ยนแปลง

คำสั่ง ALTER ใช้เพื่อแก้ไขแอตทริบิวต์ของไฟล์ VSAM เราสามารถเปลี่ยนแอตทริบิวต์ของไฟล์ VSAM ซึ่งเราได้กล่าวถึงในนิยาม VSAM Cluster ต่อไปนี้เป็นไวยากรณ์ในการเปลี่ยนแอตทริบิวต์ -

ALTER  file-cluster-name [password] 
   [ADDVOLUMES(volume-serial)] 
   [BUFFERSPACE(size)] 
   [EMPTY / NOEMPTY] 
   [ERASE / NOERASE] 
   [FREESPACE(CI-percentage CA-percentage)] 
   [KEYS(length offset)] 
   [NEWNAME(new-name)] 
   [RECORDSIZE(average maximum)] 
   [REMOVEVOLUMES(volume-serial)] 
   [SCRATCH / NOSCRATCH] 
   [TO(date) / FOR(days)] 
   [UPGRADE / NOUPGRADE] 
   [CATALOG(catalog-name [password]]

ไวยากรณ์ด้านบนแสดงพารามิเตอร์ที่เราสามารถแก้ไขได้ในคลัสเตอร์ VSAM ที่มีอยู่ คำอธิบายพารามิเตอร์ยังคงเหมือนเดิมตามที่กล่าวไว้ใน VSAM - โมดูลคลัสเตอร์

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงวิธีใช้คำสั่ง ALTER เพื่อเพิ่ม Freespace เพื่อเพิ่มไดรฟ์ข้อมูลเพิ่มเติมและ Alter Keys -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1  EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN DD  *
   ALTER  MY.VSAM.KSDSFILE 
   [ADDVOLUMES(2)] 
   [FREESPACE(6 6)] 
   [KEYS(10 2)] 
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรดำเนินการกับ MAXCC = 0 และจะเปลี่ยน Freespace, Volumes และ Keys

Repro

คำสั่ง REPRO ใช้เพื่อโหลดข้อมูลลงในชุดข้อมูล VSAM นอกจากนี้ยังใช้เพื่อคัดลอกข้อมูลจากชุดข้อมูล VSAM หนึ่งไปยังอีกชุดหนึ่ง เราสามารถใช้คำสั่งนี้เพื่อคัดลอกข้อมูลจากไฟล์ลำดับไปยังไฟล์ VSAM ยูทิลิตี้ IDCAMS ใช้คำสั่ง REPRO เพื่อโหลดชุดข้อมูล

REPRO INFILE(in-ddname) 
   OUTFILE(out-ddname)

ในไวยากรณ์ข้างต้น in-ddname คือชื่อ DD สำหรับ Input Dataset ซึ่งมีระเบียนอยู่ out-ddname คือชื่อ DD สำหรับชุดข้อมูลเอาต์พุตซึ่งจะคัดลอกระเบียนชุดข้อมูลอินพุต

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงวิธีคัดลอกระเบียนจากชุดข้อมูลหนึ่งไปยังชุดข้อมูล VSAM อื่น -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1  EXEC PGM = IDCAMS
//IN  DD DSN = MY.VSAM.KSDSFILE,DISP = SHR
//OUT DD DSN = MY.VSAM1.KSDSFILE,DISP = SHR
//SYSPRINT DD  SYSOUT = *
//SYSIN DD  *
   REPRO INFILE(IN) 
      OUTFILE(OUT)
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรรันด้วย MAXCC = 0 และจะคัดลอกระเบียนทั้งหมดจาก MY.VSAM.KSDSFILE ไปยังไฟล์ MY.VSAM1.KSDSFILE VSAM

Listcat

คำสั่ง LISTCAT ใช้เพื่อรับรายละเอียดแค็ตตาล็อกของชุดข้อมูล VSAM คำสั่ง Listcat ให้ข้อมูลต่อไปนี้เกี่ยวกับชุดข้อมูล VSAM -

  • ข้อมูล SMS
  • ข้อมูล RLS
  • ข้อมูลปริมาณ
  • ข้อมูลทรงกลม
  • ข้อมูลการจัดสรร
  • แอตทริบิวต์ชุดข้อมูล
LISTCAT ENTRY(vsam-file-name) ALL

ในไวยากรณ์ข้างต้น vsam-file-name คือชื่อชุดข้อมูล VSAM ที่เราต้องการข้อมูลทั้งหมด คำสำคัญทั้งหมดถูกระบุเพื่อรับรายละเอียดแคตตาล็อกทั้งหมด

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงวิธีดึงรายละเอียดทั้งหมดโดยใช้คำสั่ง Listcat สำหรับชุดข้อมูล VSAM -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1  EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN DD  *
   LISTCAT ENTRY(MY.VSAM.KSDSFILE) 
   ALL 
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรดำเนินการด้วย MAXCC = 0 และจะแสดงรายละเอียดแคตตาล็อกทั้งหมดเกี่ยวกับชุดข้อมูล MY.VSAM.KSDSFILE

ตรวจสอบ

คำสั่งตรวจสอบใช้เพื่อตรวจสอบความสมบูรณ์ของโครงสร้างของคลัสเตอร์ชุดข้อมูลที่เรียงตามลำดับคีย์ ตรวจสอบดัชนีและส่วนประกอบข้อมูลและหากพบปัญหาใด ๆ ข้อความแสดงข้อผิดพลาดจะถูกส่งสปูล คุณสามารถตรวจสอบข้อความ IDCxxxxx ได้

EXAMINE NAME(vsam-ksds-name) -                                    
   INDEXTEST DATATEST -                  
   ERRORLIMIT(50)

ในไวยากรณ์ข้างต้น vsam-ksds-name คือชื่อชุดข้อมูล VSAM ซึ่งเราต้องตรวจสอบดัชนีและส่วนข้อมูลของคลัสเตอร์ VSAM

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงวิธีการตรวจสอบว่าส่วนดัชนีและข้อมูลของชุดข้อมูล KSDS ซิงโครไนซ์หรือไม่ -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1  EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN DD  *
   EXAMINE NAME(MY.VSAM.KSDSFILE) -                                    
   INDEXTEST DATATEST -                  
   ERRORLIMIT(50)
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรดำเนินการกับ MAXCC = 0 และจะแสดงปัญหาทั้งหมดกับชุดข้อมูล VSAM ในข้อความ IDCxxxxx อย่างใดอย่างหนึ่งในสปูล

ตรวจสอบ

คำสั่ง Verify ใช้เพื่อตรวจสอบและแก้ไขไฟล์ VSAM ที่ปิดไม่ถูกต้องหลังจากเกิดข้อผิดพลาด คำสั่งจะเพิ่มเร็กคอร์ด End-Of-Data ที่ถูกต้องลงในไฟล์

VERIFY DS(vsam-file-name)

ในไวยากรณ์ข้างต้น vsam-file-name คือชื่อชุดข้อมูล VSAM ซึ่งเราต้องตรวจสอบข้อผิดพลาด

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงวิธีตรวจสอบและแก้ไขข้อผิดพลาดในชุดข้อมูล VSAM -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1  EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN DD  *
   VERIFY DS(MY.VSAM.KSDSFILE)                                  
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรดำเนินการด้วย MAXCC = 0 และจะแก้ไขข้อผิดพลาดในชุดข้อมูล VSAM

ดัชนีสำรองคือดัชนีเพิ่มเติมที่สร้างขึ้นสำหรับชุดข้อมูล KSDS / ESDS นอกเหนือจากดัชนีหลัก ดัชนีทางเลือกให้การเข้าถึงระเบียนโดยใช้มากกว่าหนึ่งคีย์ คีย์ของดัชนีทางเลือกอาจเป็นคีย์ที่ไม่ซ้ำกันซึ่งอาจมีรายการซ้ำกันได้

การสร้างดัชนีสำรอง

ขั้นตอนต่อไปนี้ใช้เพื่อสร้างดัชนีสำรอง -

  • กำหนดดัชนีสำรอง
  • กำหนดเส้นทาง
  • ดัชนีอาคาร

กำหนดดัชนีสำรอง

ดัชนีสำรองถูกกำหนดโดยใช้ DEFINE AIX คำสั่ง

DEFINE AIX                              -
(NAME(alternate-index-name)             -
RELATE(vsam-file-name)                  -
CISZ(number)                            -
FREESPACE(CI-Percentage,CA-Percentage)  -
KEYS(length offset)                     -
NONUNIQUEKEY / UNIQUEKEY                -
UPGRADE / NOUPGRADE                     -
RECORDSIZE(average maximum))            -
DATA                                    -
   (NAME(vsam-file-name.data))          -
INDEX                                   -
   (NAME(vsam-file-name.index))

ไวยากรณ์ด้านบนแสดงพารามิเตอร์ที่ใช้ในขณะกำหนดดัชนีสำรอง เราได้พูดถึงพารามิเตอร์บางตัวในกำหนดโมดูลคลัสเตอร์แล้วและพารามิเตอร์ใหม่บางตัวถูกใช้ในการกำหนดดัชนีสำรองซึ่งเราจะพูดถึงที่นี่ -

ซีเนียร์ No พารามิเตอร์พร้อมคำอธิบาย
1

DEFINE AIX

กำหนดคำสั่ง AIX ใช้เพื่อกำหนดดัชนีสำรองและระบุแอ็ตทริบิวต์พารามิเตอร์สำหรับคอมโพเนนต์

2

NAME

NAME ระบุชื่อของดัชนีสำรอง

3

RELATE

RELATE ระบุชื่อของคลัสเตอร์ VSAM ที่สร้างดัชนีทางเลือก

4

NONUNIQUEKEY / UNIQUEKEY

UNIQUEKEY ระบุว่าดัชนีทางเลือกไม่ซ้ำกันและ NONUNIQUEKEY ระบุว่าอาจมีรายการที่ซ้ำกัน

5

UPGRADE / NOUPGRADE

UPGRADE ระบุว่าควรแก้ไขดัชนีทางเลือกหากคลัสเตอร์ฐานถูกแก้ไขและ NOUPGRADE ระบุว่าควรปล่อยดัชนีสำรองไว้ตามลำพังหากคลัสเตอร์ฐานถูกแก้ไข

ตัวอย่าง

ต่อไปนี้เป็นตัวอย่างพื้นฐานเพื่อแสดงวิธีการกำหนดดัชนีสำรองใน JCL -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1  EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN    DD  *
   DEFINE AIX (NAME(MY.VSAM.KSDSAIX)      -
   RELATE(MY.VSAM.KSDSFILE)               -
   CISZ(4096)                             -
   FREESPACE(20,20)                       -
   KEYS(20,7)                             -
   NONUNIQUEKEY                           -
   UPGRADE                                -
   RECORDSIZE(80,80))                     -
   DATA(NAME(MY.VSAM.KSDSAIX.DATA))       -
   INDEX(NAME(MY.VSAM.KSDSAIX.INDEX))
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรรันด้วย MAXCC = 0 และจะสร้าง MY.VSAM.KSDSAIX Alternate Index

กำหนดเส้นทาง

กำหนดเส้นทางใช้เพื่อเชื่อมโยงดัชนีทางเลือกกับคลัสเตอร์ฐาน ในขณะที่กำหนดเส้นทางเราระบุชื่อของเส้นทางและดัชนีทางเลือกที่เกี่ยวข้องกับเส้นทางนี้

DEFINE PATH                        -
NAME(alternate-index-path-name)    -
PATHENTRY(alternate-index-name))

ไวยากรณ์ด้านบนมีสองพารามิเตอร์ NAME ใช้เพื่อระบุชื่อเส้นทางดัชนีสำรองและ PATHENTRY ใช้เพื่อระบุชื่อดัชนีสำรอง

ตัวอย่าง

ต่อไปนี้เป็นตัวอย่างพื้นฐานในการกำหนด Path ใน JCL -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1  EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN    DD  *
DEFINE PATH                          -
   NAME(MY.VSAM.KSDSAIX.PATH)    -
   PATHENTRY(MY.VSAM.KSDSAIX))
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรดำเนินการด้วย MAXCC = 0 และจะสร้างเส้นทางระหว่างดัชนีสำรองไปยังคลัสเตอร์ฐาน

ดัชนีอาคาร

คำสั่ง BLDINDEX ใช้เพื่อสร้างดัชนีทางเลือก BLDINDEX อ่านบันทึกทั้งหมดในชุดข้อมูลที่จัดทำดัชนี VSAM (หรือคลัสเตอร์ฐาน) และแยกข้อมูลที่จำเป็นในการสร้างดัชนีทางเลือก

BLDINDEX                           -
INDATASET(vsam-cluster-name)       -
OUTDATASET(alternate-index-name))

ไวยากรณ์ด้านบนมีสองพารามิเตอร์ INDATASET ใช้เพื่อระบุ VSAM Cluster Name และ OUTDATASET ใช้เพื่อระบุ Alternate Index Name

ตัวอย่าง

ต่อไปนี้เป็นตัวอย่างพื้นฐานในการสร้างดัชนีใน JCL -

//SAMPLE JOB(TESTJCL,XXXXXX),CLASS = A,MSGCLASS = C
//STEP1  EXEC PGM = IDCAMS
//SYSPRINT DD  SYSOUT = *
//SYSIN    DD  *
   BLDINDEX                           -
   INDATASET(MY.VSAM.KSDSFILE)        -
   OUTDATASET(MY.VSAM.KSDSAIX))
/*

หากคุณจะเรียกใช้ JCL ข้างต้นบนเซิร์ฟเวอร์ Mainframes ควรดำเนินการกับ MAXCC = 0 และจะสร้างดัชนี

แค็ตตาล็อกรักษาหน่วยและปริมาตรที่ชุดข้อมูลอยู่ แค็ตตาล็อกใช้สำหรับการดึงชุดข้อมูล ชุดข้อมูลที่ไม่ใช่ VSAM สร้างรายการแค็ตตาล็อกโดยใช้ Disposition Parameter ใน JCL ชุดข้อมูล VSAM เก็บรักษาแค็ตตาล็อกของตัวเองในรูปแบบคลัสเตอร์ KSDS ในภาพต่อไปนี้คุณจะเห็นประเภทของแคตตาล็อก VSAM -

แคตตาล็อกหลัก

แค็ตตาล็อกหลักเป็นไฟล์ที่ตรวจสอบและจัดการการทำงานของ VSAM เป็นแค็ตตาล็อกหลักเพียงรายการเดียวในระบบใด ๆ ที่มีรายการเกี่ยวกับชุดข้อมูลระบบและชุดข้อมูล VSAM ชุดข้อมูล VSAM และ Non-VSAM อาจมีรายการอยู่ในแค็ตตาล็อกหลัก แต่ไม่ใช่แนวทางปฏิบัติที่ดี แค็ตตาล็อกหลักถูกสร้างขึ้นในระหว่างกระบวนการสร้างระบบและอยู่บนไดรฟ์ข้อมูลระบบ แค็ตตาล็อกหลักเป็นเจ้าของทรัพยากร VSAM ทั้งหมดในระบบปฏิบัติการ ไฟล์ทั้งหมดที่ใช้ใน VSAM ถูกควบคุมโดยแค็ตตาล็อกหลัก มาสเตอร์แคตตาล็อกมีหน้าที่รับผิดชอบในการดำเนินการต่อไป -

  • การอนุญาตรหัสผ่านสำหรับไฟล์
  • การเพิ่มความปลอดภัย
  • การเข้าถึง VSAM สำหรับไฟล์
  • การจัดการพื้นที่ของไฟล์
  • ตำแหน่งของไฟล์
  • มีพื้นที่ว่างในไฟล์

เมื่อแอตทริบิวต์ของไฟล์ใด ๆ ข้างต้นเปลี่ยนแปลงไประบบจะอัปเดตโดยอัตโนมัติในแค็ตตาล็อกหลัก แค็ตตาล็อกหลักถูกกำหนดโดยใช้โปรแกรม IDCAMS

แคตตาล็อกผู้ใช้

แค็ตตาล็อกผู้ใช้มีโครงสร้างและแนวคิดเหมือนกับแค็ตตาล็อกหลัก มีอยู่ในระดับลำดับชั้นถัดไปหลังจากแค็ตตาล็อกหลัก แค็ตตาล็อกผู้ใช้ไม่บังคับในระบบ แต่ใช้เพื่อเพิ่มความปลอดภัยของระบบ VSAM แค็ตตาล็อกหลักชี้ไปที่ไฟล์ VSAM แต่ถ้าแค็ตตาล็อกผู้ใช้มีอยู่แค็ตตาล็อกหลักจะชี้ไปที่แค็ตตาล็อกผู้ใช้ แค็ตตาล็อกของผู้ใช้สามารถมีได้หลายแบบตามความต้องการของระบบ ในโครงสร้าง VSAM ถ้าแค็ตตาล็อกหลักถูกลบออกจะไม่มีผลกับแค็ตตาล็อกผู้ใช้ แค็ตตาล็อกผู้ใช้ประกอบด้วยรายการเกี่ยวกับชุดข้อมูลเฉพาะของแอปพลิเคชัน ข้อมูลของแค็ตตาล็อกผู้ใช้จะถูกเก็บไว้ในแค็ตตาล็อกหลัก

พื้นที่ข้อมูล

พื้นที่ข้อมูลคือพื้นที่ของอุปกรณ์จัดเก็บข้อมูลการเข้าถึงโดยตรงที่จัดสรรไว้สำหรับการใช้ VSAM โดยเฉพาะ ต้องสร้างพื้นที่ข้อมูลก่อนสร้างคลัสเตอร์ VSAM พื้นที่ที่ครอบครองโดยพื้นที่ข้อมูลจะถูกบันทึกไว้ใน Volume Table of Contents (VTOC) ดังนั้นพื้นที่จะไม่พร้อมสำหรับการจัดสรรให้ใช้งานอื่นใดทั้ง VSAM หรือไม่ใช่ VSAM VTOC มีการเข้าสู่พื้นที่ที่ถูกครอบครองโดยพื้นที่ VSAM สร้างพื้นที่ข้อมูลเพื่อเก็บรายการแค็ตตาล็อกผู้ใช้ VSAM ควบคุมพื้นที่นี้และตรวจสอบและดูแลพื้นที่นี้ตามที่ไฟล์ VSAM ต้องการ

กลุ่มที่ไม่ซ้ำกัน

คลัสเตอร์ที่ไม่ซ้ำกันประกอบด้วยพื้นที่ข้อมูลแยกต่างหากซึ่งถูกใช้อย่างสมบูรณ์โดยคลัสเตอร์ที่สร้างขึ้นภายใน คลัสเตอร์ที่ไม่ซ้ำกันถูกสร้างขึ้นจากพื้นที่ที่ไม่ได้ถูกจัดสรรบนพื้นที่เก็บข้อมูลที่เข้าถึงได้โดยตรง

คลัสเตอร์ย่อยที่จัดสรร

ไฟล์ VSAM ที่จัดสรรย่อยจะแชร์พื้นที่ VSAM กับไฟล์ที่จัดสรรย่อยอื่น ๆ ระบุว่าไฟล์ควรถูกจัดสรรย่อยภายในพื้นที่ VSAM ที่มีอยู่ การจัดสรรย่อยใช้เพื่อการจัดการและควบคุมช่องว่าง VSAM ที่ง่ายขึ้น

ชุดข้อมูลที่ไม่ใช่ VSAM

ชุดข้อมูลที่ไม่ใช่ VSAM อยู่ทั้งบนเทปและหน่วยเก็บข้อมูลแบบเข้าถึงโดยตรง ชุดข้อมูลที่ไม่ใช่ VSAM อาจมีรายการทั้งในแค็ตตาล็อกหลักและแค็ตตาล็อกผู้ใช้ หน้าที่หลักของการลงรายการชุดข้อมูลที่ไม่ใช่ VSAM คือการเก็บรักษาข้อมูลอนุกรมของหน่วยและปริมาตร

ในขณะที่ทำงานกับชุดข้อมูล VSAM คุณอาจพบบ่อย ต่อไปนี้เป็นรหัสสถานะไฟล์ทั่วไปพร้อมคำอธิบายซึ่งจะช่วยคุณแก้ไขปัญหา -

รหัส คำอธิบาย
00 การดำเนินการเสร็จสมบูรณ์
02 พบคีย์ที่ซ้ำกันของดัชนีสำรองที่ไม่ซ้ำกัน
04 บันทึกความยาวคงที่ไม่ถูกต้อง
05 ขณะดำเนินการเปิดไฟล์และไม่มีไฟล์อยู่
10 พบจุดสิ้นสุดของไฟล์
14 พยายามอ่านเร็กคอร์ดสัมพัทธ์นอกขอบเขตไฟล์
20 คีย์ไม่ถูกต้องสำหรับ VSAM KSDS หรือ RRDS
21 ข้อผิดพลาดของลำดับขณะดำเนินการเขียนหรือเปลี่ยนคีย์บน REWRITE
22 พบคีย์ที่ซ้ำกันหลัก
23 ไม่พบบันทึกหรือไม่พบไฟล์
24 คีย์นอกขอบเขตของไฟล์
30 ข้อผิดพลาด I / O ถาวร
34 บันทึกนอกขอบเขตไฟล์
35 ขณะดำเนินการเปิดไฟล์และไม่มีไฟล์อยู่
37 เปิดไฟล์ด้วยโหมดที่ไม่ถูกต้อง
38 พยายามเปิดไฟล์ที่ถูกล็อก
39 OPEN ล้มเหลวเนื่องจากแอตทริบิวต์ของไฟล์ที่ขัดแย้งกัน
41 พยายามเปิดไฟล์ที่เปิดอยู่แล้ว
42 พยายามปิดไฟล์ที่ไม่ได้เปิด
43 พยายามรีไรท์โดยไม่อ่านบันทึกก่อน
44 พยายามทำซ้ำบันทึกที่มีความยาวต่างกัน
46 พยายามอ่านเกินจุดสิ้นสุดของไฟล์
47 พยายามอ่านจากไฟล์ที่ไม่ได้เปิด IO หรือ INPUT
48 พยายามเขียนไปยังไฟล์ที่ไม่ได้เปิด IO หรือ OUTPUT
49 พยายามลบหรือเขียนซ้ำไปยังไฟล์ที่ไม่ได้เปิด IO
91 รหัสผ่านหรือการอนุญาตล้มเหลว
92 ลอจิกผิดพลาด
93 ทรัพยากรไม่พร้อมใช้งาน
94 บันทึกตามลำดับไม่พร้อมใช้งานหรือเกิดข้อผิดพลาด OPEN พร้อมกัน
95 ข้อมูลไฟล์ไม่ถูกต้องหรือไม่สมบูรณ์
96 ไม่มีคำสั่ง DD สำหรับไฟล์
97 เปิดสำเร็จและตรวจสอบความสมบูรณ์ของไฟล์
98 ไฟล์ถูกล็อค - OPEN ล้มเหลว
99 บันทึกถูกล็อก - การเข้าถึงบันทึกล้มเหลว