কম্পিউটার

অ্যান্ড্রয়েড স্কলাইটে অবরোহী ক্রমে রেকর্ডগুলি কীভাবে দেখাবেন?


উদাহরণে আসার আগে, আমাদের জেনে নেওয়া উচিত অ্যান্ড্রয়েডে স্কলাইট ডেটা বেস কী। SQLite হল একটি ওপেন সোর্স SQL ডাটাবেস যা একটি ডিভাইসে একটি টেক্সট ফাইলে ডেটা সঞ্চয় করে। অ্যান্ড্রয়েড বিল্ট ইন SQLite ডাটাবেস বাস্তবায়নের সাথে আসে। SQLite সমস্ত রিলেশনাল ডাটাবেস বৈশিষ্ট্য সমর্থন করে। এই ডাটাবেস অ্যাক্সেস করার জন্য, আপনাকে এটির জন্য JDBC, ODBC ইত্যাদির মতো কোনো ধরনের সংযোগ স্থাপন করতে হবে না।

এই উদাহরণটি Android sqlite ক্রমানুসারে রেকর্ডগুলি কীভাবে দেখাতে হয় সে সম্পর্কে প্রদর্শন করে৷

ধাপ 1 − অ্যান্ড্রয়েড স্টুডিওতে একটি নতুন প্রকল্প তৈরি করুন, ফাইল ⇒ নতুন প্রকল্পে যান এবং একটি নতুন প্রকল্প তৈরি করতে প্রয়োজনীয় সমস্ত বিবরণ পূরণ করুন৷

ধাপ 2 &মাইনাস res/layout/activity_main.xml এ নিম্নলিখিত কোড যোগ করুন।

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="https://schemas.android.com/apk/res/android"
   xmlns:tools="https://schemas.android.com/tools"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   tools:context=".MainActivity"
   android:orientation="vertical">
   <EditText
      android:id="@+id/name"
      android:layout_width="match_parent"
      android:hint="Enter Name"
      android:layout_height="wrap_content" />
   <EditText
      android:id="@+id/salary"
      android:layout_width="match_parent"
      android:inputType="numberDecimal"
      android:hint="Enter Salary"
      android:layout_height="wrap_content" />
   <LinearLayout
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"><Button
      android:id="@+id/save"
      android:text="Save"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content" />
      <Button
         android:id="@+id/refresh"
         android:text="Refresh"
         android:layout_width="wrap_content"
         android:layout_height="wrap_content" />
      <Button
         android:id="@+id/udate"
         android:text="Update"
         android:layout_width="wrap_content"
         android:layout_height="wrap_content" />
   </LinearLayout>

   <ListView
      android:id="@+id/listView"
      android:layout_width="match_parent"
      android:layout_height="wrap_content">
   </ListView>
</LinearLayout>

উপরের কোডে, আমরা নাম এবং বেতন এডিট টেক্সট হিসাবে নিয়েছি, যখন ব্যবহারকারী সেভ বোতামে ক্লিক করবে তখন এটি sqlite ডেটা বেসে ডেটা সংরক্ষণ করবে। কার্সার থেকে লিস্টভিউ আপডেট করার জন্য মান সন্নিবেশ করার পরে রিফ্রেশ বোতামে ক্লিক করুন নিরোচিত ক্রমে . ব্যবহারকারী আপডেট বোতামে ক্লিক করলে এটি ডেটা আপডেট করবে।

ধাপ 3 − src/MainActivity.java

-এ নিম্নলিখিত কোড যোগ করুন
package com.example.andy.myapplication;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.Toast;

import java.util.ArrayList;

public class MainActivity extends AppCompatActivity {
   Button save, refresh;
   EditText name, salary;
   private ListView listView;

   @Override
   protected void onCreate(Bundle readdInstanceState) {
      super.onCreate(readdInstanceState);
      setContentView(R.layout.activity_main);
      final DatabaseHelper helper = new DatabaseHelper(this);
      final ArrayList array_list = helper.getAllCotacts();
      name = findViewById(R.id.name);
      salary = findViewById(R.id.salary);
      listView = findViewById(R.id.listView);
      final ArrayAdapter arrayAdapter = new ArrayAdapter(MainActivity.this, android.R.layout.simple_list_item_1, array_list);
      listView.setAdapter(arrayAdapter);
      findViewById(R.id.refresh).setOnClickListener(new View.OnClickListener() {
         @Override
         public void onClick(View v) {
            array_list.clear();
            array_list.addAll(helper.getAllCotacts());
            arrayAdapter.notifyDataSetChanged();
            listView.invalidateViews();
            listView.refreshDrawableState();
         }
      });

      findViewById(R.id.save).setOnClickListener(new View.OnClickListener() {
         @Override
         public void onClick(View v) {
            if (!name.getText().toString().isEmpty() && !salary.getText().toString().isEmpty()) {
               if (helper.insert(name.getText().toString(), salary.getText().toString())) {
                  Toast.makeText(MainActivity.this, "Inserted", Toast.LENGTH_LONG).show();
               } else {
                  Toast.makeText(MainActivity.this, "NOT Inserted", Toast.LENGTH_LONG).show();
               }
            } else {
               name.setError("Enter NAME");
               salary.setError("Enter Salary");
            }
         }
      });
   }
}

পদক্ষেপ 4৷ − src/ DatabaseHelper.java

-এ নিম্নলিখিত কোড যোগ করুন
package com.example.andy.myapplication;

import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteException;
import android.database.sqlite.SQLiteOpenHelper;

import java.io.IOException;
import java.util.ArrayList;

class DatabaseHelper extends SQLiteOpenHelper {
   public static final String DATABASE_NAME = "salaryDatabase5";
   public static final String CONTACTS_TABLE_NAME = "SalaryDetails";
   public DatabaseHelper(Context context) {
      super(context,DATABASE_NAME,null,1);
   }

   @Override
   public void onCreate(SQLiteDatabase db) {
      try {
         db.execSQL(
            "create table "+ CONTACTS_TABLE_NAME +"(id INTEGER PRIMARY KEY, name text,salary text,datetime default current_timestamp )"
         );
      } catch (SQLiteException e) {
         try {
            throw new IOException(e);
         } catch (IOException e1) {
            e1.printStackTrace();
         }
      }
   }

   @Override
   public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
      db.execSQL("DROP TABLE IF EXISTS "+CONTACTS_TABLE_NAME);
      onCreate(db);
   }

   public boolean insert(String s, String s1) {
      SQLiteDatabase db = this.getWritableDatabase();

      ContentValues contentValues = new ContentValues();
      contentValues.put("name", s);
      contentValues.put("salary", s1);
      db.replace(CONTACTS_TABLE_NAME, null, contentValues);
      return true;
   }

   public ArrayList getAllCotacts() {
      SQLiteDatabase db = this.getReadableDatabase();
      ArrayList<String> array_list = new ArrayList<String>();
      Cursor res = db.rawQuery( "select * from "+CONTACTS_TABLE_NAME+" ORDER BY name DESC", null );
      res.moveToFirst();

      while(res.isAfterLast() == false) {
         array_list.add(res.getString(res.getColumnIndex("name")));
         res.moveToNext();
      }
      return array_list;
   }

   public boolean update(String s, String s1) {
      SQLiteDatabase db = this.getWritableDatabase();
      db.execSQL("UPDATE "+CONTACTS_TABLE_NAME+" SET name = "+"'"+s+"', "+ "salary = "+"'"+s1+"'");
      return true;
   }

   public boolean delete() {
      SQLiteDatabase db = this.getWritableDatabase();
      db.execSQL("DELETE from "+CONTACTS_TABLE_NAME);
      return true;
   }
}

আপনার অ্যাপ্লিকেশন চালানোর চেষ্টা করা যাক. আমি ধরে নিচ্ছি আপনি আপনার কম্পিউটারের সাথে আপনার আসল অ্যান্ড্রয়েড মোবাইল ডিভাইসটি সংযুক্ত করেছেন৷ অ্যান্ড্রয়েড স্টুডিও থেকে অ্যাপটি চালাতে, আপনার প্রোজেক্টের অ্যাক্টিভিটি ফাইলগুলির একটি খুলুন এবং টুলবার থেকে রান আইকনে ক্লিক করুন। একটি বিকল্প হিসাবে আপনার মোবাইল ডিভাইস নির্বাচন করুন এবং তারপরে আপনার মোবাইল ডিভাইসটি পরীক্ষা করুন যা আপনার ডিফল্ট স্ক্রীন প্রদর্শন করবে -

অ্যান্ড্রয়েড স্কলাইটে অবরোহী ক্রমে রেকর্ডগুলি কীভাবে দেখাবেন?

অ্যান্ড্রয়েড স্কলাইটে অবরোহী ক্রমে রেকর্ডগুলি কীভাবে দেখাবেন?

উপরের ফলাফলে, আমরা কিছু মান সন্নিবেশ করাচ্ছি সমস্ত রেকর্ড সংরক্ষণ করার পরে এখন রিফ্রেশ বোতামে ক্লিক করুন, এটি নীচে দেখানো হিসাবে DESC ক্রম সহ নামের মানগুলি দেখাবে -

অ্যান্ড্রয়েড স্কলাইটে অবরোহী ক্রমে রেকর্ডগুলি কীভাবে দেখাবেন?


  1. Android sqlite এ সময়() কিভাবে ব্যবহার করবেন?

  2. কিভাবে অ্যান্ড্রয়েড sqlite এ sqlite_version () ব্যবহার করবেন?

  3. কিভাবে অ্যান্ড্রয়েড sqlite এ sqlite_source_id () ব্যবহার করবেন?

  4. Android sqlite এ rtrim() কিভাবে ব্যবহার করবেন?