【例5-5】 创建与删除数据库
编写一个数据库的演示程序,创建与删除数据库,数据库命名为eBook.db。

教学视频
布局文件activity_db.xml的源代码
<?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"
android:orientation="vertical"
android:layout_marginLeft="20dp"
android:layout_marginRight="20dp"
android:layout_marginTop="100dp"
>
<Button
android:id="@+id/createdb"
android:layout_width="178dp"
android:layout_height="40dp"
android:text="重建数据库"
android:textSize="18sp" />
<Button
android:id="@+id/deletedb"
android:layout_width="178dp"
android:layout_height="40dp"
android:text="删除数据库"
android:textSize="18sp" />
<TextView
android:id="@+id/txt"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:layout_marginTop="50dp"
android:text="数据库测试"
android:textSize="24sp" />
</LinearLayout>
控制文件DBActivity.java源代码
package com.myapp.chap05;
import androidx.appcompat.app.AppCompatActivity;
import android.content.Context;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;
public class DBActivity extends AppCompatActivity
{
Button creatBtn, deleteBtn;
TextView txt;
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_db);
txt = (TextView)findViewById(R.id.txt);
creatBtn=(Button)findViewById(R.id.createdb);
creatBtn.setOnClickListener(new mClick());
deleteBtn=(Button)findViewById(R.id.deletedb);
deleteBtn.setOnClickListener(new mClick());
}
class mClick implements View.OnClickListener
{
@Override
public void onClick(View arg0)
{
if(arg0 == creatBtn)
{
MySQLDatabase db = new MySQLDatabase();
Toast.makeText(DBActivity.this, "数据库和数据表创建成功", Toast.LENGTH_SHORT).show();
txt.setText("创建数据库成功");
}
else if(arg0 == deleteBtn)
{
deleteDatabase(MySQLDatabase.Database_name);
Toast.makeText(DBActivity.this, "数据库删除成功", Toast. LENGTH_SHORT).show();
txt.setText("删除数据库成功");
}
}
}
class MySQLDatabase
{
static final String Database_name = "eBook.db";
private MySQLDatabase()
{
SQLiteDatabase db;
String TABLE_NAME = "diary"; //数据表名
String ID = "nid"; //ID编号
String TITLE = "title"; //用户名
String BODY = "body"; //联系电话
String DATABASE_CREATE =
"CREATE TABLE IF NOT EXISTS " + TABLE_NAME + " ("
+ ID + " INTEGER primary key autoincrement,"
+ TITLE + " text not null, "
+ BODY + " text not null);";
int mode = Context.MODE_PRIVATE;
db = openOrCreateDatabase(Database_name, mode, null);//创建数据库
db.execSQL(DATABASE_CREATE);//创建数据表
}
}
}
打开项目配置文件AndroidManifest.xml,配置要启动的Activity类名
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.chap05">
<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=".DBActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>

