安卓連接數據庫SQLite實現註冊登陸顯示功能

代碼在下方

Android連接SQLite

1.SQLite簡介:

  1. 輕量級:

    使用 SQLite 只需要帶一個動態庫,就可以享受它的全部功能, 而且那個動態庫的尺寸想當小。

  2. 獨立級:

    SQLite 數據庫的核心引擎不需要依賴第三方軟件,也不需要所謂的“安裝”。

  3. 隔離性

    SQLite 數據庫中所有的信息(比如表、視圖、觸發器等) 都包含在一個文件夾內,方便管理和維護。

  4. 跨平臺

    1. SQLite 目前支持大部分操作系統,不至電腦操作系統更在衆多的手機系統 也是能夠運行,比如:Android。
  5. 多語言接口

    SQLite 數據庫支持多語言編程接口。

  6. 安全性

    SQLite 數據庫通過數據庫級上的獨佔性和共享鎖來實現獨立事務處理。 這意味着多個進程可以在同一時間從同一數據庫讀取數據, 但只能有一個可以寫入數據。

2.安卓連接SQLite

2.1 創建數據庫類:

DatabaseHelper是一個繼承自SQLiteOpenHelper的Java類,它需要重寫父類的onCreate()和onUpgrade()方法。該類的構造函數,也就是DatabaseHelper()用來初始化數據庫連接。當數據表第一次被創建時,onCreate()方法將被觸發,在該方法中實現數據表的創建。當數據庫需要升級時,onUpgrade()方法將被觸發,該方法實現數據庫更新。

在Android中連接SQLite需要先創建一個類,並且這個類 繼承 SQLiteOpenHelper,代碼如下:

package com.example.sqlite_android.service;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
public class DatabaseHelper extends SQLiteOpenHelper {
    private static final String name="user.db";//自定義的數據庫名
    private static final int dbVersion=1;//版本號
    public DatabaseHelper(Context context) {
        super(context, name, null, dbVersion);
    }
    
    //該方法會自動調用,首先系統會檢查該程序中是否存在數據庫名爲‘user’的數據庫,如果存在則不會執行該方法,如果不存在則會執行該方法。 
    
    public void onCreate(SQLiteDatabase db) {
        String sql="create table user(
            id integer primary key autoincrement,
             username varchar(20),
             password varchar(20),
             age integer,
             sex varchar(2))";
        //SQL語句
        
        db.execSQL(sql);
    }
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    }
}

SQLiteOpenHelper是SQLiteDatabase的一個幫助類, 用來管理數據庫的創建和版本的更新。 一般是建立一個類繼承它,並實現它的onCreate和onUpgrade方法。 常用的方法有:

onCreate(SQLiteDatabase db)
創建數據庫時調用

onUpgrade(SQLiteDatabase db,int oldVersion , int newVersion)
版本更新時調用

getReadableDatabase()
創建或打開一個只讀數據庫

getWritableDatabase()
創建或打開一個讀寫數據庫

2.2 對數據庫的插入等操作:

//實例化剛纔上面我們創建的那個類    
MySQLDatabase DatabaseHelper = new DatabaseHelper(MainActivity.this);
/*在通過getReadableDatabase()方法
    或者通過getWritableDatabase()
獲得SQLDatabse類的對象;通過SQLDatabase類的對象來對數據進行操作;*/
        SQLiteDatabase sqlDatabase =  DatabaseHelper.getReadableDatabase();
        

SQLDatabase類的常用方法:

  • (long) insert(String table,String nullColumnHack,ContentValues values)

    刪除數據行的便捷方法

  • (int) delete(String table,String whereClause,String[] whereArgs)

    更新數據行的便

  • (int) update(String table, ContentValues values, String whereClause, String[] whereArgs) 更新數據行的便捷方法

    關閉數據庫

  • (void) close()

    查詢指定的數據表返回一個帶遊標的數據集

  • (Cursor) query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit)

    運行一個預置的SQL語句,返回帶遊標的數據集(與上面的語句最大的區別就是防止SQL注入)

  • (Cursor) rawQuery(String sql, String[] selectionArgs)

    這個是執行SQL語句(sql字符串可以是select,delete,或者insert,update中的任意語句)

  • (void) execSQL(String sql)

//往數據庫中插入數據的代碼,在這裏我使用的是execSQL(sql);
for(int i=0;i<20;i++){
            String sql = "insert into wx_user(id,name,tou,content,dateTime) values("+i+",'張校花"+i+"','aa','你今天會被打','11月19日')";
            sqlDatabase.execSQL(sql);}

2.3讀取數據庫

往數據庫中參入數據之後,我們再將數據庫中的數據取出來看看;我們需要先創建一個實體類;

package com.example.entiy;

public class unserInFo {
    private int id;
    private String name;
    private String dateTime;
    private String tou;
    private String content;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getContent() {
        return content;
    }
    public void setContent(String content) {
        this.content = content;
    }
    
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getDateTime() {
        return datetime;
    }
    public void setDateTime(String dateTime) {
        this.dateTime= dateTime;
    }
    public String getTou() {
        return tou;
    }
    public void setTou(String tou) {
        this.tou = tou;
    }
    
    @Override
    public String toString() {
        return "unserInFo [id="+id+,"name=" + name + ", dataTime=" + dataTime+ ", tou="
                + tou+ "]";
    }
    public unserInFo() {
        super();
        // TODO Auto-generated constructor stub
    }
   
}

獲取數據:

//定義一個集合用來存放所有的結果
List<unserInFo> user = new ArrayList<unserInFo>();
//通過遊標來獲取表wx_user的信息,
Cursor c=sqlDatabase.query("wx_user", null, null, null, null, null, null);
        //先判斷是否有第一條數據(ic.moveToFirst()將遊標移到第一條數據,如果沒有第一條數據則返回false,否則返回true)
       if(c.moveToFirst()){
                //通過getCount()來決定循環的次數getCount()是遊標的總數量。
        for (int i = 0; i<c.getCount();i++) {
            unserInFo uif = new unserInFo();
            
            //將遊標移動到下一條數據
            c.moveToNext();
            uif.setId(c.getInt(c.getColumnIndex("id")));
            uif.setLastdate(c.getString(c.getColumnIndex("dateTime")));
            uif.setName(c.getString(c.getColumnIndex("name")));
            uif.setZhao(c.getString(c.getColumnIndex("tou")));
            uif.setContent(c.getString(c.getColumnIndex("content")));
            user.add(uif);
            
        }
}    
//最後數據庫中獲取到的數據就全部存放到user集合中了,我們只需要遍歷user就能顯示數據了。

登陸註冊實例:

1.項目目錄:

在這裏插入圖片描述

  1. 添加布局文件——主界面activity_main
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">
        <TextView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:gravity="center"
            android:text="歡迎進入登錄界面!"
            android:textSize="30dp"
            android:textStyle="bold" />
        <TableLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:stretchColumns="1" >
            <TableRow>
                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_gravity="center"
                    android:text="用戶名:" />
                <EditText
                    android:id="@+id/username"
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:hint="請輸入用戶名!" />
            </TableRow>
            <TableRow>
                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_gravity="center"
                    android:text="密碼:" />

                <EditText
                    android:id="@+id/password"
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:hint="請輸入密碼!" />
            </TableRow>
            <TableRow>
                <TextView />
                <LinearLayout>

                    <Button
                        android:id="@+id/login"
                        android:layout_width="100dp"
                        android:layout_height="wrap_content"
                        android:text="登錄" />
                    <Button
                        android:id="@+id/register"
                        android:layout_width="100dp"
                        android:layout_height="wrap_content"
                        android:text="註冊" />
                </LinearLayout>
            </TableRow>
        </TableLayout>
    </LinearLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
  1. XML佈局文件——註冊界面:activity_register
 <?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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=".RegisterActivity">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">
        <TextView
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:gravity="center"
            android:text="歡迎進入註冊界面!"
            android:textSize="30dp"
            android:textStyle="bold" />

        <TableLayout
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:stretchColumns="1" >

            <TableRow >

                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_gravity="center"
                    android:text="用戶名:" />

                <EditText
                    android:id="@+id/usernameRegister"
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:hint="請輸入用戶名!" />
            </TableRow>

            <TableRow >

                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_gravity="center"
                    android:text="密碼:" />

                <EditText
                    android:id="@+id/passwordRegister"
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:hint="請輸入密碼!" />
            </TableRow>

            <TableRow >

                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_gravity="center"
                    android:text="年齡:" />

                <EditText
                    android:id="@+id/ageRegister"
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:hint="請輸入年齡!" />
            </TableRow>

            <TableRow >

                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_gravity="center"
                    android:text="性別:"
                    android:textSize="20dp" />

                <RadioGroup
                    android:id="@+id/sexRegister"
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:checkedButton="@+id/woman"
                    android:orientation="horizontal" >

                    <RadioButton
                        android:id="@+id/nan"
                        android:text="男"
                        android:layout_height="wrap_content"
                        android:layout_width="wrap_content" />

                    <RadioButton
                        android:id="@id/woman"
                        android:text="女"
                        android:layout_height="wrap_content"
                        android:layout_width="wrap_content"/>
                </RadioGroup>
            </TableRow>

            <TableRow >

                <TextView />

                <LinearLayout >
                    <Button
                        android:id="@+id/Register"
                        android:layout_width="150dp"
                        android:layout_height="wrap_content"
                        android:text="註冊" />
                </LinearLayout>
            </TableRow>
        </TableLayout>

    </LinearLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
  1. XML佈局文件——登陸成功後顯示界面:activity_0k
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        >
        <TextView
        android:id="@+id/tv_id"
        android:textAlignment="center"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="id"
        android:layout_weight="1"/>
        <TextView
            android:text="姓名"
            android:textAlignment="center"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"/>
        <TextView
            android:textAlignment="center"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="age"
            android:layout_weight="1"/>
        <TextView
            android:textAlignment="center"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="性別"
            android:layout_weight="1"/>

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

    </ListView>

</LinearLayout>

4.XML佈局文件——顯示數據庫裏面信息的XML:item_sql

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <TextView
        android:id="@+id/tv_id"
        android:textAlignment="center"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_weight="1"/>
    <TextView
        android:id="@+id/tv_name"
        android:textAlignment="center"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_weight="1"/>
    <TextView
        android:id="@+id/tv_age"
        android:textAlignment="center"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_weight="1"/>
    <TextView
        android:id="@+id/tv_sex"
        android:textAlignment="center"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_weight="1"/>
</LinearLayout>
  1. 在service包DatabaseHelper中添加鏈接AS自帶數據庫以及創建表的語句:
package com.example.sqlite_android.service;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;

public class DatabaseHelper extends SQLiteOpenHelper {
    private static final String name="user.db";//自定義的數據庫名
    private static final int dbVersion=1;//版本號
    public DatabaseHelper(Context context) {
        super(context, name, null, dbVersion);
    }
    //該方法會自動調用,首先系統會檢查該程序中是否存在數據庫名爲‘user’的數據庫,如果存在則不會執行該方法,如果不存在則會執行該方法。
    public void onCreate(SQLiteDatabase db) {
        String sql="create table user(" +
                "id integer primary key autoincrement," +
                "username varchar(20)," +
                "password varchar(20)," +
                "age integer," +
                "sex varchar(2))";
        db.execSQL(sql);
    }
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

    }
}
  1. 在service包UserService中用sql語句寫登錄註冊功能的實現:
package com.example.sqlite_android.service;

import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;

import com.example.sqlite_android.User;


public class UserService {
    private DatabaseHelper dbHelper;
    public UserService(Context context){
        dbHelper=new DatabaseHelper(context);
    }
    public boolean login(String username,String password){
        SQLiteDatabase sdb=dbHelper.getReadableDatabase();
        String sql="select * from user where username=? and password=?";
        Cursor cursor=sdb.rawQuery(sql, new String[]{username,password});
        if(cursor.moveToFirst()==true){
            cursor.close();
            return true;
        }
        return false;
    }
    public boolean register(User user){
        SQLiteDatabase sdb=dbHelper.getReadableDatabase();
        String sql="insert into user(username,password,age,sex) values(?,?,?,?)";
        Object obj[]={user.getUsername(),user.getPassword(),user.getAge(),user.getSex()};
        sdb.execSQL(sql, obj);
        return true;
    }
}
  1. 在User文件中聲明要用到的表列名的變量,並對其添加get&&set方法:
package com.example.sqlite_android;

import java.io.Serializable;

public class User implements Serializable{
    private int id;
    private String username;
    private String password;
    private int age;
    private String sex;
    public User() {
        super();
        // TODO Auto-generated constructor stub
    }
    public User(String username, String password, int age, String sex) {
        super();
        this.username = username;
        this.password = password;
        this.age = age;
        this.sex = sex;
    }
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    public String getSex() {
        return sex;
    }
    public void setSex(String sex) {
        this.sex = sex;
    }
    @Override
    public String toString() {
        return "User [id=" + id + ", username=" + username + ", password="
                + password + ", age=" + age + ", sex=" + sex + "]";
    }

}
  1. 爲登陸功能添加activity組件—Login_Activity:
package com.example.sqlite_android;

import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;
import com.example.sqlite_android.service.UserService;
public class LoginActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);//即activity_login.xml
        findViews();
    }
    private EditText username;
    private EditText password;
    private Button login;
    private Button register;

    private void findViews() {
        username=(EditText) findViewById(R.id.username);
        password=(EditText) findViewById(R.id.password);
        login=(Button) findViewById(R.id.login);
        register=(Button) findViewById(R.id.register);

        login.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                String name=username.getText().toString();
                System.out.println(name);
                String pass=password.getText().toString();
                System.out.println(pass);

                Log.i("TAG",name+"_"+pass);
                UserService uService=new UserService(LoginActivity.this);
                boolean flag=uService.login(name, pass);

                if(flag){
                    Log.i("TAG","登錄成功");
                    Toast.makeText(LoginActivity.this, "登錄成功", Toast.LENGTH_LONG).show();
                    Intent intent = new Intent(LoginActivity.this,MainActivity.class);
                    startActivity(intent);
                }else{
                    Log.i("TAG","登錄失敗");
                    Toast.makeText(LoginActivity.this, "登錄失敗", Toast.LENGTH_LONG).show();
                }
            }
        });
        register.setOnClickListener(new View.OnClickListener() {
            public void onClick(View v) {
                Intent intent=new Intent(LoginActivity.this,RegisterActivity.class);
                startActivity(intent);
            }
        });
    }
}
  1. 爲註冊功能添加activity組件:
package com.example.sqlite_android;

import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.RadioButton;
import android.widget.RadioGroup;
import android.widget.Toast;

import androidx.appcompat.app.AppCompatActivity;

import com.example.sqlite_android.service.UserService;

public class RegisterActivity extends AppCompatActivity {

    EditText username;
    EditText password;
    EditText age;
    RadioGroup sex;
    Button register;
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_register);
        findViews();
        register.setOnClickListener(new View.OnClickListener() {
            public void onClick(View v) {
                String name=username.getText().toString().trim();
                String pass=password.getText().toString().trim();
                String agestr=age.getText().toString().trim();
                String sexstr=((RadioButton)RegisterActivity.this.findViewById(sex.getCheckedRadioButtonId())).getText().toString();
                Log.i("TAG",name+"_"+pass+"_"+agestr+"_"+sexstr);
                UserService uService=new UserService(RegisterActivity.this);
                User user=new User();
                user.setUsername(name);
                user.setPassword(pass);
                user.setAge(Integer.parseInt(agestr));
                user.setSex(sexstr);
                uService.register(user);
                Toast.makeText(RegisterActivity.this, "註冊成功", Toast.LENGTH_LONG).show();
                Intent intent = new Intent(RegisterActivity.this,LoginActivity.class);
                startActivity(intent);
            }
        });
    }
    private void findViews() {
        username=(EditText) findViewById(R.id.usernameRegister);
        password=(EditText) findViewById(R.id.passwordRegister);
        age=(EditText) findViewById(R.id.ageRegister);
        sex=(RadioGroup) findViewById(R.id.sexRegister);
        register=(Button) findViewById(R.id.Register);
    }

}
  1. 登陸成功後跳轉的顯示見面——Activity_main
package com.example.sqlite_android;

import androidx.annotation.Nullable;
import android.app.Activity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import static android.content.Context.MODE_PRIVATE;

public class MainActivity extends Activity {
    ListView listView;
    SimpleAdapter adapter;
    List<Map<String,String>> list;
    SQLiteDatabase db;
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_ok);
        inti();

    }
    private void inti() {
        //每個程序都要自己數據庫,默認情況下各自互不干擾
        //創建一個數據庫,並且打開;
        //通過下面這個方法,創建,如果存在就打開,不存在就創建並打開
        db= openOrCreateDatabase("user.db",MODE_PRIVATE,null);
        list=new ArrayList<Map<String, String>>();
        //初始化
        listView=(ListView)findViewById(R.id.read_listview);
        adapter=new SimpleAdapter(this,
                getData(),
                R.layout.item_sql,
                new String[]{"id","name","age","sex"},
                new int[]{R.id.tv_id,
                        R.id.tv_name,
                        R.id.tv_age,
                        R.id.tv_sex});
        listView.setAdapter(adapter);
    }

    public List<Map<String,String>> getData() {
        if (isTableExist("user")) {
            Cursor c = db.rawQuery("select * from user", null);
            if (c != null) {
                while (c.moveToNext()) {
                    Map<String, String> map = new HashMap<>();
                    map.put("id", c.getString(0));
                    map.put("name", c.getString(1));
                    //getColumnIndex獲取該列數據的index(索引)。返回值爲int
                    map.put("age", c.getString(c.getColumnIndex("age")));
                    System.out.println("heh"+(c.getColumnIndex("age")));
                    map.put("sex", c.getString(c.getColumnIndex("sex")));
                    list.add(map);

                }
                c.close();
                db.close();
                return list;
            } else {
                c.close();
                db.close();
            }
        }
        return list;
    }
    //判斷table是否存在
    public boolean isTableExist(String table) {
        Cursor c = db.rawQuery("select count(*) from sqlite_master where type='table' and name='"+table+"'", null);
        if (c != null) {
            while (c.moveToNext()) {
                int count = c.getInt(0);
                if (count > 0) {
                    c.close();
                    return true;
                }
            }
        }else{
            c.close();
        }
        return false;
    }
}
  1. Androidmanifest.xml清單文件中,程序運行必備的內容一般都已經自動完成添加了。也可以進行修改:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.sqlite_android">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".RegisterActivity">
            <!--<intent-filter>-->
            <!--<action android:name="android.intent.action.MAIN" />-->

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

        <activity android:name=".LoginActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN"/>
                <category android:name="android.intent.category.LAUNCHER"/>
            </intent-filter>
        </activity>
        <activity android:name=".MainActivity">
<!--            <intent-filter>-->
<!--                <action android:name="android.intent.action.MAIN"/>-->
<!--                <category android:name="android.intent.category.LAUNCHER"/>-->
<!--            </intent-filter>-->
        </activity>
        <!--<uses-library android:name="android.test.runner"/>-->
    </application>
</manifest>

在模擬器或者真機運行程序,即可,一個連接數據庫的登錄註冊功能已經實現,效果如下:

在這裏插入圖片描述
在這裏插入圖片描述在這裏插入圖片描述

在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章