رفتن به مطلب
انجمن اندروید ایران | آموزش برنامه نویسی اندروید و موبایل
  • android.png.1fab383bc8500cd93127cebc65b1dcab.png

خواندن ID های انتخابی از دیتابیس sqlite


پست های پیشنهاد شده

سلام 

یک لیست ویو داریم که تمامی ستون های جدول رو از دیتابس می خونه و نمایش میده 

حالا باید کاری کنیم که فقط ستون هایی که ما تعیین می کنیم رو بخونه ، به چه صورت دستور بدم بهتره ؟ اینکه مشخص کنم مثلا بیا ID های مورد نظر منو بخون و یا یه کولمن به تیبل اضافه کنم و بهش مقدار بدم و دستور بدم که ID هایی رو بخون که مقدار کلومن اونا برابر با 1 یا 2 یا 3 و .. غیره هست؟

این اکتیویتیی هست که لیست ویو داخلش قرار گرفته و تمام ID ها رو می خونه و لیست می کنه :

ممنون میشم بگید کدوم روش بهتره و بهینه تره و دستوراتی که باید جایگزین بشه چیه و به جای کدم دستور فعلی 

[shcode=java]package ir.apy.book;

import

java.io.FileNotFoundException;

import

java.io.FileOutputStream;

import

java.io.IOException;

import

java.io.InputStream;

import

java.io.OutputStream;

import

java.util.List;

import

ir.apy.database.DBAdapter;

import

ir.apy.database.Dastan;

import

android.os.Bundle;

import

android.util.Log;

import

android.view.View;

import

android.view.View.OnClickListener;

import

android.widget.ArrayAdapter;

import

android.widget.Button;

import

android.widget.ImageButton;

import

android.widget.ListView;

import

android.app.ListActivity;

import

android.content.Intent;

public class Rashtextends ListActivity {

    DBAdapter

db;

    List

dastanha;

    ListView

lst;

    boolean

isAll;

    @Override

    protectedvoid onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.rasht);

                

        Buttonbtn_about = (Button) findViewById(R.id.main_about);

        ImageButtonbtn_sett = (ImageButton) findViewById(R.id.main_setting);

        

        

        isAll

=true;

        lst= getListView();

        db= new DBAdapter(getBaseContext());

        db.open();

        dastanha= db.getAllContacts();

        

        if(dastanha.size() == 0) {

            

            StringdestPath = "/data/data/" + getPackageName() + "/databases";

            

            try

{

                CopyDB(getBaseContext().getAssets().open("mydb"),

                        newFileOutputStream(destPath + "/dastanha"));

                

                dastanha= db.getAllContacts();

            

                refreshDisplay();

                

                

            }catch (FileNotFoundException e) {

                //TODO Auto-generated catch block

                e.printStackTrace();

            }catch (IOException e) {

                //TODO Auto-generated catch block

                e.printStackTrace();

            }

        }else {

            refreshDisplay();

        }

        

{

        btn_about.setOnClickListener(newOnClickListener() {

            @Override

            publicvoid onClick(View arg0) {

                Intentnext = new Intent(getBaseContext(), About.class);

                startActivity(next);

            }

        });

    

    btn_sett.setOnClickListener(newOnClickListener() {

        @Override

        publicvoid onClick(View arg0) {

            Intentnext = new Intent(getBaseContext(), Setting.class);

            startActivity(next);

        }

    });

    

        

}

    

    }

    @Override

    protectedvoid onListItemClick(ListView l, View v, int position, long id) {

        //TODO Auto-generated method stub

        super.onListItemClick(l,v, position, id);

        Dastandastan = dastanha.get(position);

        Intentnext = new Intent(this, ShowData.class);

        next.putExtra("thisdastan",

dastan);

        startActivity(next);

    }

    

    

    publicvoid CopyDB(InputStream inputStream, OutputStream outputStream)

            throwsIOException {

    

        byte[]buffer = new byte[1024];

        int

length;

        while((length = inputStream.read(buffer)) > 0) {

            outputStream.write(buffer,0, length);

        }

        inputStream.close();

        outputStream.close();

    }

    

    publicvoid refreshDisplay() {

        ArrayAdapteradapter = new DastanAdapter(this, dastanha);

        setListAdapter(adapter);

    }

    

    

    

    

    

    

    

    

}

[/shcode]

لینک ارسال
به اشتراک گذاری در سایت های دیگر

دوست عزیز شما با کد خط زیر تمامی مقادیر دیتابیس رو میگیری

[shcode=java]

dastanha = db. getAllContacts();

[/shcode]

حال باید به جای فراخوانی متد   getAllContacts() ، متدی را در کلاس دیتابیس تعریف کنید که مقدار دلخواه شمارو برگردونه.

لینک ارسال
به اشتراک گذاری در سایت های دیگر

می تونید این متد رو که فرمودید رو در غالب مثالی عنوان کنید ؟ممنون


این هست :

[shcode=java]public List getAllContacts() {

Cursor cursor = db.query(DATABASE_TABLE, yek_name, null, null, null,

null, null);

List nams = cursorToList(cursor);

return nams;

}[/shcode]

چه جوری تغییر بدم و یا چه متدی رو استفاده کنم؟

بازم ممنون

لینک ارسال
به اشتراک گذاری در سایت های دیگر

خب بستگی به نیاز شما داره که چی رو میخواین از جدول تون بگیرین .

مثلا متد زیر با توجه به متدی که شما تعریف کردین نوشتم.

  [shcode=java]  public List findid(int id, String name_fild)

                throws SQLException {

            Cursor cursor = db.query(true, DATABASE_TABLE, yek_name, name_fild

                    + " LIKE '%" + id + "%'", null, null, null, null, null);

            List nams = cursorToList(cursor);

           

            return nams;

        }[/shcode]

در این متد پارامتر اول مقداری هست که توی فیلد پارامتر دوم موجود هست.

یعنی اطلاعاتی رو برمی گردونه که مقدار name_fild آنها برابر id  هست!

لینک ارسال
به اشتراک گذاری در سایت های دیگر

به گفتگو بپیوندید

هم اکنون می توانید مطلب خود را ارسال نمایید و بعداً ثبت نام کنید. اگر حساب کاربری دارید، برای ارسال با حساب کاربری خود اکنون وارد شوید .

مهمان
ارسال پاسخ به این موضوع...

×   شما در حال چسباندن محتوایی با قالب بندی هستید.   حذف قالب بندی

  تنها استفاده از 75 اموجی مجاز می باشد.

×   لینک شما به صورت اتوماتیک جای گذاری شد.   نمایش به صورت لینک

×   محتوای قبلی شما بازگردانی شد.   پاک کردن محتوای ویرایشگر

×   شما مستقیما نمی توانید تصویر خود را قرار دهید. یا آن را اینجا بارگذاری کنید یا از یک URL قرار دهید.

×
×
  • اضافه کردن...