Mỗi danh tỷ lệ kèo bóng đá có bất kỳ dữ liệu ban đầu được tạo bằng tay (một số không) có tương ứng.dat
Tệp chứa dữ tỷ lệ kèo bóng đá ban đầu của nó ở định dạng có thể chỉnh sửa.
mỗi.dat
Tệp chứa các cấu trúc dữ liệu Perl theo nghĩa đen chỉ đơn giản là để tạo ra một cấu trúc dữ liệu trong bộ nhớ bao gồm một mảng các tài liệu tham khảo băm, một hàng trên mỗi hàng danh tỷ lệ kèo bóng đá. Một đoạn trích được sửa đổi một chút từpg_database.dat
sẽ trình bày tỷ lệ kèo bóng đá tính năng chính:
[[
Điểm để lưu ý:
Bố cục tập tin tổng thể là: Khung vuông mở, một hoặc nhiều bộ niềng răng xoăn mỗi thứ đại diện cho một hàng danh tỷ lệ kèo bóng đá, đóng khung vuông. Viết dấu phẩy sau mỗi lần đóng giằng xoăn.
Trong mỗi hàng danh tỷ lệ kèo bóng đá, hãy viết dấu phẩyKey
=
giá trị
cặp. Cho phépKey
S là tên của các cột của danh tỷ lệ kèo bóng đá, cộng với các phím siêu dữ liệuoid
, oid_symbol
, mảng_type_oid
vàDescr
. (Việc sử dụngoid
vàoid_symbol
được mô tả trongPhần 74.2.2bên dưới, trong khimảng_type_oid
được mô tả trongPhần 74.2.4. Descr
cung cấp chuỗi mô tả cho đối tượng, sẽ được chèn vàopg_descrip
hoặcpg_shdescrip
khi thích hợp.) Trong khi các khóa siêu dữ liệu là tùy chọn, tất cả các cột được xác định của danh tỷ lệ kèo bóng đá phải được cung cấp, ngoại trừ khi danh tỷ lệ kèo bóng đá của.h
Tệp Chỉ định giá trị mặc định cho cột. (Trong ví dụ trên,Datdba
Trường đã bị bỏ qua vìpg_database.h
cung cấp giá trị mặc định phù hợp cho nó.)
Tất cả tỷ lệ kèo bóng đá giá trị phải được trích dẫn đơn. tỷ lệ kèo bóng đá trích dẫn đơn lẻ được sử dụng trong một giá trị với dấu gạch chéo ngược.Phần 4.1.2.2); Ví dụ\ T
Chuyển đổi thành tỷ lệ kèo bóng đá ký tự tab. Nếu bạn thực sự muốn tỷ lệ kèo bóng đá dấu gạch chéo ngược trong giá trị cuối cùng, bạn sẽ cần phải viết bốn trong số chúng: Perl Strips Two, rời khỏi\
Để máy quét bootstrap xem.
Giá trị null được biểu diễn bằng_null_
. (Lưu ý rằng không có cách nào để tạo tỷ lệ kèo bóng đá giá trị chỉ là chuỗi đó.)
Nhận xét được đi trước#
, và phải ở trên dòng của riêng họ.
Các giá trị trường là OID của các tỷ lệ kèo bóng đá danh tỷ lệ kèo bóng đá khác phải được biểu diễn bằng các tên biểu tượng thay vì OID số thực tế. (Trong ví dụ trên,Dattablespace
chứa tỷ lệ kèo bóng đá tham chiếu như vậy.) Điều này được mô tả trongPhần 74.2.3bên dưới.
Vì các băm là các cấu trúc dữ tỷ lệ kèo bóng đá không theo thứ tự, thứ tự trường và bố cục dòng không có ý nghĩa về mặt ngữ nghĩa. Tuy nhiên, để duy trì ngoại hình nhất quán, chúng tôi đặt một vài quy tắc được áp dụng bởi tập lệnh định dạngReformat_dat_file.pl
:
Trong mỗi cặp niềng răng xoăn, các trường siêu dữ tỷ lệ kèo bóng đáOID
, oid_symbol
, mảng_type_oid
vàDescr
(nếu có) đến trước, theo thứ tự đó, sau đó các trường riêng của danh tỷ lệ kèo bóng đá xuất hiện theo thứ tự được xác định của chúng.
Newlines được chèn giữa các trường khi cần thiết để giới hạn độ dài dòng xuống 80 ký tự, nếu có thể. Một dòng mới cũng được chèn giữa các trường siêu dữ tỷ lệ kèo bóng đá và các trường chính quy.
Nếu danh tỷ lệ kèo bóng đá của.h
Tệp Chỉ định giá trị mặc định cho cột và tỷ lệ kèo bóng đá nhập dữ liệu có cùng giá trị đó,Reformat_dat_file.pl
Sẽ bỏ qua nó khỏi tệp dữ tỷ lệ kèo bóng đá. Điều này giữ cho biểu diễn dữ tỷ lệ kèo bóng đá nhỏ gọn.
Reformat_dat_file.pl
Bảo tồn tỷ lệ kèo bóng đá dòng trống và tỷ lệ kèo bóng đá dòng bình luận AS-IS.
Nên chạyReformat_dat_file.pl
Trước khi gửi các bản vá dữ liệu danh tỷ lệ kèo bóng đá. Để thuận tiện, bạn chỉ có thể thay đổi thànhsrc/bao gồm/catalog/
và chạyLàm cho ReforTat-Dat-Files
.
Nếu bạn muốn thêm một phương thức mới để làm cho biểu diễn dữ tỷ lệ kèo bóng đá nhỏ hơn, bạn phải thực hiện nó trongReformat_dat_file.pl
và cũng dạyDanh tỷ lệ kèo bóng đá :: Parsedata ()
Cách mở rộng dữ tỷ lệ kèo bóng đá trở lại thành đại diện đầy đủ.
Một hàng danh tỷ lệ kèo bóng đá xuất hiện trong dữ liệu ban đầu có thể được đưa ra một OID được chỉ định bằng thủ công bằng cách viếtoid =
Trường siêu dữ tỷ lệ kèo bóng đá. Hơn nữa, nếu một OID được gán, một macro C cho OID đó có thể được tạo bằng cách viết mộtnnnn
oid_symbol =
Trường siêu dữ tỷ lệ kèo bóng đá.tên
Các hàng danh tỷ lệ kèo bóng đá được tải sẵn phải có OID được chỉ định trước nếu có các tham chiếu OID cho chúng trong các hàng được tải sẵn khác. Một OID được chỉ định trước cũng cần thiết nếu OID của hàng phải được tham chiếu từ mã C.oid
Trường siêu dữ liệu có thể được bỏ qua, trong trường hợp đó, mã bootstrap gán một OID tự động. Trong thực tế, chúng tôi thường chỉ định các OID cho tất cả hoặc không có hàng được tải sẵn trong một danh tỷ lệ kèo bóng đá nhất định, ngay cả khi chỉ một số trong số chúng thực sự được tham chiếu chéo.
Viết giá trị số thực tế của bất kỳ OID nào trong mã C được coi là dạng rất xấu; Thay vào đó, luôn luôn sử dụng tỷ lệ kèo bóng đá macro.PG_PROC
OIDS đủ phổ biến để có một cơ chế đặc biệt để tạo tỷ lệ kèo bóng đá macro cần thiết tự động; nhìn thấysrc/backend/utils/gen_fmgrtab.pl
. Tương tự - nhưng, vì lý do lịch sử, không được thực hiện theo cùng tỷ lệ kèo bóng đá cách - có tỷ lệ kèo bóng đá phương thức tự động để tạo macro choPG_TYPE
oids.oid_symbol
Do đó không cần thiết trong hai danh tỷ lệ kèo bóng đá đó. Tương tự như vậy, macro chopg_ class
OIDS của các danh tỷ lệ kèo bóng đá và chỉ tỷ lệ kèo bóng đá hệ thống được thiết lập tự động. Đối với tất cả các danh tỷ lệ kèo bóng đá hệ thống khác, bạn phải chỉ định thủ công bất kỳ macro nào bạn cần quaoid_symbol
tỷ lệ kèo bóng đá nhập.
Để tìm OID có sẵn cho tỷ lệ kèo bóng đá hàng mới được tải sẵn, chạy tập lệnhsrc/bao gồm/catalog/unude_oids
. Nó in phạm vi bao gồm tỷ lệ kèo bóng đá OID chưa sử dụng (ví dụ: dòng đầu ra45-900
có nghĩa là OIDS 45 đến 900 chưa được phân bổ). Hiện tại, OIDS 1 Ném9999 được dành riêng để phân công thủ công;uned_oids
tập lệnh chỉ cần xem qua các tiêu đề danh tỷ lệ kèo bóng đá và.dat
Tệp để xem cái nào không xuất hiện. Bạn cũng có thể sử dụngtrùng lặp_oids
Kịch bản để kiểm tra sai lầm. (Genbki.pl
18311_18443
Khi chọn OID cho một bản vá không được dự kiến sẽ được thực hiện ngay lập tức, thực tiễn tốt nhất là sử dụng một nhóm tỷ lệ kèo bóng đá OID liên tiếp hơn hoặc ít hơn bắt đầu với một số lựa chọn ngẫu nhiên trong phạm vi 8000. Điều này giảm thiểu nguy cơ va chạm OID với tỷ lệ kèo bóng đá bản vá khác đang được phát triển đồng thời.Renumber_oids.pl
có thể được sử dụng cho tỷ lệ kèo bóng đá đích này. Nếu một bản vá không cam kết được tìm thấy có xung đột OID với một số bản vá được cam kết gần đây,Renumber_oids.pl
cũng có thể hữu ích cho việc phục hồi từ tình huống đó.
Vì quy ước này có thể đánh số lại tỷ lệ kèo bóng đá OID được gán bởi tỷ lệ kèo bóng đá bản vá, tỷ lệ kèo bóng đá OID được gán bởi một bản vá không nên được coi là ổn định cho đến khi bản vá được đưa vào bản phát hành chính thức. Tuy nhiên, chúng tôi không thay đổi đối tượng được chỉ định thủ công một khi được phát hành, vì điều đó sẽ tạo ra tỷ lệ kèo bóng đá vấn đề tương thích tỷ lệ kèo bóng đá loại.
nếuGenbki.pl
Cần gán một OID cho một tỷ lệ kèo bóng đá nhập danh tỷ lệ kèo bóng đá không có OID được chỉ định thủ công, nó sẽ sử dụng một giá trị trong phạm vi 10000 Wap11999. Bộ đếm OID của máy chủ được đặt thành 10000 khi bắt đầu chạy bootstrap, để bất kỳ đối tượng nào được tạo trên đường trong quá trình xử lý bootstrap cũng nhận được OID trong phạm vi này.
Đối tượng có OIDS bên dướiFirstUnpinNedObjectID
(12000) được coi làGhimHồi, Ngăn chặn chúng bị xóa. (Có một số lượng nhỏ tỷ lệ kèo bóng đá trường hợp ngoại lệ, được dây cứng thànhispinnedObject ()
.)initDBBuộc bộ đếm OID lên đếnFirstUnpinNedObjectID
Ngay khi nó sẵn sàng tạo tỷ lệ kèo bóng đá đối tượng chưa được khai thác. Do đó tỷ lệ kèo bóng đá đối tượng được tạo trong tỷ lệ kèo bóng đá giai đoạn sau củainitDB, chẳng hạn như tỷ lệ kèo bóng đá đối tượng được tạo trong khi chạythông tin_schema.sql
tập lệnh, sẽ không được ghim, trong khi tất cả tỷ lệ kèo bóng đá đối tượng được biết đếnGenbki.pl
sẽ là.
OID được gán trong hoạt động cơ sở dữ tỷ lệ kèo bóng đá thông thường bị hạn chế là 16384 trở lên. Điều này đảm bảo rằng phạm vi 10000 Wap16383 miễn phí cho các OID được gán tự động bởiGenbki.pl
hoặc tronginitDB. tỷ lệ kèo bóng đá OID được chỉ định tự động này không được coi là ổn định và có thể thay đổi từ cài đặt này sang cài đặt khác.
Về nguyên tắc, các tham chiếu chéo từ hàng danh tỷ lệ kèo bóng đá ban đầu này sang hàng khác có thể được viết chỉ bằng cách viết OID được chỉ định trước của hàng được tham chiếu trong trường tham chiếu. Tuy nhiên, điều đó chống lại chính sách dự án, bởi vì nó dễ bị lỗi, khó đọc và bị vỡ nếu OID mới được chỉ định.Genbki.pl
cung cấp các cơ chế để viết các tài tỷ lệ kèo bóng đá tham khảo tượng trưng thay thế. Các quy tắc như sau:
Sử dụng các tài liệu tham khảo tượng trưng được bật trong một cột danh tỷ lệ kèo bóng đá cụ thể bằng cách đính kèmbki_lookup (
Định nghĩa của cột, trong đóLookUprule
)LookUprule
là tên của danh tỷ lệ kèo bóng đá được tham chiếu, ví dụ:PG_PROC
. BKI_Lookup
có thể được gắn vào tỷ lệ kèo bóng đá cột loạioid
, RegProc
, oidVector
hoặcoid []
; Trong hai trường hợp sau, nó ngụ ý thực hiện tra cứu trên từng phần tử của mảng.
Nó cũng được phép đính kèmbki_lookup (mã hóa)
22912_23059GENBKI.PL
.
Trong một số cột danh tỷ lệ kèo bóng đá, nó được phép các tỷ lệ kèo bóng đá nhập bằng không thay vì tham chiếu hợp lệ. Nếu điều này được cho phép, hãy viếtBKI_LOOKUP_OPT
thay vìBKI_Lookup
. Sau đó, bạn có thể viết0
cho một tỷ lệ kèo bóng đá. (Nếu cột được khai báoRegProc
, bạn có thể viết tùy ý-
thay vì0
.) Ngoại trừ trường hợp đặc biệt này, tất cả các tỷ lệ kèo bóng đá trong ABKI_Lookup
Cột phải là tài tỷ lệ kèo bóng đá tham khảo tượng trưng.Genbki.pl
Sẽ cảnh báo về tỷ lệ kèo bóng đá tên không được công nhận.
Hầu hết các loại đối tượng danh tỷ lệ kèo bóng đá được tham chiếu đơn giản bằng tên của chúng. Lưu ý rằng tên loại phải khớp chính xác với tham chiếuPG_TYPE
Entry'sTYPNAME
; Bạn không được sử dụng bất kỳ bí tỷ lệ kèo bóng đá nào nhưSố nguyên
choINT4
.
tỷ lệ kèo bóng đá hàm có thể được biểu diễn bằng của nóproname
, nếu đó là duy nhất trong sốpg_proc.dat
tỷ lệ kèo bóng đá (điều này hoạt động như đầu vào regproc). Nếu không, hãy viết nó dưới dạngproname (argtypename, argtypename, ...)
, giống như regprocedure. Tên loại đối số phải được đánh vần chính xác như trongpg_proc.dat
Entry'sproArgTypes
Trường. Không chèn bất kỳ khoảng trống nào.
toán tử được đại diện bởi, viết tên loại chính xác như chúng xuất hiện trong
pg_operator.dat
Entry'sOprleft
vàoprright
Trường. (Viết0
Đối với toán hạng bị bỏ qua của tỷ lệ kèo bóng đá toán tử Unary.)
25265_25373access_method_name
/
object_name
.
Trong không có trường hợp nào trong số này có bất kỳ điều khoản nào cho trình độ sơ đồ lược đồ; Tất cả tỷ lệ kèo bóng đá đối tượng được tạo trong bootstrap dự kiến sẽ nằm trongpg_catalog
lược đồ.
Genbki.pl
Giải quyết tất cả các tham chiếu tượng trưng trong khi nó chạy và đặt các OID số đơn giản vào tệp BKI phát ra. Do đó, không cần phụ trợ bootstrap để đối phó với các tài tỷ lệ kèo bóng đá tham khảo tượng trưng.
mong muốn đánh dấu tỷ lệ kèo bóng đá cột tham chiếu OID bằngBKI_Lookup
hoặcBKI_LOOKUP_OPT
Ngay cả khi danh tỷ lệ kèo bóng đá không có dữ liệu ban đầu yêu cầu tra cứu. Điều này cho phépGenbki.pl
Để ghi lại các mối quan hệ khóa nước ngoài tồn tại trong các danh tỷ lệ kèo bóng đá hệ thống. Thông tin đó được sử dụng trong các bài kiểm tra hồi quy để kiểm tra các tỷ lệ kèo bóng đá không chính xác.Declare_forign_key
, Declare_forign_key_opt
, Declare_array_forign_key
vàDeclare_array_forign_key_opt
, được sử dụng để khai báo tỷ lệ kèo bóng đá mối quan hệ khóa nước ngoài quá phức tạp đối vớiBKI_Lookup
(Thông thường, tỷ lệ kèo bóng đá khóa nước ngoài nhiều cột).
Hầu hết các loại dữ tỷ lệ kèo bóng đá vô hướng nên có loại mảng tương ứng (nghĩa là loại mảng varlena tiêu chuẩn có loại phần tử là loại vô hướng và được tham chiếu bởiTyparray
Trường thuộc loại vô hướngPG_TYPE
tỷ lệ kèo bóng đá nhập).Genbki.pl
Có thể tạoPG_TYPE
tỷ lệ kèo bóng đá nhập cho loại mảng trong hầu hết các trường hợp.
Để sử dụng cơ sở này, chỉ cần viết tỷ lệ kèo bóng đámảng_type_oid =
Trường siêu dữ tỷ lệ kèo bóng đá trong loại vô hướngnnnn
pg_type
tỷ lệ kèo bóng đá nhập, chỉ định OID để sử dụng cho loại mảng. Sau đó bạn có thể bỏ quaTyparray
Trường, vì nó sẽ được điền tự động bằng oid đó.
Tên của loại mảng được tạo là tên của loại vô hướng với một dấu gạch dưới được chuẩn bị. Các trường khác của tỷ lệ kèo bóng đá khác được lấp đầy từbki_array_default (
Chú thích tronggiá trị
)pg_type.h
hoặc nếu không có, được sao chép từ loại vô hướng. (Cũng có tỷ lệ kèo bóng đá trường hợp đặc biệt choTypalign
.) Sau đóTypelem
vàTyparray
Trường của hai tỷ lệ kèo bóng đá được đặt thành tham chiếu chéo nhau.
Dưới đây là một số gợi ý về các cách dễ nhất để thực hiện các tác vụ chung khi cập nhật các tệp dữ liệu danh tỷ lệ kèo bóng đá.
Thêm một cột mới với mặc định vào một danh tỷ lệ kèo bóng đá:Thêm cột vào tệp tiêu đề vớiBKI_DEFAULT (
Chú thích. Tệp dữ tỷ lệ kèo bóng đá chỉ cần được điều chỉnh bằng cách thêm trường vào các hàng hiện tại khi cần giá trị không mặc định.giá trị
)
Thêm giá trị mặc định vào tỷ lệ kèo bóng đá cột hiện có không có tỷ lệ kèo bóng đá:Thêm ABKI_DEFAULT
Chú thích vào tệp tiêu đề, sau đó chạyLàm cho ReforTat-Dat-Files
Để xóa các tỷ lệ kèo bóng đá nhập trường hiện đang có.
Xóa tỷ lệ kèo bóng đá cột, cho dù nó có mặc định hay không:Xóa cột khỏi tiêu đề, sau đó chạyLàm cho ReforTat-Dat-Files
Để xóa các tỷ lệ kèo bóng đá nhập trường không có.
Thay đổi hoặc xóa giá trị mặc định hiện có:Bạn không thể đơn giản thay đổi tệp tiêu đề, vì điều đó sẽ khiến dữ tỷ lệ kèo bóng đá hiện tại được giải thích không chính xác. Chạy đầu tiênLàm cho mở rộng-DAT-FILES
Để viết lại các tệp dữ tỷ lệ kèo bóng đá với tất cả các giá trị mặc định được chèn một cách rõ ràng, sau đó thay đổi hoặc xóaBKI_DEFAULT
chú thích, sau đó chạyLàm cho ReforTat-Dat-Files
Để xóa tỷ lệ kèo bóng đá trường thừa.
Chỉnh sửa số lượng lớn ad-hoc: Refleat_dat_file.pl
có thể được điều chỉnh để thực hiện nhiều loại thay đổi số lượng lớn. Tìm kiếm tỷ lệ kèo bóng đá bình luận khối của nó hiển thị nơi có thể chèn mã một lần.PG_PROC
thành trường char:
Thêm cột mới, với mặc định, vàopg_proc.h
:
+ / * Xem các danh tỷ lệ kèo bóng đá prokind_ bên dưới * /
Tạo tập tỷ lệ kèo bóng đánh mới dựa trênReformat_dat_file.pl
Để chèn tỷ lệ kèo bóng đá giá trị thích hợp trên đường bay:
- # Tại thời điểm này, chúng ta có hàng đầy đủ trong bộ nhớ dưới dạng băm
Chạy tập tỷ lệ kèo bóng đánh mới:
$ cd src/bao gồm/danh tỷ lệ kèo bóng đá
Tại thời điểm nàypg_proc.dat
Có cả ba cột,Prokind
, proisagg
vàProisWindow
, mặc dù chúng sẽ chỉ xuất hiện trong tỷ lệ kèo bóng đá hàng mà chúng có tỷ lệ kèo bóng đá giá trị không mặc định.
Xóa tỷ lệ kèo bóng đá cột cũ khỏipg_proc.h
:
- /* Nó có phải là tỷ lệ kèo bóng đá tổng hợp không? */
Cuối cùng, chạyLàm cho ReforTat-Dat-Files
Để loại bỏ các tỷ lệ kèo bóng đá cũ vô dụng khỏipg_proc.dat
.
Để biết thêm tỷ lệ kèo bóng đá ví dụ về tập lệnh được sử dụng để chỉnh sửa số lượng lớn, xemConvert_oid2Name.pl
vàremove_pg_type_oid_symbols.pl
Được đính kèm với tin nhắn này:
Nếu bạn thấy bất cứ điều gì trong tài tỷ lệ kèo bóng đá không chính xác, không khớpMẫu nàyĐể báo cáo vấn đề tài tỷ lệ kèo bóng đá.