Mobile Application Development Practical 26

Question 1
Write a program to insert data in SQLite database using AsyncTask.
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <TextView
        android:id="@+id/textView3"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:textSize="25dp"
        android:textStyle="bold"
        android:text="Student Form" />

    <TextView
        android:id="@+id/textView4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Enter Name"
        android:layout_marginTop="70dp"
        android:layout_marginLeft="70dp"
        android:layout_below="@id/textView3"/>

    <EditText
        android:id="@+id/sname"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="10dp"
        android:ems="10"
        android:layout_toRightOf="@id/textView4"
        android:layout_alignBaseline="@id/textView4"
        android:hint="Enter student name" />

    <TextView
        android:id="@+id/textView5"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Enter Roll Number"
        android:layout_marginTop="20dp"
        android:layout_alignRight="@id/textView4"
        android:layout_below="@id/textView4"/>

    <EditText
        android:id="@+id/rollno"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="10dp"
        android:ems="10"
        android:layout_toRightOf="@id/textView5"
        android:layout_alignBaseline="@id/textView5"
        android:hint="Enter student roll number" />

    <Button
        android:id="@+id/button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignStart="@id/rollno"
        android:layout_below="@id/rollno"
        android:layout_marginTop="20dp"
        android:text="Add Student" />


</RelativeLayout>
AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools">

    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
    <application
        android:allowBackup="true"
        android:dataExtractionRules="@xml/data_extraction_rules"
        android:fullBackupContent="@xml/backup_rules"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/Theme.Practical26"
        tools:targetApi="31">
        <activity
            android:name=".MainActivity"
            android:exported="true">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>
MainActivity.java
package com.example.practical26;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {
    EditText sname,sroll;
    Button b;
    DBHandler dbh;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        sname=findViewById(R.id.sname);
        sroll=findViewById(R.id.rollno);
        b=findViewById(R.id.button);
        dbh=new DBHandler(MainActivity.this);

        b.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                String studname=sname.getText().toString();
                String studroll=sroll.getText().toString();
                if(studname.isEmpty()||studroll.isEmpty())
                    Toast.makeText(getApplicationContext(),"Enter data first",Toast.LENGTH_LONG).show();
                else
                {
                    dbh.addStudent(studname,studroll);
                    Toast.makeText(getApplicationContext(),"Student Added",Toast.LENGTH_LONG).show();
                    sname.setText("");
                    sroll.setText("");
                }
            }
        });
    }
}
DBHandler.java
package com.example.practical26;
import android.content.ContentValues;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

public class DBHandler extends SQLiteOpenHelper {
    static final String dbname="studentdb";
    static final String tablename="student";
    static final String col_roll="roll";
    static final String col_name="name";
    static int dbversion=1;

    public DBHandler(Context c)
    {
        super(c,dbname,null,dbversion);
    }
    @Override
    public void onCreate(SQLiteDatabase db) {
        String query="CREATE TABLE "+tablename+" ("+col_name+" TEXT,"+col_roll+" INTEGER)";
        db.execSQL(query);
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int i, int i1) {
        db.execSQL("DROP TABLE IF EXISTS " + tablename);
        onCreate(db);
    }

    public void addStudent(String sname,String sroll){
        SQLiteDatabase db = this.getWritableDatabase();
        ContentValues values = new ContentValues();
        values.put(col_name,sname);
        values.put(col_roll,sroll);
        db.insert(tablename,null,values);
        db.close();
    }
}
Output
Screenshot_20230325_191658
Screenshot_20230325_191712

Leave a Comment

Your email address will not be published. Required fields are marked *