Android Programlama Ders 40: INNER JOIN Ve rawQuery Metotları - Technopat
Sonuç bulunamadı
Bütün Sonuçları Göster
Teknoloji tutkunu Technopatların ortak adresi: Technopat.net
  • Haber
  • Yapay Zeka
  • Tavsiyeler
  • Oyun
  • Video
  • Teknoloji
    • Mobil
    • Nasıl Yapılır
    • Yazılım
    • Elektronik Alışveriş Fırsatları
    • Pratik
    • Ev Teknolojileri
    • Makale
    • Güvenlik
    • Ekonomi
    • İnternet
    • Giyilebilir Teknoloji
    • Sağlık
    • Yazıcı
    • Sosyal Medya
    • Otomobil
      • Elektrikli Otomobil
  • Sosyal
Teknoloji tutkunu Technopatların ortak adresi: Technopat.net
  • Haber
  • Yapay Zeka
  • Tavsiyeler
  • Oyun
  • Video
  • Teknoloji
    • Mobil
    • Nasıl Yapılır
    • Yazılım
    • Elektronik Alışveriş Fırsatları
    • Pratik
    • Ev Teknolojileri
    • Makale
    • Güvenlik
    • Ekonomi
    • İnternet
    • Giyilebilir Teknoloji
    • Sağlık
    • Yazıcı
    • Sosyal Medya
    • Otomobil
      • Elektrikli Otomobil
  • Sosyal
Sonuç bulunamadı
Bütün Sonuçları Göster
Teknoloji tutkunu Technopatların ortak adresi: Technopat.net

Anasayfa - Makale - Pratik - Android Programlama Ders 40: INNER JOIN Ve rawQuery Metotları

Android Programlama Ders 40: INNER JOIN Ve rawQuery Metotları

18 Haziran 2014 - 12:00
- Makale, Mobil, Pratik

Android Programlama Ders 40′ta SQlite kullanarak iki tablodan sorgulama yapacağız ve sonucu bildirime yazdıracağız.

Basit bir uygulama oluşturalım. Uygulamamız iki tablodan (Tablolar: people ve position) sorgulama gerçekleştirecek. Birinci tabloda insanların listesi ve ikincide meslekleri listesi olacak. Her insan için people listesinde position tablosunda mesleğin id’si olacaktır.

Projeyi oluşturalım:

  • Project name: P0040_SQLiteInnerJoin
  • Build Target: Android 4.2
  • Application name: SQLiteInnerJoin
  • Package name: tr.example.sqliteinnerjoin
  • Create Activity: MainActivity

 

Bu proje için ekranı kullanmayacağız. Bu yüzden direkt MainActivity.java oluşturuyoruz.

MainActivity.java:

import android.app.Activity;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.os.Bundle;
import android.util.Log;

public class MainActivity extends Activity {

  final String LOG_TAG = "myLogs";

  // meslek tablonun verileri
  int[] position_id = { 1, 2, 3, 4 };
  String[] position_name = { "Mudur", "Programci", "Muhasebeci", "Guvenlik" };
  int[] position_salary = { 15000, 13000, 10000, 8000 };

  // insan tablonun verileri
  String[] people_name = { "Ahmet", "Seyda", "Ali", "Omer", "Sevgi", "Umut", "Murat", "Mehmet" };
  int[] people_posid = { 2, 3, 2, 2, 3, 1, 2, 4 };

  /** Called when the activity is first created. */
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    DBHelper dbh = new DBHelper(this);
    SQLiteDatabase db = dbh.getWritableDatabase();

    Cursor c;

    // bildirime mesleklere ait verileri yazdiriyoruz
    Log.d(LOG_TAG, "--- Table position ---");
    c = db.query("position", null, null, null, null, null, null);
    logCursor(c);
    c.close();
    Log.d(LOG_TAG, "--- ---");

    // bildirime insanlara ait veriler yazdiriyoruz
    Log.d(LOG_TAG, "--- Table people ---");
    c = db.query("people", null, null, null, null, null, null);
    logCursor(c);
    c.close();
    Log.d(LOG_TAG, "--- ---");

    // birlestiren sorgudan sonucu aliyoruz
    // rawQuery kullaniyoruz
    Log.d(LOG_TAG, "--- INNER JOIN with rawQuery---");
    String sqlQuery = "select PL.name as Name, PS.name as Position, salary as Salary "
        + "from people as PL "
        + "inner join position as PS "
        + "on PL.posid = PS.id "
        + "where salary > ?";
    c = db.rawQuery(sqlQuery, new String[] {"12000"});
    logCursor(c);
    c.close();
    Log.d(LOG_TAG, "--- ---");

    // birlestiren sorgudan sonucu aliyoruz
    // query kullaniyoruz
    Log.d(LOG_TAG, "--- INNER JOIN with query---");
    String table = "people as PL inner join position as PS on PL.posid = PS.id";
    String columns[] = { "PL.name as Name", "PS.name as Position", "salary as Salary" };
    String selection = "salary < ?";
    String[] selectionArgs = {"12000"};
    c = db.query(table, columns, selection, selectionArgs, null, null, null);
    logCursor(c);
    c.close();
    Log.d(LOG_TAG, "--- ---");
   
    // veri tabani kapatiyoruz
    dbh.close();
  }

  // cursordan bildirime verileri cikartiyoruz
  void logCursor(Cursor c) {
    if (c != null) {
      if (c.moveToFirst()) {
        String str;
        do {
          str = "";
          for (String cn : c.getColumnNames()) {
            str = str.concat(cn + " = " + c.getString(c.getColumnIndex(cn)) + "; ");
          }
          Log.d(LOG_TAG, str);
        } while (c.moveToNext());
      }
    } else
      Log.d(LOG_TAG, "Cursor is null");
  }

  // veri tabaniyla calismak icin klasi olusturuyoruz
  class DBHelper extends SQLiteOpenHelper {

    public DBHelper(Context context) {
      super(context, "myDB", null, 1);
    }

    public void onCreate(SQLiteDatabase db) {
      Log.d(LOG_TAG, "--- onCreate database ---");

      ContentValues cv = new ContentValues();

      // meslekler tabloyu olusturuyoruz
      db.execSQL("create table position ("
          + "id integer primary key,"
          + "name text," + "salary integer"
          + ");");

      // tabloyu dolduruyoruz
      for (int i = 0; i < position_id.length; i++) {
        cv.clear();
        cv.put("id", position_id[i]);
        cv.put("name", position_name[i]);
        cv.put("salary", position_salary[i]);
        db.insert("position", null, cv);
      }

      // insanlar tabloyu olusturuyoruz
      db.execSQL("create table people ("
          + "id integer primary key autoincrement,"
          + "name text,"
          + "posid integer"
          + ");");

      // dolduruyoruz
      for (int i = 0; i < people_name.length; i++) {
        cv.clear();
        cv.put("name", people_name[i]);
        cv.put("posid", people_posid[i]);
        db.insert("people", null, cv);
      }
    }

    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

    }
  }

}

Kodu inceleyelim. İlk başta veri dizileri (position_id, position_name v.b.) belirtiyoruz.

onCreate metodunda veri tabanı yönetmek için nesneyi oluşturuyoruz ve veri tabanına bağlıyoruz. Sonraki aşamada query kullanarak bildirime iki tablonun (position ve people) verilerini yazdırıyoruz.

İki tablonun verilerini bildirime yazdırmak için rawQuery metodu kullanıyoruz. Bu metodda giriş olarak SQL sorguyu ve şart (Where eğer gerekiyorsa) argümanları kullanılıyor. Sorgulamamız insanın ismini, mesleğini ve maaşını sorguluyor. Şart olarak maaşı 12,000 üzeri olacak.

Sonraki aşamada iki tablonun verilerini bildirime yazdırmak için query kullanıyoruz. Bu sefer şart olarak maaş 12,000 (selectionArgs) altı olacak.

logCursor metodu giriş olarak kürsör (Cursor) alıyor ve içinde olanları bildirime aktarıyor.

DBHelper klasta tabloların oluşumunu ve doldurulmasını programlıyoruz.

Kaydedelim ve çalıştıralım. Bildirime bakalım:

— onCreate database —

—Table position —

id = 1; name = Mudur; salary = 15000;

id = 2; name = Programci; salary = 13000;

id = 3; name = Muhasebeci; salary = 10000;

id = 4; name = Guvenlik; salary = 8000;

— —

— Table people —

id = 1; name = Ahmet; posid = 2;

id = 2; name = Seyda; posid = 3;

id = 3; name = Ali; posid = 2;

id = 4; name = Omer; posid = 2;

id = 5; name = Sevgi; posid = 3;

id = 6; name = Umut; posid = 1;

id = 7; name = Murat; posid = 2;

id = 8; name = Mehmet; posid = 4;

— —

Tabloların verilerini ayrı çıkardık.

— INNER JOIN with rawQuery—

Name = Ahmet; Position = Programci; Salary = 13000;

Name = Ali; Position = Programci; Salary = 13000;

Name = Omer; Position = Programci; Salary = 13000;

Name = Umut; Position = Mudur; Salary = 15000;

Name = Murat; Position = Programci; Salary = 13000;

— —

rowQuery kullanarak 12,000 üzeri maaşı olanları çıkardık.

— INNER JOIN with query—

Name = Seyda; Position = Muhasebeci; Salary = 10000;

Name = Sevgi; Position = Muhasebeci; Salary = 10000;

Name = Mehmet; Position = Guvenlik; Salary = 8000;

— —

Query kullanarak 12,000 altı maaşı olanları çıkardık.

Ders Sonu Notları:

Gördüğünüz gibi SQLite sorgularının normal veri tabanından pek farkı yok. Hangi yöntemi (rawQuery veya query) kullanacağınız size kalıyor. Gelecek derste veri tabanında kullanılan işlemleri inceleyeceğiz.

Etiketler: AndroidAndroid programlama dersleridersINNER JOINlogCursorprogramlamarowQuerySQLitetechnopatteknolojiYazılımyeni
PaylaşPaylaşTweetYollaPaylaş
Victor Cuiumju

Victor Cuiumju

Yorum Yap Yanıtı iptal et

E-posta adresiniz yayınlanmayacak. Gerekli alanlar * ile işaretlenmişlerdir

RSS Technopat Sosyal

  • H61 anakarta i7 3770 takılınca görüntü gelmedi
  • ARC Raiders'e 40 dolar verilir mi?
  • R7 7800x3D RX 9070 XT sistem için yükseltme önerisi
  • 839 TL'ye AC Shadows alınır mı?
  • İncehesap bozuk monitör değişiminde süreç nasıl işliyor?
  • 80 binde, 2020 model Dacia Duster alınır mı?
  • Ryzen 5 7500F ve 5060 Ti sistem toplama
  • Sapphire Nitro+ 9070XT alınır mı?
  • VXE R1 SE+ masaya konunca kendi kendine hem sol hem sağ tık yapıyor
  • Monitör çalışırken gelen "pat" sesi ve ekran karıncalanması nedir?

Technopat Video

Şu an oynayan

Laptop işlemcili kasa olur mu? ASUS TUF Gaming T500MV (2025) inceleme

ASUS TUF Gaming T500MV

Laptop işlemcili kasa olur mu? ASUS TUF Gaming T500MV (2025) inceleme

Haber
iOS 26.1 hangi yenilikleri getirdi?

iOS 26.1 hangi yenilikleri getirdi?

Haber
Kriz kapıda! RAM ve SSD fiyatlarına büyük zam

Kriz kapıda! RAM ve SSD fiyatlarına büyük zam

Haber

Teknoloji tutkunu Technopatların ortak adresi: Technopat.net!

Güncel teknoloji, internet, donanım, yazılım, oyun ve daha fazlası haber, makale ve videolar ile Technopat’ta sizlerle.


01010100 01100101 01100011 01101000 01101110 01101111 01110000 01100001 01110100

Kategoriler

  • Yapay Zeka
  • Ev Teknolojileri
  • Makale
  • Video

Sosyal Medya

Bağlantılar

  • Hakkında
  • Haber
  • Video
  • Sosyal
  • Çerez Politikası
© 2011-2025 Technopat. Tüm Hakları Saklıdır.
Netse
Çerez Onayı
Web sitemizi ziyaret ettiğinizde, kullanıcı deneyiminizi daha iyi hale getirmek, hizmetlerimizi size daha etkin bir şekilde sunabilmek için çerezler (cookies) ve benzeri araçlar kullanıyoruz. Çerezler, internet sitesinin düzgün çalışmasını sağlamak, içeriği kişiselleştirmek, sosyal medya özellikleri sağlamak ve trafik analizi yapmak için kullanılan küçük metin dosyalarıdır. Çerezleri nasıl kullandığımız ve kişisel verilerinizi nasıl işlediğimiz hakkında daha fazla bilgi almak için çerez politikamızı ve kişisel veri politikamızı inceleyebilirsiniz.
Fonksiyonel Her zaman aktif
Teknik depolama veya erişim, sadece kullanıcının açıkça talep ettiği belirli bir hizmetin kullanılmasını sağlama amacıyla veya iletişimin elektronik iletişim ağı üzerinden iletilmesinin tek amacıyla yasal olarak kesinlikle gereklidir.
Tercihler
Teknik depolama veya erişim, abone veya kullanıcı tarafından istenmeyen tercihlerin depolanması yasal amacıyla gereklidir.
İstatistikler
Sadece istatistiksel amaçlarla kullanılan teknik depolama veya erişim. The technical storage or access that is used exclusively for anonymous statistical purposes. Without a subpoena, voluntary compliance on the part of your Internet Service Provider, or additional records from a third party, information stored or retrieved for this purpose alone cannot usually be used to identify you.
Pazarlama
Teknik depolama veya erişim, reklam gönderimi için kullanıcı profilleri oluşturmak veya kullanıcıyı bir web sitesinde veya birden fazla web sitesinde benzer pazarlama amaçları için takip etmek amacıyla gereklidir.
  • Seçenekleri yönet
  • Hizmetleri yönetin
  • {vendor_count} satıcılarını yönetin
  • Bu amaçlar hakkında daha fazla bilgi edinin
Tercihleri yönet
  • {title}
  • {title}
  • {title}
Sonuç bulunamadı
Bütün Sonuçları Göster
  • Giriş
  • Teknoloji Haberleri
  • Sosyal
  • Nasıl Yapılır
  • Yapay Zeka
  • Video
  • Tavsiyeler
  • İncelemeler
    • Video İncelemeler
  • Güvenlik
  • Oyun
  • Makale
    • Pratik
    • Yazar Köşeleri

© 2025 Technopat
Sorularınız için Technopat Sosyal