SQL Kod ile Tablo Oluşturma



Benzer belgeler
SORGULAR. Öğr.Gör.Volkan Altıntaş

VERİTABANI. SQL (Structured Query Language)

SQL Komutları (2) Uzm. Murat YAZICI

Bu işleçlerin dışında, aşağıda belirtilen karşılaştırma işleçlerinden de yararlanılır.

BİLİŞİM TEKNOLOJİLERİ

BİLİŞİM TEKNOLOJİLERİ

VERİTABANI ve YÖNETİMİ

Veritabanı. SQL (Structured Query Language)

TEMEL SQL SORGU ÖRNEKLERİ. Yukarıdaki sorguyu yazıp çalıştırdığımızda db_market adında bir veritabanı oluşturulur.

Veri Tabanı Yönetim Sistemleri Bölüm - 6

Veri Tabanı SQL Server ve Management Studio kurulum linkleri:

VERĐTABANI YÖNETĐM SĐSTEMLERĐ

Veri Tabanı Tasarım ve Yönetimi

ÜNİTE NESNE TABANLI PROGRAMLAMA I. Uzm. Orhan ÇELİKER VERİTABANI SORGULARI İÇİNDEKİLER HEDEFLER

SQL'e Giriş. SELECT Deyimi. SQL Komutları. Yardımcı Deyimler

VERİTABANI Veritabanı Yönetimi

Aşağıdaki şemaya dikkat edin. Sorgulamalarımızı genellikle bu şemaya göre yapacağız.

ACCESS PLATFORMUNDA SQL

ÜNİTE NESNE TABANLI PROGRAMLAMA I. Uzm. Orhan ÇELİKER VERİTABANI SORGULARI İÇİNDEKİLER HEDEFLER

Çok tablolu sorgulamalar

SQL (Structured Query Language)

SQL'e Giriş. SELECT Deyimi. SQL Komutları. 1. DDL (Data Definition Language - Veri Tanımlama Dili)

BMB202. Veritabanı Yönetimi Ders 6. SQL. Erdinç Uzun NKÜ Çorlu Mühendislik Fakültesi Bilgisayar Mühendisliği Bölümü

YAPISAL SORGULAMA DİLİ (SQL)

SQL (Structured Query Language)

SUNGURLU MESLEK YÜKSEKOKULU 5. T-SQL-2

Mysql Veritabanı Komutları

VERİ TABANI YÖNETİM SİSTEMLERİ I

Aşağıdaki tabloyu inceleyin. Sorgulama işlemlerini bu tabloya göre yapacağız.

Veritabanı Yönetim Sistemleri (Veritabanı Tasarımı) SQL (Structured Query Language)

VERĐTABANI YÖNETĐM SĐSTEMLERĐ

SQL veri tabalarına erişmek ve onları kullanmak için geliştirilmiş bir lisandır.

Aşağıdaki şemaya dikkat edin. Sorgulamalarımızı genellikle bu şemaya göre yapacağız.

Maltepe Üniversitesi Bilgisayar Mühendisliği Bölümü Veri Tabanı ve Yönetimi (BİL 301)

VERİTABANI Veritabanı Sorgulama

BMB202. Veritabanı Yönetimi Ders 5. İlişkisel Cebir ve SQL. Erdinç Uzun NKÜ Çorlu Mühendislik Fakültesi Bilgisayar Mühendisliği Bölümü

Data Programming SQL Language. Elbistan Meslek Yüksek Okulu Bahar Yarıyılı

Yukarıdakilerden hangileri DML (Data Manipulation Language) ile gerçekleştirilir?

BİLİŞİM TEKNOLOJİLERİ

Bilgisayar Uygulamaları. MySql

Genel Kavramlar. Bilgisayar ortamında işlenebilecek durumda bulunan kayıtlar. Birbiri ile ilişkili veriler topluluğu ve veriler arası ilişkiler

Tablolar Arası İlşikiler ve Alan Özellikleri Siparis.musteri_no musteri.musteri_no Siparis.urun_kodu musteri.urun_kodu

Veri Tabanı Yönetim Sistemleri Bölüm - 7

Birden Çok Tabloda Sorgulama (Join)

Veri tabanı içinde bulunan tablolardakibazı sütunlarda bulunan bilgilerin, herkes tarafından görülmesi istenmeyebilir.

Bilgisayar Teknolojileri Bölümü Bilgisayar Programcılığı Programı. Öğr. Gör. Cansu AYVAZ GÜVEN

Lıke Joker Karakterler, Is [not] Null, Order By, Group By, As

İNTERNET PROGRAMCILIĞI HAFTA. MYSQL ile VERİTABANI İŞLEMLERİ - 1. Hazırlayan Fatih BALAMAN. İçindekiler. Hedefler. Veritabanı Oluşturma, Silme

MİRSİS BİLGİ TEKNOLOJİLERİ LTD. ŞTİ. MİCROSOFT SQL SERVER VERİTABANI VE SORGULARI

08221 Veri Tabanı II. Elbistan Meslek Yüksek Okulu GÜZ Yarıyılı. Hafta IV. Öğr. Gör. Murat KEÇECĠOĞLU

Veri Tabanı Yönetim Sistemleri Bölüm - 4

Veri Tabanı Programlamaya Giriş

Bölüm 4: DDL Veri Tanımlama Dili

Bilgisayar Teknolojileri Bölümü Bilgisayar Programcılığı Programı. Öğr. Gör. Cansu AYVAZ GÜVEN

Veritabanı Tasarımı. Sütun Değerlerini Güncelleme ve Satırları Silme

Tablolar Arası İlşikiler ve Alan Özellikleri. Şekil 1. Magaza veritabanının tabloları ve tablolar arasındaki ilişkiler

T.C GAZİ ÜNİVERSİTESİ BİLİŞİM ENSTİTÜSÜ YÖNETİM BİLİŞİM SİSTEMLERİ ANA BİLİM DALI MS SQL KOMUTLARI VE MS SQL KOMUTLARI İLE İLGİLİ UYGULAMALAR

EBE-368 Veri Tabanı Yönetim Sistemleri SQL

Veritabanı Tasarımı. Kartezyen Çarpım ve Join İşlemleri

5 SQL- Yapısal Sorgulama Dili. Veritabanı 1

20461C Querying Microsoft SQL Server Modül Seviye Belirleme Testi

SQL e Giriş. Uzm. Murat YAZICI

VERĐTABANI YÖNETĐM SĐSTEMLERĐ

Like Joker Karakterler, Order By, Group By

EBE-368 Veri Tabanı Yönetim Sistemleri İlişkisel Model (The Relational Model)

Bölüm 3: DML Veri İşleme Dili

SQL Deyimleri. Öğr.Gör.Volkan ALTINTAŞ Volkanaltintas.com

DAO İLE SQL KOMUTLARI. Sql komutlarını artık veri tabanında kullanmaktan başka çaremiz yok arkadaşlar. Şimdi bu sql derslerimize başlayalım.

SQL DİĞER Deyimler ve Komutlar

Öğr.Gör.Murat KEÇECĠOĞLU. Elbistan Meslek Yüksek Okulu Bahar Yarıyılı

DML işlemleri. Elbistan Meslek Yüksek Okulu Bahar Yarıyılı May Öğr. Gör. Murat KEÇECĠOĞLU

SQL Query and Table Application

BÖLÜM- 5: BİRDEN FAZLA TABLODAN VERİ GETİRMEK

SQL'e Giriş 2. CREATE TABLE tabloadı (kolon isimleri ve veri türleri) (BOLUM_NO NUMBER, BOLUM_ADI CHAR(10));

Güz Yarıyılı MT 487 Bilgisayarda Veri Yapıları Final Çalışma Soruları

15 Aralık 2011 / Perşembe.

VERİ TABANI YÖNETİM SİSTEMLERİ I

Veri Tabanı II Alt Sorgular

SORGULAR VE ÇEŞİTLERİ II

İNTERNET TABANLI PROGRAMLAMA- 12.ders

SP_RENAMEDB eski_isim, yeni_isim VEYA SP_RENAMEDB 'eski isim', 'yeni isim'

-- işareti tek satırlık açıklamalarda kullanılır. Açıklama olarak yazılan satırın önüne konulması yeterlidir.

Nesneler üzerinde değişiklik yapmak için kullanılır. Veri tabanındaki nesnelerin oluşturulabilmesi için CREATE komutu kullanılır.

Veritabanına Uygulanması

Öğr.Gör.Murat KEÇECĠOĞLU 27 May. 28 May Elbistan Meslek Yüksek Okulu Bahar Yarıyılı

SQL PROGRAMLAMA. Bir batch, bir arada bulunan bir dizi SQL deyimidir. Batch ayıracı GO deyimidir.

VERİ TABANI ve YÖNETİMİ

IN ve NOT IN Tablodaki alan içeriklerine ulaşmak için IN deyimi kullanılır.

Emrah UYSAL 1

SQL (Structured Query Language) kendisi bir programlama dili olmamasına rağmen bir çok kişi tarafından programlama dili olarak bilinir.

BTP203 VERİTABANI YÖNETİM SİSTEMLERİ

Kişiler tablosundan AD kolonu yusuf olan tüm satırları siler. ORDER BY deyimi bir tablodan SELECT ile seçilen verileri sıralamak için kullanılır.

3. Hafta Tablo İşlemleri BPR255 Veritabanı. Bu Derste Öğrenecekleriniz: 1. Tablo İşlemleri Kısıtlamalar (Constraints)

Aşağıdaki tabloyu inceleyin. Yeni kayıt girme, var olan bir kaydı silme veya güncelleme işlemlerini bu tabloya göre yapacağız.

Veri Tabanı Hafta Dersi

Basit SQL Sorguları Veritabanından verilerin SELECT cümleleri ile alınması işlemine sorgulama denir.

Fonksiyonlar istenilen deger tipinde dönüs yapabilir. INT, VARCHAR deger döndürebileceğiniz gibi bir tablo da döndürebilirsiniz.

Veritabanı Tasarımı. Kullanıcı Erişimini Kontrol Etme

SQL TRIGGERS (Tetikleyiciler)

Transkript:

SQL Kod ile Tablo Oluşturma Aşağıdaki SQL kodları Veri tabanı hazırlama programında yazılıp çalıştırıldığı zaman PERSONEL adında bir tablo oluşturulur ve bu tablonun sütunları Personel_no, Adı, Soyadı olarak tanımlanmış olur. CREATE TABLE PERSONEL( Personel_no INT, Adı VARCHAR(15), Soyadı VARCHAR(15) ) SQL Kod ile Tablo Silme Daha önceden oluşturmuş olduğunuz bir tabloya ihtiyaç duymayıp veri tabanından silmek isteyebilirsiniz. Silme işlemini gerçekleştirmek için DROP deyimi kullanılmaktadır. DROP TABLE Tablo1 SQL Kod İle Sütun Ekleme Bir tablo oluşturduktan sonra, isteğe göre oluşturulmuş olan tabloya yeni sütunlar ekleyebilirsiniz. Tabloya yeni bir sütun eklemek için ADD COLUMN deyimi kullanılır. ALTER TABLE PERSONEL ADD COLUMN Bölümü Text(15), Cep_Telefonu INT SQL Kod ile Tablo Güncelleme Belirtilen tablodaki alanların değerlerini belirtilen ölçütlere göre değiştirmek için bir güncelleme sorgusu oluşturmak gerekir. Bunun için UPDATE deyimi kullanılır. UPDATE PERSONEL

SET Maaşı = Maaşı-0.007*Maaşı Verilerin Sınıflandırılması Veri tabanında veriyi alma işlemi sırasında satırlara birtakım sınırlamalar getirilerek tablonun tüm satırları yerine istenildiği kadarını elde etmek mümkündür. Tabloda belirli kısımları seçme işlemini gerçekleştirmek için WHERE sözcüğü kullanılmaktadır. 1 - PERSONEL tablosunda yer alan İl_kodu 34 olan kayıtları listelemek istersek komut satırı aşağıdaki şekilde olacaktır. SELECT*FROM PERSONEL WHERE İl_Kodu="34" 2 - Maaşları 2000 TL den yüksek olan çalışanları seçmeye yarar. SELECT Personel_no, Maaşı FROM Ücret WHERE Maaşı > 2000; Sıralama İşlemleri Tabloların satırlarının herhangi bir sütuna göre sıralanmasının istendiği durumlarda SELECT deyimi ORDER BY ile birlikte kullanılır. Örnekler: 1 - Alfabetik Sıraya Göre Soyadlarını Sıralama SELECT Soyadı, Adı FROM PERSONEL ORDER BY Soyadı; 2 - İl Kodlarını Azalan Şekilde Sıralama

SELECT Soyadı, İl_Kodu FROM PERSONEL ORDER BY İl_Kodu DESC, Soyadı Verileri Gruplayarak Analiz Etme Şu ana kadar incelemiş olduğumuz deyimler söz konusu tablonun tüm satırlarına uygulanmaktaydı. Bazı durumlarda bazı işlemlerin satırlar yerine gruplara uygulanması gerekmektedir. Veriler gruplara ayrılıp analiz edilir ve bu tür gruplama işlemleri için de grup fonksiyonları kullanılır. 1.Grup Fonksiyonları Tek satır fonksiyonları tablonun bir satırına uygulanıp buna karşılık gelen bir sonuç satırı elde ediliyordu. Bir grup satıra bir fonksiyonun uygulanmasının söz konusu olduğu durumlara; "çoklu satır" veya "grup fonksiyonları" adı verilir. Grup fonksiyonları tablonun tüm satırlarına uygulanabilmektedir. AVG() Bu fonksiyon, herhangi bir sütunun içerdiği sayısal değerlerin aritmetik ortalamasını hesaplamak amacıyla kullanılır. Fonksiyonun uygulandığı sütunun veri türü sayısal olmalıdır. SELECT AVG(NOTLAR) AS ORTALAMA FROM OGRENCİ SUM() Sütunların içerdiği sayısal değerleri toplamak amacıyla kullanılan fonksiyondur. SELECT SUM(NOTLAR) AS TOPLAM FROM OGRENCİ

STDEV() Standart sapma, sayısal verilerin aritmetik ortalamalardan farklarının kareli ortalaması olarak bilinir. Bu hesaplamayı yapan SQL fonksiyonu ise; STDEV() 'dir. SELECT STDEV(NOTLAR) AS St SAPMA FROM OGRENCİ VARP() Sorgunun belirtilen alanında bulunan değerler kümesiyle temsil edilen bir grubun tahmini varyansını gösterir. Varyans, sayısal değerler arasındaki değişkenliği ölçen bir kavramdır. Standart sapmanın karesi olarak bilinmektedir. SELECT VARP(MAAŞ) AS VARYANS FROM PERSONEL MAX() ve MIN() Tablodaki değerler arasında en büyük olanı bulmak için MAX(), en küçük olanını bulmak içinse MIN() ve fonksiyonları kullanılır. Örnekler: 1 - SELECT MAX(NOLAR) AS EN YÜKSEK FROM ÖĞRENCİ 2 - SELECT MİN(NOTLAR) AS EN DÜŞÜK FROM ÖĞRENCİ COUNT() Bir tablodaki kayıtların sayılması amacıyla kullanılan fonksiyondur. COUNT(*) fonksiyonu, NULLdeğerleri de içeren tüm kayıtların sayılmasını sağlar. WHERE ile birlikte kullanılırsa, bu koşula uygun tüm kayıtları sayar. COUNT(sütun) biçiminde kullanılırsa, söz konusu sütunda NULL değerler içermeyen tüm kayıtların sayılmasına neden olur.

SELECT COUNT(*) AS ÖĞRENCİ SAYISI FROM ÖĞRENCİ 2.Birden Fazla Sütuna Göre Gruplama GROUP BY kullanarak belirtilen alan listesindeki benzer değerlere sahip kayıtları tek bir kayıt olarak birleştirebilirsiniz. Yani birden fazla sütun için de gruplama yapabilirsiniz. Örnekler: 1 - PERSONEL tablosunda yer alan personellerin yaşadıkları illere göre sayısı listelemek SELECT İl_Kodu,COUNT(*) from PERSONEL GROUP BY İl_Kodu 2 - PERSONEL tablosunda yer alan toplam personel sayısını göstermek SELECT Count(*) AS Personel sayısı FROM PERSONEL; 3.Grup Koşullarının Kullanımı Grup işlemlerinin uygulanması sırasında birtakım sınırlamalar gerekebilir. Grup koşulları belirlenirken HAVING sözcüğü kullanılır. HAVING sözcüğü gruplama yaptıktan sonra kullanılır. Gruplandırmak istenilmeyen satırları dışarıda tutmak için WHERE, gruplandırılan kayıtlara filtre uygulamak için ise HAVING kullanılır.group By ifadesi Where ifadesinden sonra, Having ifadesinden önce kullanılır. Order By ifadesi ise en son kullanılır. Kayıtlar GROUP BY ile gruplandırılır ve HAVING ile de hangi kayıtların görüntüleneceği gösterilir. Ücret tablosunda Toplam maaşı 2500 den büyük olan grupları listelemek

SELECT Personel_no, Sum(Maaşı) FROM Ücret GROUP BY Personel_no HAVING Sum(maaşı) > 2500; 2. İLİŞKİLİ TABLOLAR İlişkisel veri tabanları, birbirleri ile mantıksal ilişkiler içinde olan tablolardan oluşmaktadır. Tabloları ortak olarak sahip oldukları alanlarda birleştirmek için ilişkiler kullanılır. İlişki ise bir sorguda birleştirmeyle gösterilmektedir. 1.Tabloların Birleştirilmesi Birden fazla tablodan veri almak gerektiği durumlarda tablolar arasında ilişki kurulması gerekmektedir. Bu işleme Join (birleştirme) adı verilir. Join işlemi birden fazla tabloyu birbirine bağlayıp bu tablolar üzerinde işlem yapabilmemizi sağlamaktadır.birleştirme işlemi yapabilmek için tabloların aynı değerleri içeren sütunlarının kullanılması gerekir.tablo birleştirme işlemi yapılırken birleştirmek istediğiniz duruma göre, Kartezyen birleşim, eşiti olan birleştirme veya eşiti olmayan birleştirme türlerinden uygun olanını kullanabilirsiniz. 1. Kartezyen Çarpımı İki tablo arasında birleştirme koşulunun tanımlanmadığı durumlarda Kartezyen çarpımından söz edilir. Soldaki tablonun her kaydı için, sağdaki tablodan bütün kayıtları çeker. Birleştirme koşulunun geçersiz olduğu ve birinci tablodaki tüm satırların ikinci tablodaki tüm satırlarla birleşmediği durumlarda da Kartezyen çarpım elde edilir. Ürünler tablosundaki kayıtlar ile Reyonlar tablosundaki kayıtlara Kartezyen birleşimi SELECT *FROM ÜRÜNLER, REYONLAR; 2.Eşiti Olan Birleştirme

İç birleştirme olarak da adlandırılan birleştirme türüdür. İç birleştirme bir sorguya, birleştirilen tabloların birinde yer alan satırların, birleştirilen alanlardaki verileri temel alarak, diğer tablodaki satırlara karşılık geldiğini bildirir. İç birleştirme içeren bir sorgu çalıştırıldığında, sorgu işlemlerine yalnızca, birleştirilen tabloların her ikisinde de bulunan ortak değere sahip olan satırlar eklenir. Birleştirmede yer alan her iki tablodan sadece, birleştirme alanında eşleşen satırlar döndürülmek istenildiği zaman iç birleştirme kullanılır.eşiti olan birleştirme yapılırken INNER JOIN deyimi kullanılır. REYONLAR tablosundaki tüm kayıtları çekip, bu kayıtlar ile eşleşen ÜRÜNLER tablosudaki kayıtlar listelenir. SELECT*FROM ÜRÜNLER,REYONLAR WHERE ÜRÜNLER.Grup_no=REYONLAR.Grup_no; veya SELECT*FROM ÜRÜNLER INNER JOIN REYONLAR ON ÜRÜNLER.Grup_no=Reyonlar.Grup_no; 3.Eşiti Olmayan Birleştirme Eşiti olan birleştirme sırasında bir tablodaki bir sütunun içerdiği değerler diğer tablonun ilgili sütunu ile eşleştirilip sadece eşleşen değerler birleştiriliyordu. Eşleşmeyen satırlar ise birleştirilemiyordu.eşleşmeyen satırların da birleştirilip sonuca dâhil edilmesi istenilen durumlarda Eşiti Olmayan Birleştirme kullanılmaktadır.eşiti olmayan birleştirmeler (dış birleştirmeler), eşleşmeyen kayıtların hangi tabloda olduğuna bakarak sol dış birleştirme veya sağ dış birleştirme olmak üzere iki şekilde olabilmektedir. Sol dış birleştirme oluşturmak için LEFT JOIN kullanılır. Soldaki tablodan tüm kayıtlar alınır, sağdaki tabloda eşleşen kayıtlar yazılır ve eşleşmeyen kayıtlar için NULL değer döndürülür.sağ dış birleştirme oluşturmak için RIGHT JOIN kullanılır. Sağ dış birleşimler, ilk tablonun (soldaki tablo) kayıtlarında eşleşen değer olmasa bile, iki tablodan ikincisinin (sağdaki tablo) tüm kayıtlarını içerir. Örnekler:

1 - ÜRÜNLER ve REYONLAR tablosunu RIGHT JOIN kullanarak birleştirmek SELECT* FROM ÜRÜNLER RIGHT JOIN REYONLAR ON ÜRÜNLER.Grup_no=REYONLAR:Grup_no; 2 - ÜRÜNLER ve REYONLAR tablosunu LEFT JOIN kullanarak birleştirmek SELECT* FROM ÜRÜNLER LEFT JOIN REYONLAR ON ÜRÜNLER.Grup_no=REYONLAR:Grup_no; 2.Alt Sorgular Bazı durumlarda bir sorgudan elde edilen sonuç diğer başka bir sorgu içerisinde kullanılabilmektedir. Bu tür durumlarda iç içe sorgular oluşturulmaktadır. Kullanılan iç içe sorgularda yer alan içteki sorgulara alt sorgular adı verilir. 1.Alt Sorgunun Tanımlanması Alt sorgu bir SELECT, SELECT...INTO, INSERT...INTO, DELETE veya UPDATE deyimi içinde veya başka bir alt sorguda SELECT deyiminin kullanılması ile elde edilir. Bir alt sorgu aşağıdaki bölümlerden oluşmaktadır:karşılaştırma [ANY ALL SOME] (sqldeyimi):karılaştırma, ifadeyi, alt sorgunun sonuçları ile karşılaştırmaya yarayan bir karşılaştırma işlecidir.ifade [NOT] IN (sqldeyimi): İfade, alt sorgu sonuç kümesinde aranan ifadeye verilen addır.where iki sorguyu birbirine bağlamak için kullanılmaktadır. ANY veya SOME, yapılan karşılaştırma sonucunda alt sorgu kayıtlarından herhangi bir tanesi ile eşleşen ana sorgu kayıtlarını almak için kullanılır. ALL, yapılan karşılaştırma sonucunda alt sorgu kayıtlarının tümüyle eşleşen ana sorgu kayıtlarını almak için kullanılmaktadır. IN, alt sorgudaki kayıtların değerine eşit olan ana sorgu kayıtlarını almak için kullanılır. NOT IN ise alt sorgudaki kayıtların değerine eşit olmayan ana sorgu kayıtlarını almak için kullanılır. 2.Çoklu Satır Alt Sorguları

Alt sorgudan bir satır yerine birden fazla satırın elde edildiği durumlar çoklu satır alt sorgusu olarak adlandırılır.bu tür sorgular IN, ANY, ALL gibi işleçler yardımıyla yapılabilmektedir. >ANY en azdan daha büyük, ALL en büyükten daha büyük, Örnek IN işleci: İndirim oranı %30 dan daha fazla olan tüm ürünleri göstermek SELECT * FROM Ürünler WHERE U_No IN (SELECT U_No FROM Sipariş WHERE İndirim =.30); Örnek ANY işleci: Birim fiyatı, % 30 veya daha fazla indirimle satılmış herhangi bir ürünün birim fiyatından yüksek olan tüm ürünleri göstermek SELECT * FROM Ürünler WHERE B_Fiyat > ANY (SELECT B_Fiyat FROM Sipariş WHERE İndirim >=.30); Örnek ALL işleci: Birim fiyatı, % 30 veya daha fazla indirimle satılmış tüm ürünlerin birim fiyatından yüksek olan ürünleri listelemek SELECT * FROM Ürünler WHERE B_Fiyat > ALL (SELECT B_Fiyat FROM Sipariş WHERE İndirim >=.30); 3.Tek Satır Alt Sorguları

Alt sorgudan tek satırın elde edildiği sorgulardır. PERSONEL tablosuna göre Personel numarası 10 olan personelle aynı bölümde çalışan personelin isimlerini listelemek SELECT Adı, Bölüm_no FROM PERSONEL WHERE Bölüm_no= (SELECT Bölüm_no FROM PERSONEL WHERE p_no=10); Alt sorgu sonucunda 10 numaralı personelin çalıştığı bölümün numarası, yani 200 değeri elde edilecektir. Ana sorguda ise çalıştığı bölüm numarası 200 olan kişileri sorgulamaktadır. DML SORGULARI Bir tabloya yeni bir kayıt eklemek, mevcut kayıt üzerinde değişiklik yapmak veya bir kaydı silmek istediğimiz durumlarda, Select deyimi kullanarak yapmış olduğumuz sorgulamalar işe yaramaz. DML (Data Manipulation Language) dili kullanılarak, veri tabanı tablosuna veri ekleme, silme ve güncelleme işlemleri yapılabilmektedir. 1.Tabloya Satır Ekleme İşlemi Bir tabloya bir veya daha çok satır (kayıt) eklemek için INSERT INTO deyimi kullanılır. Bu işlem Ekleme Sorgusu olarak adlandırılmaktadır. 1.INSERT Deyimi Yapısı Bir tabloya yeni veri eklemek için INSERT deyimi kullanılır. INSERT deyimi, INTO ve VALUES ifadeleri ile birlikte kullanılır ve tabloya yeni veri eklenmesi sağlanır. Tablodaki tüm alanlara değer girilecekse, tablo isminden sonra sütun isimlerinin belirtilmesine gerek yoktur. Çünkü bu tür durumda tablodaki tüm alanlara veri girişi sağlanmış olacaktır.

Sütun ismi belirtmeden kullanımı: INSERT INTO tablo VALUES (değer1, değer2 ) Sütun ismi belirterek kullanımı: INSERT INTO tablo (sütun1, sütun2 )VALUES (değer1, değer2 ) Mevcut kayıtlarda bulunan tek alanlardaki verileri değiştirmek için ekleme sorgusu yerine güncelleştirme sorgusu kullanılmaktadır. Ekleme sorguları sadece veri satırları eklemek için kullanılır. Örnekler: 1 - Öğrenci tablosuna bir kayıt eklemek istiyorsak INSERT INTO PERSONEL VALUES(119,'AHMET','ARABACI','ANKARA','1995'); 2 - Öğrenci tablosunda sadece Doğum Yeri ve Doğum Tarihi alanlarına veri girişi yapmak istiyorsak INSERT INTO PERSONEL(Doğum_Yeri, Doğum_Tarihi) VALUES (Çorum, '2012'); 2.NULL Değer Ekleme Oluşturduğunuz tablodaki bir veya birden fazla alana Null değer girilmesi gerekebilir. Bunun için kullanılan iki yol mevcuttur. Birinci yöntem ile INSERT INTO deyimi içerisinde Null değer alacak olan alanlar yazılmaz. INSERT INTO PERSONEL(Doğum_Yeri, Doğum_Tarihi) VALUES ('Ankara', 1995); Diğer yöntem ise aşağıdaki şekilde uygulanır;

INSERT INTO PERSONEL(Öğrenci_no, Adı, Soyadı, Sınıfı, Doğum Yeri,Doğum_Tarihi) VALUES (119, Ahmet, Arabacı, NULL, NULL) Bu yöntem ile boş bırakılmak istenilen alanlara NULL şeklinde bir atama yapılmıştır. 3.Fonksiyonların Kullanımı INSERT INTO içerisinde fonksiyonlar da kullanılabilmektedir. Örneğin Öğrenci tablosuna yeni bir kayıt eklerken Giriş_tarihi isimli alana o günün tarih ve zaman bilgisini eklemek istiyorsak komut satırı aşağıdaki gibi olacaktır. INSERT INTO Öğrenci(Öğrenci_no,Sınıfı,Giriş_Tarihi)VALUES(119,'AND 11-A',now); 4.Bir Diğer Tablodan Satır Kopyalama INSERT işlemini kullanarak bir tabloda bulunan kayıtları istediğiniz diğer bir tabloya kopyalayabilirsiniz. Bu işlem için yapılması gereken Values yerine Select ifadesini kullanmaktır. Dershaneye Gidenler tablosunda tek bir kayıt bulunmaktadır. Bu kaydı Öğrenci tablosuna kopyalamak için gerekli olan komut satırı aşağıdaki gibi olacaktır. INSERT INTO Öğrenci(Öğrenci_no, Adı, Soyadı, Sınıfı) SELECT Öğrenci_no, Adı, Soyadı, Sınıfı FROM Dershaneye_Gidenler 2.Tablodaki Verileri Güncelleme Bir tabloda bulunan kayıt veya kayıtların istenildiği zaman değiştirilmesi mümkündür. Tablolarda güncelleme işlemini gerçekleştirmek için UPDATE komutu kullanılır. SET ifadesi ile güncellenecek alanlar ve bu alanların alacakları yeni değerler belirlenir. WHERE deyimi ile de verilerin güncelleştirilmesi için koşul belirlenir. Eğer WHERE ifadesi ile bir koşul belirlenmezse tablodaki tüm kayıtlar güncellenmiş olacağından WHERE kullanmaya dikkat edilmesi gerekmektedir.

Örnekler: 1 - Öğrenci tablosunda yer alan 30 numaralı öğrencinin 35 olan İl_Kodu bilgisini 06 olarak değiştirmek isteyelim. UPDATE PERSONEL SET İl_Kodu = '06' WHERE Personel_no = 30 2 - Öğrenci tablosundaki tüm illerin kodunu 06 olarak değiştirmek istersek UPDATE PERSONEL SET İl_Kodu = '06' WHERE Personel_no 3.Tablolardan Veri Silme Bir tabloda bulunan kayıt veya kayıtların istenildiği zaman silinmesi mümkündür. Tablolarda silme işlemini gerçekleştirmek için DELETE komutu kullanılır. DELETE komutu kullanılırken FROM eki ile birlikte tablo ismi yazılarak hangi tablodan veri silinmesi istendiği belirtilebilir. WHERE deyimi ile de verilerin silinme koşulu belirlenir. Eğer WHERE ifadesi ile bir koşul belirlenmezse tablodaki tüm kayıtlar silineceğinden WHERE kullanmaya dikkat edilmesi gerekmektedir. Örnekler: 1 - Öğrenci tablosunda yer alan 30 numaralı öğrenciyi silmek için DELETE FROM PERSONEL WHERE Personel_no = 30 2 - Öğrenci tablosunda bulunan tüm kayıtlar silinecek DELETE FROM ÇALIŞANLAR 3 - Öğrenci tablosunda Sınıfı AND 11-A ve Ankara olanlar dışındaki diğer kayıtların silinmesini istersek;

DELETE FROM Öğrenci WHERE Sınıfı NOT IN ("AND 11-A", "Ankara") www.devinyeri.com