.\" http://belgeler.org \- 2009\-10\-29T15:35:49+02:00 .TH "CREATE OPERATOR CLASS" 7 "" "PostgreSQL" "SQL \- Dil Deyimleri" .nh .PD 0 .SH İSİM CREATE OPERATOR CLASS \- yeni bir işleç sınıfı tanımlar .SH KULLANIM .nf \fBCREATE OPERATOR CLASS\fR \fIisim\fR [ \fBDEFAULT\fR ] \fBFOR TYPE\fR \fIveri_türü\fR \ \fBUSING\fR \fIindeksleme_yöntemi\fR \ \fBAS\fR { \fBOPERATOR\fR \fIstrateji_numarası\fR \ \fIişleç_ismi\fR [ ( \fIişleç_türü\fR, \fIişleç_türü\fR ) ] \ [ \fBRECHECK\fR ] \ | \fBFUNCTION\fR \fIdestek_numarası\fR \fIişlev_ismi\fR ( \fIarg_türü\fR [, ...] ) \ | \fBSTORAGE\fR \fIsaklama_türü\fR \ } [, ... ] .fi .SH AÇIKLAMA \fBCREATE OPERATOR CLASS\fR yeni bir işleç sınıfı oluşturur. Bir işleç sınıfı belli bir veri türünün bir indeks ile nasıl kullanılabileceğini tanımlar. İşleç sınıfı bu veri türü ya da indeksleme yöntemi için bazı roller alacak veya stratejileri üstlenecek işleçleri belirler. Ayrıca, işleç sınıfı bir indeks sütunu için seçildiğinde indeksleme yöntemi tarafından kullanılacak destek yordamlarını da belirtir. Bir işleç sınıfı tarafından kullanılacak bütün işleçler ve işlevler işleç sınıfı oluşturulmadan önce tanımlanmalıdır. Bir şema ismi verilmişse, işleç sınıfı belirtilen şemada oluşturulur. Aksi takdirde o anki şemada oluşturulur. Aynı şema içinde iki işleç sınıfı, sadece farklı indeksleme yöntemleri içinseler aynı isimde olabilirler. İşleç sınıfını tanımlayan kullanıcı işleç sınıfının sahibi olur. Şimdilik, bu kullanıcı ayrıcalıklı kullanıcı olmak zorundadır. (Bir hatalı işleç sınıfı tanımının karışıklığa yol açması ve hatta sunucunun çökmesine sebep olması nedeniyle bu kısıtlama konmuştur.) \fBCREATE OPERATOR CLASS\fR şimdilik işleç sınıfı tanımının içerdiği tüm işleçlerin ve işlevlerin indeksleme yöntemi için gerekli olup olmadığına bakmamaktadır. Geçerli bir işleç sınıfı tanımlamak kullanıcının sorumluluğundadır. Daha fazla bilgi için, .br http://www.postgresql.org/uygulamalar/pgsql/xindex.html adresine bakınız. .SH PARAMETRELER .br .ns .TP \fIisim\fR Oluşturulacak işleç sınıfının ismi (şema nitelemeli olabilir). .TP \fBDEFAULT\fR Belirtilmişse, işleç sınıfı kendi veri türü için öntanımlı hale gelir. Bir veri türü ve indeksleme yöntemi için en fazla bir işleç sınıfı öntanımlı olabilir. .TP \fIveri_türü\fR İşleç sınıfının kullanılacağı sütunun veri türü. .TP \fIindeksleme_yöntemi\fR İşleç sınıfının kullanılacağı indeksleme yönteminin ismi. .TP \fIstrateji_numarası\fR İşleç sınıfı ile ilgili bir işleç için indeksleme yönteminin strateji numarası .TP \fIişleç_ismi\fR İşleç sınıfı ile ilgili bir işlecin ismi (şema nitelemeli olabilir). .TP \fIişleç_türü\fR Bir işlecin terim veri türü ya da türleri. İşleç tekterimli ise bunu belirtmek için \fBNONE\fR. İşleç veri türü işleç sınıfının veri türü ile aynıysa belirtilmeyebilir. .TP \fBRECHECK\fR Belirtilmişse, bu işleç için indeks kaybolmuş demektir ve dolayısıyla alınan satırlar, indeks kullanılarak doğrulamak için ve dolaylı olarak aslında bu işlecin yeterlik deyimine sokulmasını sağlamak için yeniden sınanmalıdır. .TP \fIdestek_numarası\fR İşleç sınıfı ile ilişkili bir işlev için indeksleme yönteminin destek yordamı numarası. .TP \fIişlev_ismi\fR İndeksleme yönteminin işleç sınıfı için destek yordamı olan işlevin ismi (şema nitelemeli olabilir). .TP \fIarg_türü\fR İşlev argümanlarının veri türleri. .TP \fIsaklama_türü\fR Aslında indekste saklanan verinin türü. Normalde, bu sütun veri türü ile aynıdır, ama bazı indeksleme yöntemleri farklı bir tür kullanımına izin verir (şimdilik sadece GiST). İndeksleme yöntemi farklı bir türün kullanımına izin vermiyorsa, \fBSTORAGE\fR deyimi kullanılmamalıdır. .PP \fBOPERATOR\fR, \fBFUNCTION\fR ve \fBSTORAGE\fR deyimleri herhangi bir sırada belirtilebilir. .SH EK BİLGİ İşleçler SQL işlevleri tarafından tanımlanmamalıdır. Bir SQL işlevi çağrılan sorgu içinde satıriçi işlev gibidir ve eniyileyicinin bu sorgunun bir indeksle eşleştiğini saptamasını engelleyecektir. .SH ÖRNEKLER Aşağıdaki örnekte, _int4 (int4 dizisi) türü için bir GiST indeksi işleç sınıfı tanımlanmaktadır. Tam bir örnek için contrib/intarray/ dizinine bakınız. .nf CREATE OPERATOR CLASS gist__int_ops \ DEFAULT FOR TYPE _int4 USING gist AS \ OPERATOR 3 &&, \ OPERATOR 6 = RECHECK, \ OPERATOR 7 @, \ OPERATOR 8 ~, \ OPERATOR 20 @@ (_int4, query_int), \ FUNCTION 1 g_int_consistent (internal, _int4, int4), \ FUNCTION 2 g_int_union (bytea, internal), \ FUNCTION 3 g_int_compress (internal), \ FUNCTION 4 g_int_decompress (internal), \ FUNCTION 5 g_int_penalty (internal, internal, internal), \ FUNCTION 6 g_int_picksplit (internal, internal), \ FUNCTION 7 g_int_same (_int4, _int4, internal); .fi .SH UYUMLULUK \fBCREATE OPERATOR CLASS\fR bir PostgreSQL oluşumudur. SQL standardında \fBCREATE OPERATOR CLASS\fR diye bir deyim yoktur. .SH İLGİLİ BELGELER \fBALTER OPERATOR CLASS\fR [alter_operator_class(7)], .br \fBDROP OPERATOR CLASS\fR [drop_operator_class(7)]. .SH ÇEVİREN Nilgün Belma Bugüner , Nisan 2005