Bloğa geri dön

Ubuntu 20.04 üzerinde PHP ile MySQL Kullanarak Çoklu Kayıtları Görüntülemek için Sayfalandırma Uygulama

Ubuntu 20.04 üzerinde PHP ile MySQL Kullanarak Çoklu Kayıtları Görüntülemek için Sayfalandırma Uygulama

Giriş

Sayfalama veri odaklı uygulamalar oluşturmada önemli bir kavramdır. Veritabanından kayıtlar çekilirken, çok sayıda kayıt getirilebilir. Örneğin, aktif kullanıcılar veya belirli bir konuma ait kullanıcılar için sorgu çalıştırıldığında, yüzlerce hatta binlerce kullanıcı dönebilir. Bu kadar büyük miktarda kaydı tek bir web sayfasında görüntülemek, kullanıcıyı bunaltabileceği ve kullanıcı deneyiminin akıcılığını bozabileceği için kullanıcı dostu bir çözüm değildir.

Bu nedenle, tercih edilen bir seçenek kayıt sayısını sınırlamaktır. Bu, sayfalama kavramıdır. Başka bir deyişle, kayıt sayısını sayfalara böleriz ve ardından sayfayı görüntüleriz. Tek bir sayfa, ön uçta görüntülenebilecek on, hatta on beş veya uygun olan herhangi bir miktarda kayıt içerebilir.

Sayfalama, uygulamanın genel kullanıcı deneyimini iyileştirirken, daha az sayıda kayıt çekebildiğimiz için uygulamayı daha hızlı hale de getirebilir. Böylece, istemci ile sunucu arasında ağ üzerinden daha az veri aktarılır ve gecikme süresi azalır.

Bu öğreticide, veritabanına bağlanan bir PHP kodu oluşturacağız ve MySQL veritabanını ve onun LIMIT ifadesini kullanarak sayfalama uygulayacağız.

Gereksinimler

Bu öğreticiyi takip etmek için şunlara ihtiyacınız olacak:

  1. Ubuntu'nun en son sürümünün kurulu ve çalışır durumda olması. Yardıma ihtiyacınız varsa Ubuntu sunucunuzu nasıl kuracağınıza dair öğreticiyi takip edin.

  2. Ayrıca PHP ve MySQL'in kurulu olması gerekir. PHP ve MySQL'i kurmak için bir öğreticimiz var: LAMP Stack kurulumu – Linux Apache MySQL PHP.

Adım 1 — Bir Veritabanı Kullanıcısı ve Test Veritabanı Kurma

Bu öğreticide, MySQL veritabanı ile veritabanı bağlantısı kuracağız ve kayıtları çekeceğiz. Bu kayıtlar, tablo öğesi içeren bir HTML sayfasında görüntülenecektir. Bağlantıyı kurmak ve kayıtları görüntülemek için bir PHP betiği kullanacağız. Veritabanı bağlantısını hazırladıktan sonra, uygulamamızı sayfalama ile ve sayfalama olmadan test edeceğiz. Bu şekilde test etmek, sayfalama işleminin pratikte nasıl çalıştığını anlamamızı sağlayacaktır.

MySQL veritabanına bağlanmak için örnek bir MySQL veritabanına ve MySQL veritabanına bağlanacak kullanıcının kimlik doğrulama bilgilerine ihtiyacımız olacak. Bu adımda, MySQL veritabanınız için root olmayan bir kullanıcı, örnek bir veritabanı ve PHP betiğini test etmek için bir tablo oluşturacaksınız.

İlk olarak sunucunuza giriş yapın. Ardından, aşağıdaki komutu kullanarak MySQL sunucusuna giriş yapın:

Sizden root kullanıcısının şifresi istenecektir. Şifreyi girin ve devam etmek için Enter tuşuna basın. Ardından, öğreticimizde kullanacağımız test_db, adında örnek bir veritabanı oluşturun. Yeni bir veritabanı oluşturmak için aşağıdaki komutu çalıştırın:

MySQL sunucusundan bir satırın etkilendiğine dair çıktıyı göreceksiniz. Ardından, bu veritabanı için yeni bir kullanıcı oluşturmamız gerekecek. Bu kullanıcıya tüm yetkileri vereceğiz. Ancak, pratik uygulamalarla çalışırken yetkileri sınırladığınızdan emin olun. Kullanıcımıza test_user adını vereceğiz. Aşağıdaki komutta, PASSWORD kısmını güçlü bir şifre ile değiştirin:

Kullanıcı oluşturulduktan sonra yetkileri yenileyin (flush):

Artık hem test_user hem de test_db hazır olduğuna göre, tablolar oluşturmak için test_db veritabanını kullanın. test_db veritabanına geçiş yapmak için aşağıdaki komutu çalıştırın:

Çıktıda veritabanının değiştiğini gördükten sonra, tablomuzu oluşturmaya hazırız. Ürünleri tutmak için Products adında yeni bir tablo oluşturacağız. Amacımız doğrultusunda, bu tabloda yalnızca iki sütuna ihtiyacımız olacak: product_id ve product_name. product_id sütununu AUTO_INCREMENT, böylece her yeni ürün eklediğimizde otomatik olarak artacaktır. Diğer sütun olan product_name ise ürünün adını saklamak için kullanılacaktır. product_name sütunu, her ürünü ismine göre ayırt etmek için kullanılacaktır:

Şimdi bu yeni oluşturulan tabloya bazı ürünler ekleyeceğiz. Bunun için aşağıdaki komutları çalıştırın:

Bu ürünlerin tabloya girilip girilmediğini doğrulamak için aşağıdaki komutu çalıştırın:

Yukarıda girdiğiniz ürünleri görüyorsanız, devam etmeye hazırsınız demektir. Aşağıdaki komutu kullanarak MySQL veritabanından çıkın:

MySQL veritabanını kurduğumuza ve test verilerini girdiğimize göre, bu veritabanına bağlanacak ve kayıtları çekecek PHP betiğini kodlamaya hazırız.

Adım 2 – Sayfalama Olmadan Kayıtları Çekme ve Görüntüleme

Yukarıda belirtildiği gibi, ilk olarak kayıtları sayfalama olmadan görüntüleyeceğiz. MySQL veritabanına bağlanan ve kayıtları çeken bir PHP betiği oluşturacağız. Yukarıda oluşturduğumuz test_db veritabanına, test_user kullanıcısını kullanarak bağlanacağız ve kayıtları çekeceğiz.

Şu anda products tablomuzda şu anda yalnızca on kayıt bulunmaktadır. Birçok kullanıcı için sayfalama yapılması gerekip gerekmediği açık olmayabilir. Ancak, uygulamayı sayfalama olmadan test etmek, bunun uygulamanın genel deneyimine nasıl yardımcı olduğunu açıklayacaktır. Ayrıca verileri bölmenin nasıl daha iyi bir kullanıcı deneyimi oluşturmaya yardımcı olduğunu ve sunucu üzerindeki yükü nasıl azalttığını da anlayacağız.

PHP sunucunuzda, web sitesi klasörünün belge kök dizininde (document root) aşağıdaki komutu çalıştırın:

sudo nano /var/www/html/pagination_test.php

Şimdi bu dosyaya aşağıdaki içeriği ekleyin. PASSWORD kısmını, kendi test_user:

Dosyayı kaydedin. Devam etmeden önce, yukarıda ne yaptığımızı özetleyeceğiz:

  1. İlk olarak, MySQL veritabanına bağlandık ve bunun için PHP Data Object (PDO) kütüphanesini kullandık. MySQL veritabanına bağlanmak için yukarıda kullandığımız MySQL kullanıcısının kimlik bilgilerini kullandık. PDO, veritabanına bağlanmak için kullanılan son derece yararlı bir kütüphanedir. Veri erişim katmanının kodlanmasını kolaylaştırır ve uygulamayı kapsamlı bir şekilde yeniden yapılandırmaya gerek kalmadan çeşitli veritabanlarına bağlanmaya olanak tanır. PDO, güvenliğin tehlikeye atılmamasını sağlayan hazırlanmış ifadeler (prepared statements) kullanır. Dolayısıyla sorgular güvenli bir şekilde yürütülür.

  1. Ardından, PDO APIsini kullanarak select * from products ifadesini yürüttük. $pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES,false) ayarı, PHP'deki veri türlerinin veritabanındakilerle aynı olmasını sağlar. Böylece, product_id ve product_name sırasıyla tamsayı ve dize olarak görünür.

  2. The $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); ayarı, bir hata oluştuğunda PDO'ya istisna fırlatmasını söyler. Böylece, istisnayı try catch bloğunda kolayca yakalayabilir ve gerektiği gibi işleyebiliriz.

Artık betiğimiz hazır olduğuna göre, bunu çalıştırmamız gerekiyor. Bunun için tarayıcınızı açın ve şu URL'yi ziyaret edin: /var/www/html/pagination_test.php. URL'nin sonuna sunucu IP'nizi eklediğinizden emin olun. Yerel olarak çalıştırıyorsanız, URL'niz şu şekilde olacaktır: http://localhost/var/www/html/pagination_test.php.

Aşağıdaki çıktıyı göreceksiniz:

Applying Pagination to Display Multiple Records using MySQL with PHP image 1

Burada ürünlerimiz döndürülür ve sayfada görüntülenir. Şimdi, yüzlerce ürünümüz olduğunu hayal edin. Bu, verileri çekmek ve sayfada görüntülemek için uzun bir döngüye neden olur. Bu da sayfa yükleme süresini artıracaktır.

Bir sonraki bölümde, PHP betiğini değiştireceğiz ve MySQL LIMIT ifadesini ekleyeceğiz. Bu, çok sayıda kaydın görüntülenmesi sorununu çözecektir. Kullanıcının sayfalar arasında gezinebilmesi için sayfalama bağlantılarını ekleyeceğiz.

Adım 3 – PHP kullanarak Sayfalamayı Ayarlama

Bu adımda, verileri birden fazla tablo kullanarak görüntülemek için PHP kullanarak sayfalama ayarlayacağız. Sayfalamayı uyumlu hale getirmek için önceki adımda kodladığımız betiği değiştireceğiz.

MySQL veritabanının LIMIT ifadesini kullanacağız. Bunu betiğe eklemeden önce, MySQL LIMIT sözdiziminin bir örneğine bakalım:

Yukarıdaki ifadede, LIMIT ifadesinin offset ve records argümanlarına sahip olduğunu görebiliriz. offset kaç kaydın atlanacağını belirtir ve records sayfa başına görüntülenecek veya veritabanından çekilecek maksimum kayıt sayısını belirtir.

Artık sayfalamanın nasıl çalıştığını bildiğimize göre, bunu nasıl uygulayacağımıza bakalım. Sayfa başına üç kayıt görüntüleyeceğiz. Dolayısıyla, veritabanımızda on kayıt varsa, toplam kayıt sayısını sayfa başına düşen kayıt sayısına bölerek dört sayfamız olacaktır. Sonuç tam sayı olmayabileceği için, tam sayı sonucunu elde etmek amacıyla en yakın tam sayıya yuvarlamak için PHP'nin Ceil işlevini kullanacağız. Aşağıda, Ceil işlevini gösteren basit bir kod parçacığı bulunmaktadır:

Şimdi sayfalama kodunu ekleyeceğiz. Sayfalamayı etkinleştirmek ve gezinti bağlantılarını eklemek için, aşağıdaki komutu kullanarak /var/www/html/pagination_test.php dosyasını açın:

Ardından, bu dosyanın içeriğini aşağıdaki kodla değiştirin:

İşte bu kodun bir özeti:

  1. Şu anda üzerinde bulunduğumuz sayfa hakkındaki bilgiyi tutmamız gerekiyor. Bunun için $page değişkenini kullanıyoruz. $page değişkeni, $_GET[page] değişkenini kullanarak şu anda bulunduğumuz sayfayı elde etmek için kullanılır.

  2. Sonra, bir sayfada kaç adet göstereceğimizi belirtmemiz gerekiyor. Bunun için $per_page değişkeni. Burada sayfa başına yalnızca üç ürün görüntülüyoruz.

  3. Yukarıda tartışıldığı gibi, veritabanında mevcut olan toplam kayıt sayısına sahip olmamız gerekir. Bu, toplam sayfa sayısını belirleyebilmemiz için gereklidir. $total_records değişkeni bu bilgiyi tutar.

  4. Son olarak, kaç kaydın atlanacağını bilmemiz gerekir. Örneğin, ikinci sayfadaysak, veritabanının ilk üç kaydını atlamamız gerekir. $offset değişkenini bu bilgiyi tutmak için kullanıyoruz. Bu bilgiyi her sayfa yüklendiğinde şu formülü kullanarak hesapladık: $offset=($page-1)*$per_page. Başka bir sayıda öğe görüntülemeniz gerekiyorsa, değeri $per_page değişkeninde belirtebilirsiniz.

  5. Gezinme düğmelerini görüntülemek için aşağıdaki kodu kullanıyoruz:

Mantık şudur: $page geçerli sayfayı tutmak için kullanılır. Sayfada önceki seçeneğini görüntülemek istiyorsak, betik $page değişkeninin değerinden bir çıkaracaktır. Sonuç bire eşit veya daha büyükse, sayfada önceki seçeneği görüntülenir.

Benzer şekilde, sonraki seçeneği görüntülemek için $page değişkenine bir ekleriz. Burada, toplama işleminin sonucunun $total_pages değişkenindeki toplam sayfa sayısını aşmamasını sağlıyoruz.

Bundan sonra, sayfayı kontrol etme zamanı gelmiştir. Tarayıcıyı açın ve daha önce kullandığınız URL'yi kullanarak sayfaya gidin:

Çıktıyı aşağıdaki gibi göreceksiniz:

Applying Pagination to Display Multiple Records using MySQL with PHP image 2

table2

table

Burada nihayet PHP betiğindeki MySQL'in LIMIT ifadesini kullanarak sayfalama işlemini gerçekleştirdiniz. Uygulamanızda sayfalama uygulayarak, birden fazla kayıt arasında gezinmek için daha iyi bir yönteme sahip olursunuz.

Sonuç

Bu öğreticide, Ubuntu üzerinde PHP ve MySQL kullanarak sayfalama işleminin nasıl uygulanacağına baktık. Bu adımları kullanarak, etkili bir yönetim için sayfalara bölünmüş, çok sayıda kaydı yeterli şekilde görüntüleyebilen uygulamalar oluşturabilirsiniz.

Ayrıca, Ubuntu üzerinde PHP ve MySQL kullanımı hakkında daha fazla faydalı öğreticimiz bulunmaktadır:

Keyifli Bilişimler!

author

Shreyas Patil

Yazar · CloudSigma

Preslav Dobrev, CloudSigma'da Kreatif Tasarımcı olarak görev yapmakta olup geleneksel ve yenilikçi pazarlama kanallarını kullanarak tutarlı bir kurumsal kimlik oluşturmaya odaklanmaktadır. Sanatsal vizyonu stratejik pazarlamayla harmanlayarak etkili marka anlatıları oluşturma konusunda oldukça yeteneklidir.

Yorumlar

Henüz yorum yapılmamış. İlk siz olun.