代码在下方
Android连接SQLite
1.SQLite简介:
-
轻量级:
使用 SQLite 只需要带一个动态库,就可以享受它的全部功能, 而且那个动态库的尺寸想当小。
-
独立级:
SQLite 数据库的核心引擎不需要依赖第三方软件,也不需要所谓的“安装”。
-
隔离性
SQLite 数据库中所有的信息(比如表、视图、触发器等) 都包含在一个文件夹内,方便管理和维护。
-
跨平台
- SQLite 目前支持大部分操作系统,不至电脑操作系统更在众多的手机系统 也是能够运行,比如:Android。
-
多语言接口
SQLite 数据库支持多语言编程接口。
-
安全性
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.项目目录:
- 添加布局文件——主界面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>
- 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>
- 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>
- 在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) {
}
}
- 在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;
}
}
- 在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 + "]";
}
}
- 为登陆功能添加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);
}
});
}
}
- 为注册功能添加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);
}
}
- 登陆成功后跳转的显示见面——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;
}
}
- 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>
在模拟器或者真机运行程序,即可,一个连接数据库的登录注册功能已经实现,效果如下: