Omid Zakeri

آموزش پایگاه داده Android SQLite با Sugar ORM

1 ارسال در این موضوع قرار دارد

پایگاه داده SQLite یکی از راه های ذخیره داده های برنامه شما به صورت محلی در اندروید است. در این پایگاه داده من میخوام به شما یک راه ساده تر بهنشان دهم. با استفاده از Sugar ORM .

دیتابیس اندروید

به طور معمول با استفاده از SQLite در اندروید، مقدار زیادی از کد های boilerplate مورد نیاز بوده که زمان قابل توجهی صرف می شود. اما با Sugar ORM، همه ی شما نیاز به یک مدل (Bean) دارید:

  • (Add a new note (save  : اضافه کردن
  • Delete note  : حذف کردن
  • Modify : تغییرات

 

در ابتدا کتابخانه زیر را اضافه کنید : 

compile 'com.github.satyan:sugar:1.4'

 

تنظیمات زیر را وارد منیفست کنید:

<application 
    android:name="com.orm.SugarApp"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    >
   
<meta-data 
        android:name="DATABASE"
        android:value="notes.db" />
    <meta-data 
        android:name="VERSION"
        android:value="1" />
    <meta-data 
        android:name="QUERY_LOG"
        android:value="true" />
    <meta-data 
        android:name="DOMAIN_PACKAGE_NAME"
        android:value="com.grafixartist.noteapp" />
</application>

 

 

یک مدل (Bean) کلاس شما نیاز دارید که به صورت زیر باشد :

public class Note extends SugarRecord {

String title, note;
    long time;
    // Default constructor is important!
    public Note() {
    }

public Note(String title, String note, long time) {
        this.title = title;
        this.note = note;
        this.time = time;
    }
 
// Getter setters here
}

 

برای Create کردن کد زیر را وارد کنید : 

Note note = new Note(title, desc, time);
note.save();

برای Update کردن کد زیر را وارد کنید : 

 

Note note = Note.findById(Note.class, id);
note.title = updated title here";
note.save();

 

برای  Delete کردن کد زیر را وارد کنید : 

 

Note note = Note.findById(Note.class, id);
note.delete();

برای بدست آوردن فهرست همه لیست ها :

List<Note> notes = Note.listAll(Note.class);

Query

برای این کار 2  راه برای انجام این کار وجود دارد. بیایید مثال را مقایسه کنیم:

استفاده از Raw Query :

List<Note> notes = Note.findWithQuery(Note.class, "Select * from Note where name = ?", "mynote");

 

استفاده از  Query Builder :

 

Select.from(Note.class)
.where(Condition.prop("title").eq("mynote"),
Condition.prop("description").eq("notedesc"))
.list();

 

1 کاربر پسند دیده است

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


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

برای ارسال نظر یک حساب کاربری ایجاد کنید یا وارد حساب خود شوید

برای اینکه بتوانید نظر ارسال کنید نیاز دارید که کاربر سایت شوید

ایجاد یک حساب کاربری

برای حساب کاربری جدید در انجمن ما ثبت نام کنید. عضویت خیلی ساده است !


ثبت نام یک حساب کاربری جدید

ورود به حساب کاربری

دارای حساب کاربری هستید؟ از اینجا وارد شوید


ورود به حساب کاربری