-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathDataBaseHelper.java
More file actions
85 lines (70 loc) · 2.91 KB
/
DataBaseHelper.java
File metadata and controls
85 lines (70 loc) · 2.91 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
package com.example.finaleapp;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
class DatabaseHelper extends SQLiteOpenHelper {
public static final String DATABASE_NAME = "UserDatabase.db";
public static final int DATABASE_VERSION = 1;
public static final String TABLE_NAME = "Users";
public static final String COLUMN_ID = "id";
public static final String COLUMN_USERNAME = "username";
public static final String COLUMN_PASSWORD = "password";
public DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
String CREATE_TABLE = "CREATE TABLE " + TABLE_NAME + "(" +
COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +
COLUMN_USERNAME + " TEXT, " +
COLUMN_PASSWORD + " TEXT)";
db.execSQL(CREATE_TABLE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);
onCreate(db);
}
// Register user
public boolean registerUser(String username, String password) {
if (checkUserExists(username)) return false;
SQLiteDatabase db = this.getWritableDatabase();
ContentValues values = new ContentValues();
values.put(COLUMN_USERNAME, username);
values.put(COLUMN_PASSWORD, password);
long result = db.insert(TABLE_NAME, null, values);
db.close();
return result != -1;
}
// Check login
public boolean loginUser(String username, String password) {
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.query(TABLE_NAME, null, COLUMN_USERNAME + "=? AND " + COLUMN_PASSWORD + "=?",
new String[]{username, password}, null, null, null);
boolean result = cursor.getCount() > 0;
cursor.close();
db.close();
return result;
}
// Update password
public boolean updatePassword(String username, String newPassword) {
if (!checkUserExists(username)) return false;
SQLiteDatabase db = this.getWritableDatabase();
ContentValues values = new ContentValues();
values.put(COLUMN_PASSWORD, newPassword);
int rows = db.update(TABLE_NAME, values, COLUMN_USERNAME + "=?", new String[]{username});
db.close();
return rows > 0;
}
// Check if user exists
public boolean checkUserExists(String username) {
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.query(TABLE_NAME, null, COLUMN_USERNAME + "=?", new String[]{username}, null, null, null);
boolean exists = cursor.getCount() > 0;
cursor.close();
db.close();
return exists;
}
}