PHP'de MSSQL Bağlantısı ve Kullanımı
7 Ekim Cuma ´05
PHP ve Pear Dökümanları
Dikkat: Bu yazının yazılma tarihinim üzerinden en az 60 gün geçmiş. İçerisindeki bilgiler güncelliğini yitirmiş olabilir. Yorumları ve güncellemeleri göz önünde bulundurarak yazıyı takip ediniz.
Method
MSSQL'e bağlanıp işlem yapabilmek için php'de kullanabileceğimiz 2 farklı teknik var. İlki mysql kütüphanesine çok benzeyen mssql kütüphanesi, diğeri ise ODBC kullanarak. mssql kütüphanesi ile mysql kütüphanesi arasında hiçbir fark yok, sadece mysql yerine mssql yazıp bütün işlerinizi yapıyorsunuz. Diğer teknik ise ODBC kullanarak bağlanmak.Neden ODBC?
Çünkü odbc Microsoft'un kendi bağlantı protokoludür. Sunucu üzerinde kurulan küçük bir program ile mssql sunucunuza odbc üzerinden rahatlıkla erişebiliriz. PHP'de mssql'in kendi kütüphanesindense bu kütüphaneyi kullanmanızı öneririm. Bazı veritabanlarında Türkçe tablo adları, alan adları kullanılabiliyor. Bu tarz veritabanlarında php'deki mssql kütüphanesi sorun çıkarıyor malesef. ODBC kullanarak kolayca bu problemleri aşabiliriz.Neler Gerek?
PHP'de Windows sunucuda odbc kütüphanesi için herhangi bir ekstra extension kurulu olması gerekmiyor, ancak *nix tabanlı (unix, linux, macos) sunucularda ise http://www.unixodbc.org/, http://www.minisoft.com/pages/middleware/ODBC_UNIX/odbc32_UNIX.html sayfalarına bakılması gerekebilir. Açıkcası linux sunucu üzerinde çalıştırmayı denemedim, tavsiye de etmem.Nasıl Olacak Bu İş?
Şimdi mysql'deki bağlantı yapısına yakın bir yapı kullanacağız.
$baglanti = odbc_connect('DRIVER={SQL Server};SERVER=host;DATABASE=veritabani','kadi','sifre');
$baglanti değişkenine $baglanti = mysql_connect'de atadağımız gibi bir bağlantı kaynağı atıyoruz. Ancak bu fonksiyonda CONN String olarak tanımlanan cümlecik ile veritabanını doğrudan bildiriyoruz. Geriye SQL'leri işletmek kalıyor.
// sorguyu isletelim
$sorgu = odbc_exec($baglanti,"select * from tablo");
// verileri alip isleyelim
while( $bilgi = odbc_fetch_array($sorgu) ){
print_r($bilgi);
}
İşte bu kadar kolay. Genel olarak fonksiyonlar aynı, başına mysql yerine odbc geliyor o kadar. Sorguarımızı ise odbc_exec($baglanti_degiskeni,"sorgu"); şeklinde veriyoruz. Geri kalan kısımları mysql'de bildiğiniz tekniklerle halledebiliyoruz. ODBC fonksiyonları bazı fonksiyonlarda aynı bazılarında da oldukça farklı.http://php.net/odbc adresinden php'nin odbc fonksiyonları hakkında bilgi edinebilir.
Daha ayrıntılı bir döküman olarak şu adreslere bakabilirsiniz :
- http://phplens.com/phpeverywhere/node/view/9
- http://www.zend.com/zend/tut/odbc.php?article=odbc&kind=t&id=3416&open=1&anc=0&view=1
- http://www.phpdig.net/ref/rn63.html (güzel, örnekli bir referans)
Hazırlayan : Mehmet Fatih YILDIZ
Yorumlar
6 Ekim Pazartesi ´08 10:07
6 Mart Cuma ´09 14:23
16 Aralık ÇarÅŸamba ´09 07:30
21 Mayıs Cuma ´10 11:03
25 Ekim Pazartesi ´10 19:43
15 Mart Salı ´11 11:36
24 Mart Cumartesi ´12 02:39
12 Nisan PerÅŸembe ´12 06:28
28 Mayıs Pazartesi ´12 00:36
24 Eylül Pazartesi ´12 04:08
4 Aralık Salı ´12 12:47
28 Mart PerÅŸembe ´13 10:24