.NET Uzbekistan
  • .NET Uzbekistan
  • C# / .NET
    • .NET ga xush kelibsiz
    • .NET bilan bog'liq mavhumliklardan qochish
    • .NET asoslari
      • MSIL
      • Memory Management
        • Stack & Heap
      • CLR
    • Basics
      • Starter (boshlang'ich)
        • Java vs C#
        • C# Tarixi
        • Kirish
        • Visual Studio 2019
        • O'zgaruvchilar
        • Ma'lumot turlari
        • Operatorlar
        • Kalit so'zlar
        • ReadLine
        • If-else
        • Switch
        • Math sinfi
        • For sikl operatori
        • While sikl operatori
        • Do-While sikl operatori
        • Foreach sikl operatori
        • Break
        • Continue
        • Goto
        • Kommentlar
      • Essential (muhim)
        • Funksiya
        • Funksiyani qiymat orqali chaqirish
        • Funksiyada Ref kalit so'zidan foydalanish
        • Funksiyada Out parametri
        • Massiv
        • Funksiyalarda massivdan foydalanish
        • Ko'p o'lchamli massiv
        • Parametrlar
        • Array sinfi
        • CMD argumentlari
        • Obyekt va Class lar
        • Konstruktor
        • Obyektni ishga tushiruvchilar
        • Destructor
        • this
        • static
        • Struct
        • Enum
        • Property va Field lar
        • Vorislik
        • Overload (Qayta yuklash)
        • Override (Qayta yozish)
        • Base
        • Polimorfizm
        • Sealed
        • Interface
        • Modifikatorlarga ruxsat berish
        • Inkapsulatsiya
        • Abstrakt class va funksiyalar
        • String
        • StringBuilder
        • String Intern Pool
        • Exception Handling
        • try/catch
        • finally
      • Professional
        • To'plamlar
          • List
          • ArrayList
          • LinkedList
          • SortedList
          • Dictionary
          • HashTable
          • Stack
          • Queue
        • Tuple
        • ValueTuple
        • Delegatlar
          • Func delegati
          • Action delegati
          • Predicate delegati
          • Anonim metodlar
        • Hodisalar
        • Extension metodlar
        • Stream I/O
          • StreamWriter
          • StreamReader
          • MemoryStream
        • File va Directory
          • FileInfo
          • DirectoryInfo
        • MultiThread va Parallel dasturlash
        • Asinxron dasturlash
        • XML Document bilan ishlash
    • LINQ asoslari
      • Average
      • LINQ qanday ishlaydi?
      • LINQ query yozish usullari
      • IEnumerable va IQuerable
      • LINQ operatorlari
      • Select
      • SelectMany
      • Filterlash operatorlari
      • Where
      • OfType
      • Saralash operatorlari
      • OrderBy va OrderByDescending
      • ThenBy va ThenByDescending
      • Reverse
      • Miqdor operatorlari
        • All
        • Any
        • Contains
        • Min
        • Max
      • Set operatsiyasi
        • Distinct
        • Except
        • Intersect
        • Union
      • Bo'lim operatorlari
        • Take
        • TakeWhile
        • Skip
        • SkipWhile
      • Join operatorlari
        • Inner Join
        • Group Join
        • Left Join
      • Element operatsiyalari
        • ElementAt
        • First va FirstOrDefault
        • Last va LastOrDefault
        • Single va SingleOrDefault
    • ORM
      • ADO.NET
      • Dapper
      • Entity Framework
        • Entity Framework Approaches(usullar)
          • Model First Approach
          • Database First Approach
          • Code First Approach
        • Query yozish usullari(Entity Framework)
          • LINQ to SQL
          • Entity SQL
          • Native SQL
        • Entity Framework Core
    • Qo'shimcha sinflar
      • System.Text
        • Encoding
      • System
        • Int32
        • Random
        • DateTime
        • TimeSpan
      • System.Reflection
    • .NET Dasturchi
      • Clean Arxitektura
        • Clean Kod
        • Dizayn Tamoyillari
          • SOLID
            • Yagona Mas'uliyat Tamoyili(SRP)
            • Ochiq Yopiq Tamoyili(O/CP)
            • Liskovning Almashtirish Tamoyili(LSP)
            • Interfeysga ajratish tamoyili(ISP)
            • Qaramlik Inversiya Tamoyili(DIP)
          • DRY
          • KISS
          • YAGNI
        • Dizayn Patternlar
          • Factory Method
          • Abstract Factory
          • Builder
          • Prototype
          • Singleton
          • Adapter
          • Bridge
          • Composite
          • Decorator
          • Façade
          • Flyweight
          • Proxy
          • Chain of Responsibility
          • Command
          • Interpreter
          • Iterator
          • Mediator
          • Memento
          • Observer
          • State
          • Strategy
          • Visitor
          • Template Method
      • Git / Github
      • Muhim terminlar
      • Postman
      • CLI
        • CMD savodxonligi
      • API dan foydalanish
      • WCF
      • Refactor .NET application
      • Unit Test
      • TDD
      • TFS
    • Desktop Dasturlash
      • WPF (Windows Presentation Foundation)
        • WPF ga kirish
          • WPF ning ustunliklari
          • WPF da dastur
          • WPF arxitetkturasi
          • Klasslar iorarxiyasi
        • XAML
          • XAML asoslari
          • XAML orqasida kod
          • XAML xususiyatlari
          • XAML belgilash kengaytmalari
          • Biriktirilgan xususiyatlar
          • XAML da hodisalar
          • XAML da nomlar fazosi
        • WPF ilovasini tuzish
          • Komponovka
          • StackPanel
          • WrapPanel
          • DockPanel
          • Grid
          • GridSplitter
          • Umumiy o'lchamli guruhlar
          • Canvas
          • LnkCanvas
          • Komponovkaga misollar
        • Bog'liqlik xususiyatlari (Dependency property)
          • Bog'liqlik xususiyatlari
          • Bog'liqlik xususiyatlarining roli
          • Bog'liqlik xususiyatlarining aniqlanishi
          • Bog'liqlik xususiyatlarini ishlatish
        • Marshrutlangan hodisalar (Routed Events)
          • Routed Events
          • Bubble Events
          • Direct Events
          • Tunneling Events
        • Qo'shimcha ma'lumotlar
          • WPF ga kirish
          • WinForm va WPF
          • Salom WPF
          • XAML nima?
          • Hodisalar
          • WPF oynasi
          • App.xaml
          • Resurslar
          • Argument berish
          • Son va Vaqtni Formatlash
          • TextBlock elementi – Inline formatlash
          • Label elementi
          • Textbox elementi
      • WinForm (Windows Form)
        • 1-dars. Forma yaratish
        • 2-dars. Muhit bilan tanishish
        • 3-dars. Formaga komponentalar joylashtirish
        • 4-dars. Xodisa(Event)larni boshqarish
        • 5-dars. Dasturni ishga tushurish
      • UWP (Universal Windows Platform)
      • Xamarin
    • Web Dasturlash
      • ASP.NET Core asoslari
        • ASP.NET Core haqida
        • Loyihalar turlari
        • ASP.NET Core dasturlarini hosting qilish
        • Middleware tushunchasi
        • Middleware bilan amaliyot
        • Statik fayllar bilan ishlash
        • Dependency Injection
        • Developer Exception Page
      • ASP.NET Core Web API
        • Web API ga kirish
        • Swagger nima?
        • Http metodlar
        • ActionResult
        • CORs
        • Security (JWT)
        • Swagger ni sozlash
        • Filter va atributlar
        • Configuration va middleware
        • Logging
        • Mapping (AutoMapper)
        • SignalR
        • Keshlash
      • ASP.NET Core MVC
        • MVC nima?
        • ASP.NET Core MVC haqida qisqacha
        • Loyiha strukturasi
        • Controller
        • View
        • Model
        • View larni aniqlash yo'llari
        • Controller dan view ga ma'lumot uzatish
        • ViewBag va ViewData
        • Strongly typed View
        • Layout view haqida
        • ViewStart va ViewImports fayllari haqida
        • Marshrutizatsiya (routing)
        • Tag Helpers
          • Anchor Tag Helper
          • Image Tag Helper
          • Environment Tag Helper
        • Tekshiruv qoidalari (Validation rules)
      • MicroServices
    • Mobile Dasturlash
      • Xamarin.Android
      • Xamarin.IOS
      • Xamarin.Forms
    • Game Dasturlash
      • Unity Starter (boshlang'ich)
      • Unity Advanced (rivojlangan)
    • Internet of Things
    • Machine Learning
    • Telegram Bot
      • Kirish
        • Telegram bot bilan tanishuv
        • ASP.NET Core da birinchi telegram bot
      • Starter
        • Xabar turlari va xabar yuborish
          • Matnli xabarlar bilan ishlash
          • Rasm & Sticker
          • Audio & voice
          • Video & Video Note
          • Dokument fayllar
          • Polls
          • Contact , Location, Venue
          • Album(Media Group)
      • Essential
        • Reply - Markup
          • ReplyKeyboardMarkup, KeyboardButton
          • InlineKeyboardMarkup, InlineKeyboardButton
      • Advanced
        • Deployment
    • Class Library
    • Intervyu savollari
      • C# / .NET asoslari
  • Database
    • MS SQL Server
      • SQL Server sintaksisi
      • Ma'lumot turlari
      • Select
    • PostgreSQL
      • Basic
        • Kirish
        • PostgreSQL tarixi
        • Muhitni sozlash (PgAdmin)
        • Sistaksis
        • Ma'lumot turlari
        • Create Database
        • Select Database
        • Drop Database
        • Create Table
        • Drop Table
        • Scheme
        • Insert so'rovi
        • Select so'rovi
        • Operatorlar
        • Ifodalar
        • Where
        • Where
        • And va Or
        • Update so'rovi
        • Delete so'rovi
        • Like
        • Limit
        • Order By
        • With
        • Having
        • Distinct
      • Advance
        • Constraint (cheklov) lar
        • Join lar
          • Cross join
          • Inner join
          • Left join
          • Right join
          • Full join
        • Union
  • Roadmap
    • Roadmap for .NET developers
    • Roadmap for Azure developers
Powered by GitBook
On this page
  • NOT NULL:
  • UNIQUE:
  • PRIMARY KEY:
  • FOREIGN KEY:
  • CHECK:
  • EXCLUDE:

Was this helpful?

  1. Database
  2. PostgreSQL
  3. Advance

Constraint (cheklov) lar

Muzaffar Nurillayev

Dasturlash sohasida hamma narsa aniqlik asosida qurilgan, ya'ni ma'lum bir chegaradan chiqib ketsak noaniqlik kelib chiqadi Compile-time yoki Run-time errorlar kelib chiqadi va bu bilan biz ishlatyotgan texnologiya bizga o'zi chizib qo'ygan aniq o'lchovlar va qadriyatlarni eslatib qo'yadi.

Bu bir tomondan o'zimizga juda foydali, albatta tartib bor joyda natija kutilganidek bo'ladi.

Masalan, int turidagi o'zgaruvchiga string turidagi ma'lumotni o'zlashtirib bo'lmaydi, boolga decimalni va hokazo.

Database bilan ishlash ham xuddi shunga o'xshaydi va siz allaqachon o'z database'laringizda ma'lum cheklovlar yaratib bo'lgansiz. Ya'ni har doim table yaratyotganda biz uning column (ustunlari) qanaqa turdagi ma'lumot saqlashini belgilab berganmiz. Bu ham bir cheklovdir ya'ni endi ushbu ustunlarga umuman boshqa turdagi ma'lumotni saqlash imkonsizdir.

Bulardan tashqari qo'shimcha cheklovlar ham kirita olamiz. Bu database'dagi ma'lumotlarning aniqligi va ishonchliligini ta'minlaydi.

Ikki xil darajadagi cheklovlar mavjud:

  • Ustun darajasidagi;

  • Table darajasidagi;

Ustun darajasidagi cheklovlar faqat bitta ustunga qo'llaniladi, jadval darajasidagi cheklovlar esa butun jadvalga qo'llaniladi. (masalan, ustun uchun ma'lumotlar turini belgilash aynan o'sha ustunga tegishli va ustun darajasidagi cheklov).

Quyida PostgreSQL'da keng tarqalgan cheklovlar:

  • NOT NULL - ustun NULL qiymatiga ega bo'lmasligini ta'minlaydi.

  • UNIQUE - ustundagi barcha qiymatlar takrorlanmas bo'lishini ta'minlaydi.

  • PRIMARY KEY - ma'lumotlar bazasi jadvalidagi har bir qatorni/yozuvni o'ziga xos bo'lishini belgilaydi.

  • FOREIGN - boshqa jadvallardagi ustunlar bilan bog'liqliligini tekshiradi.

  • CHECK - ustundagi barcha qiymatlar ma'lum shartlarga javob berishini ta'minlaydi.

  • EXCLUSION cheklovi – EXCLUDE cheklovi belgilangan operator(lar) yordamida belgilangan ustun(lar) yoki ifoda(lar)dagi ikkita satr solishtirilsa, bu taqqoslashlarning hammasi ham TRUE qiymatini qaytarmasligini ta’minlaydi (batafsil tushuntiraman)

NOT NULL:

Biz table'ga ma'lumot qo'shyotgan paytimizda faqat ma'lum birlariga qo'shsak qolganlarni by default NULL bo'ladi va xatolik bermaydi. Lekin biz buni xohlamasak va o'sha ma'lumotni kiritishni majburiy qilib qo'ysak endilikda biz table'ga ma'lumot qo'shyotganda ma'lum bir belgilangan ustunlarda qiymat bo'lishi majburiy bo'ladi.

CREATE TABLE student(
   id SERIAL PRIMARY KEY,
   name VARCHAR(50) NOT NULL,
   age INT NOT NULL,
   address VARCHAR(50),
);

Bu table'da name va age ustunlariga qiymat berish majburiy, address'ga qiymat berish yoki bermaslik ixtiyoriy.

UNIQUE:

Bu cheklov ma'lum bir ustunda bir xil qiymatlarga ega bo'lishiga yo'l qo'ymaydi.

CREATE TABLE student1(
   id SERIAL PRIMARY KEY,
   name VARCHAR(50) NOT NULL,
   username VARCHAR(50) NOT NULL UNIQUE,
   address VARCHAR(50),
);

Endi student1 table'ga ikkita bir xil username'ga ega ma'lumot qo'sha olmaymiz.

PRIMARY KEY:

Bu cheklovning ustun darajasidagi vazifasi yuqoridagi UNIQUE bilan bir xil, lekin bu cheklov bitta jadval uchun faqat 1 dona bo'ladi ya'ni student1'da bir vaqtning o'zida username'ni ham, name'ni ham UNIQUE qilish mumkin, lekin 1 ta ustunni PRIMARY KEY qildikmi endi boshqasini bunaqa qilolmaymiz.

CREATE TABLE student1(
   id SERIAL PRIMARY KEY,
   name VARCHAR(50) PRIMARY KEY,
   username VARCHAR(50) NOT NULL UNIQUE,
   address VARCHAR(50)
);

Bunaqa so'rov xatodir va bizga bitta table'da faqat bitta PRIMARY KEY bo'lishini anglatadi.

FOREIGN KEY:

Bu cheklov ustundagi qiymatlar boshqa jadvalning qaysidir qatorida ko'rsatilgan qiymatlarga mos kelishi kerakligini bildiradi. Ya'ni ikkita jadval bog'liqlik bo'yicha qiymat qo'sha olamiz faqat va ishlatish uchun references kalit so'zidan foydalanamiz.

CREATE TABLE course(
   id SERIAL PRIMARY KEY,
   name VARCHAR(50) NOT NULL UNIQUE
);

CREATE TABLE student2(
   id SERIAL PRIMARY KEY,
   name VARCHAR(50),
   username VARCHAR(50) NOT NULL UNIQUE,
   address VARCHAR(50),
   course_id INT references course(id)
);

Bu yerda student2 table'ga qiymat qo'shyotgan payt course_id mavjud bo'lgan kursniki bo'lishi kerakligi tekshiriladi. Agar mavjud bo'lmagan kursning id'sini qo'shadigan bo'lsak xatolik yuzaga keladi.

CHECK:

Bu cheklov orqali ma'lum filter qo'yib o'shandan o'ta olsa qo'shilishini belgilab beramiz, ma'lumot kelyotganda qo'shish paytida tekshirib olamiz va shartni qanoatlantirsa qo'shamiz.

CREATE TABLE student3(
   id SERIAL PRIMARY KEY,
   name VARCHAR(50),
   username VARCHAR(50) NOT NULL UNIQUE,
   age int CHECK(age > 5),
   course_id INT references course(id)
);

Endilikda biz table'ga age 6 dan kichik kirita olmaymiz.

EXCLUDE:

Bu cheklov table darajasida amal qiladi. Va o'ziga true yoki false qaytaradigan statementlar qabul qiladi. Va shu statementlardan eng kamida bittasi false qaytarishi kerak.

CREATE TABLE student4(
   id SERIAL PRIMARY KEY,
   name VARCHAR(50),
   username VARCHAR(50) NOT NULL UNIQUE,
   age int CHECK(age > 5)
   EXCLUDE using gist
   (name =, username !=)
);

Bunda agar oldingiz ma'lumotlar bilan solishtirganda name'lar teng bo'lsa username'lar teng bo'lmasligi kerak yoki username'lar teng bo'lsa name'lar teng bo'lmasligi kerak yoki ikkovi ham teng bo'lmasligi kerak. Ikkovi bir vaqtning o'zida teng bo'lsa xatolik yuzaga keladi.

Tepadagi query ishlashi uchun avvalo extension qo'shib olamiz:

 CREATE EXTENSION btree_gist;

Cheklovni olib tashlash ham mumkin:

ALTER TABLE table_name DROP CONSTRAINT cheklov;
PreviousAdvanceNextJoin lar

Last updated 2 years ago

Was this helpful?