SQLite 和 SQLiteDatabase 的使用

实验七:SQLite 和 SQLiteDatabase 的使用

7.1 实验目的

本次实验的目的是让大家熟悉 Android 中对数据库进行操作的相关的接口、类等。SQLiteDatabase 这个是在 android 中数据库操作使用最频繁的一个类。通过它可以实现数据库的创建或打开、创建表、插入数据、删除数据、查询数据、修改数据等操作。

7.2 实验要求

  • 实现便签管理小例程。
  • 创建项目并熟悉文件目录结构
  • 实现便签增删改查功能的实验步骤

7.3 实验内容

【练习 7.1】 便签管理小例程
步骤 1: 项目结构

创建一个名为"便签管理系统"的Android项目,包含以下文件和文件夹:

  • activity_main.xml (启动窗体)
  • insertinfo.xml (新增便签窗体)
  • showinfo.xml (查看便签信息窗体)
  • manageflag.xml (便签管理窗体)
  • MainActivity.java (主活动)
  • InsertFlag.java (新增便签活动)
  • ShowInfo.java (查看便签信息活动)
  • ManageFlag.java (便签管理活动)
  • DBOpenHelper.java (数据库帮助类)
  • FlagDao.java (便签数据访问类)
  • flag.java (便签实体类)
  • AndroidManifest.xml (清单文件)
步骤 2: 配置布局文件
  1. activity_main.xml (启动窗体)

    • 包含两个按钮:btnflaginfo (查看便签信息) 和 btninsertinfo (添加便签)

      <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="fill_parent"android:layout_height="fill_parent"android:orientation="vertical"><LinearLayoutandroid:id="@+id/linearLayout1"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_weight="0.06"android:orientation="vertical"><RelativeLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"><Buttonandroid:id="@+id/btnflaginfo"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="便签信息"android:textColor="#8C6931"android:textSize="20dp" /><Buttonandroid:id="@+id/btninsertinfo"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_toRightOf="@id/btnflaginfo"android:text="添加便签"android:textColor="#8C6931"android:textSize="20dp" /></RelativeLayout></LinearLayout>
      </LinearLayout>
      
  2. Insertinfo.xml (新增便签窗体)

    • 包含一个文本框 txtFlag 用于输入便签内容

    • 包含两个按钮:btnflagSave (保存) 和 btnflagCancel (取消)

      <?xml version="1.0" encoding="utf-8"?>
      <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:id="@+id/itemflag"android:layout_width="fill_parent"android:layout_height="fill_parent"android:orientation="vertical"><LinearLayoutandroid:layout_width="fill_parent"android:layout_height="fill_parent"android:layout_weight="3"android:orientation="vertical"><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="center"android:gravity="center_horizontal"android:text="新增便签"android:textColor="#000000"android:textSize="40sp"android:textStyle="bold" /></LinearLayout><LinearLayoutandroid:layout_width="fill_parent"android:layout_height="fill_parent"android:layout_weight="1"android:orientation="vertical"><RelativeLayoutandroid:layout_width="fill_parent"android:layout_height="fill_parent"android:padding="5dp"><TextViewandroid:id="@+id/tvFlag"android:layout_width="350dp"android:layout_height="wrap_content"android:layout_alignParentRight="true"android:text="请输入便签,最多输入 200 字"android:textColor="#8C6931"android:textSize="23sp" /><EditTextandroid:id="@+id/txtFlag"android:layout_width="350dp"android:layout_height="400dp"android:layout_below="@id/tvFlag"android:gravity="top"android:singleLine="false" /></RelativeLayout></LinearLayout><LinearLayoutandroid:layout_width="fill_parent"android:layout_height="fill_parent"android:layout_weight="3"android:orientation="vertical"><RelativeLayoutandroid:layout_width="fill_parent"android:layout_height="fill_parent"android:padding="10dp"><Buttonandroid:id="@+id/btnflagCancel"android:layout_width="80dp"android:layout_height="wrap_content"android:layout_alignParentRight="true"android:layout_marginLeft="10dp"android:text="取消" /><Buttonandroid:id="@+id/btnflagSave"android:layout_width="80dp"android:layout_height="wrap_content"android:layout_toLeftOf="@id/btnflagCancel"android:maxLength="200"android:text="保存" /></RelativeLayout></LinearLayout>
      </LinearLayout>
      
  3. showinfo.xml (查看便签信息窗体)

    • 包含一个文本视图 textView1 和一个列表视图 lvinfo 用于展示便签信息
    <?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"><TextViewandroid:id="@+id/textView1"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="便签信息"android:textSize="20dp" /><LinearLayoutandroid:id="@+id/linearLayout2"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_weight="0.94"android:orientation="vertical"><ListViewandroid:id="@+id/lvinfo"android:layout_width="match_parent"android:layout_height="match_parent"android:scrollbarAlwaysDrawVerticalTrack="true" /></LinearLayout>
    </LinearLayout>
    
  4. manageflag.xml (便签管理窗体)

    • 包含一个文本框 txtFlagManage 和两个按钮:btnFlagManageEdit (修改) 和 btnFlagManageDelete (删除)
    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:id="@+id/flagmanage"android:layout_width="fill_parent"android:layout_height="fill_parent"android:orientation="vertical"><LinearLayoutandroid:layout_width="fill_parent"android:layout_height="fill_parent"android:layout_weight="3"android:orientation="vertical"><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="center"android:gravity="center_horizontal"android:text="便签管理"android:textColor="#000000"android:textSize="40sp"android:textStyle="bold" /></LinearLayout><LinearLayoutandroid:layout_width="fill_parent"android:layout_height="fill_parent"android:layout_weight="1"android:orientation="vertical"><RelativeLayoutandroid:layout_width="fill_parent"android:layout_height="fill_parent"android:padding="5dp"><TextViewandroid:id="@+id/tvFlagManage"android:layout_width="350dp"android:layout_height="wrap_content"android:layout_alignParentRight="true"android:text="请输入便签,最多输入 200 字"android:textColor="#8C6931"android:textSize="23sp" /><EditTextandroid:id="@+id/txtFlagManage"android:layout_width="350dp"android:layout_height="400dp"android:layout_below="@id/tvFlagManage"android:gravity="top"android:singleLine="false" /></RelativeLayout></LinearLayout><LinearLayoutandroid:layout_width="fill_parent"android:layout_height="fill_parent"android:layout_weight="3"android:orientation="vertical"><RelativeLayoutandroid:layout_width="fill_parent"android:layout_height="fill_parent"android:padding="10dp"><Buttonandroid:id="@+id/btnFlagManageDelete"android:layout_width="80dp"android:layout_height="wrap_content"android:layout_alignParentRight="true"android:layout_marginLeft="10dp"android:text="删除" /><Buttonandroid:id="@+id/btnFlagManageEdit"android:layout_width="80dp"android:layout_height="wrap_content"android:layout_toLeftOf="@id/btnFlagManageDelete"android:maxLength="200"android:text="修改" /></RelativeLayout></LinearLayout>
    </LinearLayout>
    
步骤 3: 配置活动文件
  1. MainActivity.java

    • 初始化界面和按钮
    • 为按钮添加点击事件,分别跳转到 ShowInfoInsertFlag 活动
    package com.example.notemanagementsystem.activity;import android.os.Bundle;
    import android.app.Activity;
    import android.content.Intent;
    import android.view.Menu;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;import com.wenlong.DBLab.activity.R;public class MainActivity extends Activity {Button btnflaginfo, btninsertinfo;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);btnflaginfo = (Button) findViewById(R.id.btnflaginfo);btninsertinfo = (Button) findViewById(R.id.btninsertinfo);btnflaginfo.setOnClickListener(new OnClickListener() {@Overridepublic void onClick(View v) {Intent intent = new Intent(MainActivity.this, ShowInfo.class);startActivity(intent);}});btninsertinfo.setOnClickListener(new OnClickListener() {@Overridepublic void onClick(View v) {Intent intent = new Intent(MainActivity.this, InsertFlag.class);startActivity(intent);}});}@Overridepublic boolean onCreateOptionsMenu(Menu menu) {// Inflate the menu; this adds items to the action bar if it is present.getMenuInflater().inflate(R.menu.main, menu);return true;}
    }
    
  2. InsertFlag.java

    • 处理新增便签的界面逻辑
    • 获取输入的便签内容,保存到数据库,并显示相应的提示信息
    package com.example.notemanagementsystem;import android.app.Activity;
    import android.os.Bundle;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;
    import android.widget.EditText;
    import android.widget.Toast;import com.example.notemanagementsystem.DAO.FlagDao;
    import com.example.notemanagementsystem.model.flag;public class InsertFlag extends Activity {EditText txtFlag;// 创建 EditText 组件对象Button btnflagSaveButton;// 创建 Button 组件对象Button btnflagCancelButton;// 创建 Button 组件对象@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.insertinfo);txtFlag = (EditText) findViewById(R.id.txtFlag);btnflagSaveButton = (Button) findViewById(R.id.btnflagSave);btnflagCancelButton = (Button) findViewById(R.id.btnflagCancel);btnflagSaveButton.setOnClickListener(new OnClickListener() {@Overridepublic void onClick(View v) {String strFlag = txtFlag.getText().toString();// 获取便签文本框的值if (!strFlag.isEmpty()) {// 判断获取FlagDao flagDAO = new FlagDao(InsertFlag.this);// 创建FlagDAO 对象flag flag = new flag(flagDAO.getMaxId() + 1, strFlag);// 创建 Tb_flag 对象flagDAO.add(flag);// 添加便签信息// 弹出信息提示Toast.makeText(InsertFlag.this, "〖新增便签〗数据添加成功!",Toast.LENGTH_SHORT).show();} else {Toast.makeText(InsertFlag.this, "请输入便签!",Toast.LENGTH_SHORT).show();}}});btnflagCancelButton.setOnClickListener(new OnClickListener() {@Overridepublic void onClick(View v) {finish();}});}
    }
    
  3. ShowInfo.java

    • 展示所有便签信息的界面逻辑
    • 使用 ListView 显示便签列表,点击某一项跳转到 ManageFlag 活动
    package com.example.notemanagementsystem;import android.app.Activity;
    import android.content.Intent;
    import android.os.Bundle;
    import android.view.View;
    import android.widget.AdapterView;
    import android.widget.AdapterView.OnItemClickListener;
    import android.widget.ArrayAdapter;
    import android.widget.ListView;
    import android.widget.TextView;import com.example.notemanagementsystem.DAO.FlagDao;
    import com.example.notemanagementsystem.model.flag;import java.util.List;public class ShowInfo extends Activity {public static final String FLAG = "id";// 定义一个常量,用来作为请求码ListView lvinfo;// 创建 ListView 对象String[] strInfos = null;// 定义字符串数组,用来存储收入信息ArrayAdapter<String> arrayAdapter = null;// 创建 ArrayAdapter 对象@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.showinfo);lvinfo = (ListView) findViewById(R.id.lvinfo);FlagDao flaginfo = new FlagDao(ShowInfo.this);// 创建 FlagDAO 对象// 获取所有便签信息,并存储到 List 泛型集合中List<flag> listFlags = flaginfo.getScrollData(0,(int) flaginfo.getCount());strInfos = new String[listFlags.size()];// 设置字符串数组的长度int n = 0;// 定义一个开始标识for (flag tb_flag : listFlags) {// 将便签相关信息组合成一个字符串,存储到字符串数组的相应位置strInfos[n] = tb_flag.getid() + "|" + tb_flag.getFlag();if (strInfos[n].length() > 15)// 判断便签信息的长度是否大于 15strInfos[n] = strInfos[n].substring(0, 15) + "……";// 将位置大于 15之后的字符串用……代替n++;// 标识加 1}arrayAdapter = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1, strInfos);lvinfo.setAdapter(arrayAdapter);lvinfo.setOnItemClickListener(new OnItemClickListener() {@Overridepublic void onItemClick(AdapterView<?> parent, View view, int position,long id) {String strInfo = String.valueOf(((TextView) view).getText());// 记录单击的项信息String strid = strInfo.substring(0, strInfo.indexOf('|'));// 从项信息中截取编号Intent intent = null;// 创建 Intent 对象intent = new Intent(ShowInfo.this, ManageFlag.class);// 使用 FlagManage 窗口初始化 Intent 对象intent.putExtra(FLAG, strid);// 设置要传递的数据startActivity(intent);// 执行 Intent,打开相应的 Activity}});}
    }
    
  4. ManageFlag.java

    • 处理便签管理的界面逻辑
    • 获取传递的便签id,显示该便签内容,可进行编辑和删除操作
    package com.example.notemanagementsystem;import android.app.Activity;
    import android.content.Intent;
    import android.os.Bundle;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;
    import android.widget.EditText;
    import android.widget.Toast;import com.example.notemanagementsystem.DAO.FlagDao;
    import com.example.notemanagementsystem.model.flag;public class ManageFlag extends Activity {EditText txtFlag;// 创建 EditText 对象Button btnEdit, btnDel;// 创建两个 Button 对象String strid;// 创建字符串,表示便签的 id@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.manageflag);txtFlag = (EditText) findViewById(R.id.txtFlagManage);btnEdit = (Button) findViewById(R.id.btnFlagManageEdit);btnDel = (Button) findViewById(R.id.btnFlagManageDelete);Intent intent = getIntent();// 创建 Intent 对象Bundle bundle = intent.getExtras();// 获取便签 idstrid = bundle.getString(ShowInfo.FLAG);// 将便签 id 转换为字符串final FlagDao flagDAO = new FlagDao(ManageFlag.this);// 创建 FlagDAO 对象txtFlag.setText(flagDAO.find(Integer.parseInt(strid)).getFlag());// 为修改按钮设置监听事件btnEdit.setOnClickListener(new OnClickListener() {@Overridepublic void onClick(View v) {flag tb_flag = new flag();// 创建 Tb_flag 对象tb_flag.setid(Integer.parseInt(strid));// 设置便签 idtb_flag.setFlag(txtFlag.getText().toString());// 设置便签值flagDAO.update(tb_flag);// 修改便签信息// 弹出信息提示Toast.makeText(ManageFlag.this, "〖便签数据〗修改成功!",Toast.LENGTH_SHORT).show();}});// 为删除按钮设置监听事件btnDel.setOnClickListener(new OnClickListener() {@Overridepublic void onClick(View v) {flagDAO.detele(Integer.parseInt(strid));// 根据指定的 id 删除便签信息Toast.makeText(ManageFlag.this, "〖便签数据〗删除成功!",Toast.LENGTH_SHORT).show();}});}
    }
    
步骤 4: 配置数据库相关文件
  1. DBOpenHelper.java

    • 创建数据库,定义便签信息表结构
    package com.example.notemanagementsystem.DAO;import android.content.Context;
    import android.database.sqlite.SQLiteDatabase;
    import android.database.sqlite.SQLiteOpenHelper;public class DBOpenHelper extends SQLiteOpenHelper {private static final int VERSION = 1;// 定义数据库版本号private static final String DBNAME = "flag.db";// 定义数据库名public DBOpenHelper(Context context) {super(context, DBNAME, null, VERSION);}@Overridepublic void onCreate(SQLiteDatabase db) // 创建数据库{db.execSQL("create table tb_flag (_id integer primary key,flag varchar(200)) ");// 创建便签信息表}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) // 覆写基类的 onUpgrade方法,以便数据库版本更新{}
    }
    
  2. FlagDao.java

    • 提供对便签表的增删改查操作
    • 包含获取便签总记录数和最大编号的方法
    package com.example.notemanagementsystem.DAO;import java.util.ArrayList;
    import java.util.List;import android.content.Context;
    import android.database.Cursor;
    import android.database.sqlite.SQLiteDatabase;import com.example.notemanagementsystem.DAO.DBOpenHelper;
    import com.example.notemanagementsystem.model.flag;public class FlagDao {private DBOpenHelper helper;// 创建 DBOpenHelper 对象private SQLiteDatabase db;// 创建 SQLiteDatabase 对象public FlagDao(Context context)// 定义构造函数{helper = new DBOpenHelper(context);// 初始化 DBOpenHelper 对象}/*** 添加便签信息** @param tb_flag*/public void add(flag flag) {db = helper.getWritableDatabase();// 初始化 SQLiteDatabase 对象db.execSQL("insert into tb_flag (_id,flag) values (?,?)", new Object[]{flag.getid(), flag.getFlag()});// 执行添加便签信息操作}/*** 更新便签信息** @param tb_flag*/public void update(flag tb_flag) {db = helper.getWritableDatabase();// 初始化 SQLiteDatabase 对象db.execSQL("update tb_flag set flag = ? where _id = ?", new Object[]{tb_flag.getFlag(), tb_flag.getid()});// 执行修改便签信息操作}/*** 查找便签信息** @param id* @return*/public flag find(int id) {db = helper.getWritableDatabase();// 初始化 SQLiteDatabase 对象Cursor cursor = db.rawQuery("select _id,flag from tb_flag where _id = ?",new String[]{String.valueOf(id)});// 根据编号查找便签信息,并存储到 Cursor 类中if (cursor.moveToNext())// 遍历查找到的便签信息{// 将遍历到的便签信息存储到 Tb_flag 类中return new flag(cursor.getInt(cursor.getColumnIndex("_id")), cursor.getString(cursor.getColumnIndex("flag")));}return null;// 如果没有信息,则返回 null}/*** 刪除便签信息** @param ids*/public void detele(Integer... ids) {if (ids.length > 0)// 判断是否存在要删除的 id{StringBuffer sb = new StringBuffer();// 创建 StringBuffer 对象for (int i = 0; i < ids.length; i++)// 遍历要删除的 id 集合{sb.append('?').append(',');// 将删除条件添加到 StringBuffer 对象中}sb.deleteCharAt(sb.length() - 1);// 去掉最后一个“,“字符db = helper.getWritableDatabase();// 创建 SQLiteDatabase 对象// 执行删除便签信息操作db.execSQL("delete from tb_flag where _id in (" + sb + ")",(Object[]) ids);}}/*** 获取便签信息** @param start 起始位置* @param count 每页显示数量* @return*/public List<flag> getScrollData(int start, int count) {List<flag> lisTb_flags = new ArrayList<flag>();// 创建集合对象db = helper.getWritableDatabase();// 初始化 SQLiteDatabase 对象// 获取所有便签信息Cursor cursor = db.rawQuery("select * from tb_flag limit ?,?",new String[]{String.valueOf(start), String.valueOf(count)});while (cursor.moveToNext())// 遍历所有的便签信息{// 将遍历到的便签信息添加到集合中lisTb_flags.add(new flag(cursor.getInt(cursor.getColumnIndex("_id")), cursor.getString(cursor.getColumnIndex("flag"))));}return lisTb_flags;// 返回集合}/*** 获取总记录数** @return*/public long getCount() {db = helper.getWritableDatabase();// 初始化 SQLiteDatabase 对象Cursor cursor = db.rawQuery("select count(_id) from tb_flag", null);// 获取便签信息的记录数if (cursor.moveToNext())// 判断 Cursor 中是否有数据{return cursor.getLong(0);// 返回总记录数}return 0;// 如果没有数据,则返回 0}/*** 获取便签最大编号** @return*/public int getMaxId() {db = helper.getWritableDatabase();// 初始化 SQLiteDatabase 对象Cursor cursor = db.rawQuery("select max(_id) from tb_flag", null);// 获取便签信息表中的最大编号while (cursor.moveToLast()) {// 访问 Cursor 中的最后一条数据return cursor.getInt(0);// 获取访问到的数据,即最大编号}return 0;// 如果没有数据,则返回 0}
    }
    
  3. flag.java

    • 定义便签实体类,包含编号和便签内容
    package com.example.notemanagementsystem.model;public class flag {private int _id;// 存储便签编号private String flag;// 存储便签信息public flag()// 默认构造函数{super();}// 定义有参构造函数,用来初始化便签信息实体类中的各个字段public flag(int id, String flag) {super();this._id = id;// 为便签号赋值this.flag = flag;// 为便签信息赋值}public int getid()// 设置便签编号的可读属性{return _id;}public void setid(int id)// 设置便签编号的可写属性{this._id = id;}public String getFlag()// 设置便签信息的可读属性{return flag;}public void setFlag(String flag)// 设置便签信息的可写属性{this.flag = flag;}
    }
    
步骤 5: 配置清单文件
  1. AndroidManifest.xml

    • 配置主活动为 MainActivity
    • 配置其他三个活动: ShowInfo, InsertFlag, ManageFlag
    <?xml version="1.0" encoding="utf-8"?>
    <manifest xmlns:android="http://schemas.android.com/apk/res/android"package="com.wenlong.DBLab.activity"android:versionCode="1"android:versionName="1.0"><uses-sdkandroid:minSdkVersion="8"android:targetSdkVersion="18" /><applicationandroid:allowBackup="true"android:icon="@drawable/ic_launcher"android:label="@string/app_name"android:theme="@style/AppTheme"><activityandroid:name="com.example.notemanagementsystem.MainActivity"android:label="@string/app_name"><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter></activity><activityandroid:name="com.example.notemanagementsystem.ShowInfo"android:icon="@drawable/ic_launcher"android:label="便签信息"></activity><activityandroid:name="com.example.notemanagementsystem.InsertFlag"android:icon="@drawable/ic_launcher"android:label="添加便签"></activity><activityandroid:name="com.example.notemanagementsystem.ManageFlag"android:icon="@drawable/ic_launcher"android:label="便签管理"></activity></application>
    </manifest>
    
步骤 6: 运行与测试

1.文档结构

image-20231124152548336

2.运行效果

image-20231124152727243

image-20231124152751315

【拓展题】编写 Android 项目,实现商品库存数据库管理小系统。
步骤一:创建新的 Android 项目
  1. 打开 Android Studio。
  2. 选择 “File” -> “New” -> “New Project…”。
  3. 在弹出的对话框中,输入项目名称为 “InventoryManagementSystem”,选择语言为 Java,选择 “Phone and Tablet” -> “Empty Activity”,然后点击 “Finish”。
步骤二:创建数据库帮助类(DBOpenHelper)

在项目中创建一个用于管理数据库的帮助类。

DBOpenHelper.java
package com.example.inventorymanagementsystem.database;import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;public class DBOpenHelper extends SQLiteOpenHelper {private static final String DB_NAME = "inventory.db";private static final int DB_VERSION = 1;public DBOpenHelper(Context context) {super(context, DB_NAME, null, DB_VERSION);}@Overridepublic void onCreate(SQLiteDatabase db) {// 创建商品表db.execSQL("CREATE TABLE IF NOT EXISTS products (" +"_id INTEGER PRIMARY KEY AUTOINCREMENT," +"name TEXT," +"quantity INTEGER," +"price REAL)");}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {// 数据库升级操作}
}
步骤三:创建商品实体类(Product)

创建一个用于表示商品的实体类。

Product.java

package com.example.inventorymanagementsystem.model;public class Product {private int id;private String name;private int quantity;private double price;public Product() {}public Product(String name, int quantity, double price) {this.name = name;this.quantity = quantity;this.price = price;}// Getter and setter methods
}
步骤四:创建商品数据操作类(ProductDAO)

创建一个用于执行商品数据操作的类。

ProductDAO.java

package com.example.inventorymanagementsystem.database;import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import com.example.inventorymanagementsystem.model.Product;
import java.util.ArrayList;
import java.util.List;public class ProductDAO {private SQLiteDatabase db;public ProductDAO(Context context) {DBOpenHelper dbHelper = new DBOpenHelper(context);db = dbHelper.getWritableDatabase();}public long addProduct(Product product) {ContentValues values = new ContentValues();values.put("name", product.getName());values.put("quantity", product.getQuantity());values.put("price", product.getPrice());return db.insert("products", null, values);}public List<Product> getAllProducts() {List<Product> productList = new ArrayList<>();Cursor cursor = db.query("products", null, null, null, null, null, null);while (cursor.moveToNext()) {Product product = new Product();product.setId(cursor.getInt(cursor.getColumnIndex("_id")));product.setName(cursor.getString(cursor.getColumnIndex("name")));product.setQuantity(cursor.getInt(cursor.getColumnIndex("quantity")));product.setPrice(cursor.getDouble(cursor.getColumnIndex("price")));productList.add(product);}cursor.close();return productList;}// 添加其他数据库操作方法,如更新商品信息、删除商品等
}
步骤五:创建商品管理界面(MainActivity)

res/layout 文件夹中创建一个用于显示商品列表和添加商品的界面布局文件。

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".MainActivity"><ListViewandroid:id="@+id/listViewProducts"android:layout_width="match_parent"android:layout_height="match_parent"android:divider="@android:color/darker_gray"android:dividerHeight="1dp" /><Buttonandroid:id="@+id/btnAddProduct"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="Add Product"android:layout_alignParentBottom="true"android:layout_alignParentEnd="true"android:layout_margin="16dp"/>
</RelativeLayout>

activity_add_product.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"android:padding="16dp"><EditTextandroid:id="@+id/edtProductName"android:layout_width="match_parent"android:layout_height="wrap_content"android:hint="商品名称" /><EditTextandroid:id="@+id/edtProductQuantity"android:layout_width="match_parent"android:layout_height="wrap_content"android:inputType="number"android:hint="数量" /><EditTextandroid:id="@+id/edtProductPrice"android:layout_width="match_parent"android:layout_height="wrap_content"android:inputType="numberDecimal"android:hint="价格" /><Buttonandroid:id="@+id/btnAddProduct"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="添加商品" />
</LinearLayout>

MainActivity.java

package com.example.inventorymanagementsystem;import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.ListView;
import androidx.appcompat.app.AppCompatActivity;
import com.example.inventorymanagementsystem.database.ProductDAO;
import com.example.inventorymanagementsystem.model.Product;
import java.util.List;public class MainActivity extends AppCompatActivity {private ListView listViewProducts;private Button btnAddProduct;private ProductDAO productDAO;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);listViewProducts = findViewById(R.id.listViewProducts);btnAddProduct = findViewById(R.id.btnAddProduct);productDAO = new ProductDAO(this);updateProductList();btnAddProduct.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {Intent intent = new Intent(MainActivity.this, AddProductActivity.class);startActivity(intent);}});}private void updateProductList() {List<Product> productList = productDAO.getAllProducts();ArrayAdapter<Product> adapter = new ArrayAdapter<>(this, android.R.layout.simple_list_item_1, productList);listViewProducts.setAdapter(adapter);}
}

AddProductActivity.java

package com.example.inventorymanagementsystem;import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;import androidx.appcompat.app.AppCompatActivity;
import com.example.inventorymanagementsystem.database.ProductDAO;
import com.example.inventorymanagementsystem.model.Product;public class AddProductActivity extends AppCompatActivity {private EditText edtProductName, edtProductQuantity, edtProductPrice;private Button btnAddProduct;private ProductDAO productDAO;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_add_product);edtProductName = findViewById(R.id.edtProductName);edtProductQuantity = findViewById(R.id.edtProductQuantity);edtProductPrice = findViewById(R.id.edtProductPrice);btnAddProduct = findViewById(R.id.btnAddProduct);productDAO = new ProductDAO(this);btnAddProduct.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {addProduct();}});}private void addProduct() {// 获取用户输入的商品信息String productName = edtProductName.getText().toString();String quantityStr = edtProductQuantity.getText().toString();String priceStr = edtProductPrice.getText().toString();if (!productName.isEmpty() && !quantityStr.isEmpty() && !priceStr.isEmpty()) {int quantity = Integer.parseInt(quantityStr);double price = Double.parseDouble(priceStr);// 创建商品对象Product newProduct = new Product(productName, quantity, price);// 将商品添加到数据库long result = productDAO.addProduct(newProduct);if (result != -1) {Toast.makeText(AddProductActivity.this, "商品添加成功", Toast.LENGTH_SHORT).show();finish(); // 关闭当前界面} else {Toast.makeText(AddProductActivity.this, "商品添加失败", Toast.LENGTH_SHORT).show();}} else {Toast.makeText(AddProductActivity.this, "请填写完整的商品信息", Toast.LENGTH_SHORT).show();}}
}
步骤六:运行效果

image-20231124162406148

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/207268.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python自动化测试——元素定位

1.selenium简介 Selenium是一个用于Web应用程序测试的工具。Selenium是直接运行在浏览器中&#xff0c;模拟用户操作web界面。支持多平台&#xff1a;windows、linux、MAC &#xff0c;支持多浏览器&#xff1a;ie、firefox、chrome等浏览器。 2. 启动浏览器 # 导入webdrive…

Apache Airflow (十四) :Airflow分布式集群搭建及测试

&#x1f3e1; 个人主页&#xff1a;IT贫道_大数据OLAP体系技术栈,Apache Doris,Clickhouse 技术-CSDN博客 &#x1f6a9; 私聊博主&#xff1a;加入大数据技术讨论群聊&#xff0c;获取更多大数据资料。 &#x1f514; 博主个人B栈地址&#xff1a;豹哥教你大数据的个人空间-豹…

OBS Studio 30.0 正式发布:支持 WebRTC

导读OBS Studio 30.0 已正式发布。此版本移除了对 Ubuntu 20.04、Qt 5 和 FFmpeg 4.4 之前版本的支持。 OBS Studio 30.0 已正式发布。此版本移除了对 Ubuntu 20.04、Qt 5 和 FFmpeg 4.4 之前版本的支持。 主要变化包括&#xff1a; 支持 WebRTC&#xff08;详情查看 OBS Stu…

整体迁移SVN仓库到新的windows服务器

一、背景 公司原有的SVN服务器年代比较久远经常出现重启情况&#xff0c;需要把SVN仓库重新迁移到新的服务器上&#xff0c;在网上也搜到过拷贝Repositories文件直接在新服务器覆盖的迁移方案&#xff0c;但考虑到原有的操作系统和现有的操作系统版本不一致&#xff0c;SVN版本…

python的制图

测试数据示例&#xff1a; day report_user_cnt report_user_cnt_2 label 2023-10-01 3 3 欺诈 2023-10-02 2 4 欺诈 2023-10-03 6 5 欺诈 2023-10-04 2 1 正常 2023-10-05 4 3 正常 2023-10-06 4 4 正常 2023-10-07 2 6 正常 2023-10-08 3 7 正常 2023-10-09 3 12 正常 2023-…

代码随想录刷题题Day2

刷题的第二天&#xff0c;希望自己能够不断坚持下去&#xff0c;迎来蜕变。&#x1f600;&#x1f600;&#x1f600; 刷题语言&#xff1a;C / Python Day2 任务 977.有序数组的平方 209.长度最小的子数组 59.螺旋矩阵 II 1 有序数组的平方&#xff08;重点&#xff1a;双指针…

华为电视盒子 EC6108V9C 刷机成linux系统

场景&#xff1a; 提示&#xff1a;这里简述项目相关背景&#xff1a; 家里装宽带的时候会自带电视盒子&#xff0c;但是由于某些原因电视盒子没有用&#xff0c;于是就只能摆在那里吃土&#xff0c;闲来无事&#xff0c;搞一下 问题描述 提示&#xff1a;这里描述项目中遇到…

使用yolov7进行多图像视频识别

1.yolov7你可以让你简单的部署,比起前几代来说特别简单 #下面是我转换老友记的测试视频,可以看到几乎可以准确预测 2.步骤 1.在github官网下载代码 https://github.com/WongKinYiu/yolov7 2.点击下载权重文件放到项目中 3.安装依赖,我的python版本是3.6的 pip install -r requ…

无mac电脑生成uniapp云打包私钥证书的攻略

uniapp顾名思义是一个跨平台的开发工具&#xff0c;大部分uniapp的开发者&#xff0c;其实并没有mac电脑来开发&#xff0c;但是生成ios的证书&#xff0c;官网的教程却是需要mac电脑的&#xff0c;那么有没有办法无需mac电脑即可生成uniapp云打包的私钥证书呢&#xff1f; 下…

【计算机网络】14、DHCP

文章目录 一、概述1.1 好处 二、概念2.1 分配 IP2.2 控制租赁时间2.3 DHCP 的其他网络功能2.4 IP地址范围和用户类别2.5 安全 三、DHCP 消息3.1 DHCP discover message3.2 DHCP offers a message 如果没有 DHCP&#xff0c;IT管理者必须手动选出可用的 ip&#xff0c;这太耗时了…

和鲸科技与国科环宇建立战略合作伙伴关系,以软硬件一体化解决方案促进科技创新

近日&#xff0c;在国科环宇土星云算力服务器产品发布会暨合作伙伴年度会上&#xff0c;和鲸科技与国科环宇正式完成战略伙伴签约仪式&#xff0c;宣布达成战略合作伙伴关系。未来&#xff0c;双方将深化合作&#xff0c;充分发挥在产品和市场方面的互补优势&#xff0c;为企事…

什么是工业物联网(IOT)?这样的IOT平台你需要吗?——青创智通

物联网(IOT)是指在互联网上为传输和共享数据而嵌入传感器和软件的互联设备的广泛性网络。这允许将从物理对象收集的信息(数据)存储在专用服务器或云中。通过分析这些积累的信息&#xff0c;通过提供最优的设备控制和方法&#xff0c;可以实现一个更安全、更方便的社会。在智能家…

【NodeJS】 API Key 实现 短信验证码功能

这里使用的平台是 短信宝整体来讲还是挺麻烦的平台必须企业才行&#xff0c;个人是无法使用该平台的 平台必须完成 身份信息认证 和 企业认证 这里就需要 “营业执照”了 &#xff0c;没有 “营业执照” 的朋友还是后退一步吧 后端我用的是NodeJS &#xff0c;使用第三方库 ro…

【办公软件】电脑开机密码忘记了如何重置?

这个案例是家人的电脑&#xff0c;已经使用多年&#xff0c;又是有小孩操作过的&#xff0c;所以电脑密码根本不记得是什么了&#xff1f;那难道这台电脑就废了吗&#xff1f;需要重新装机吗&#xff1f;那里面的资料不是没有了&#xff1f; 为了解决以上问题&#xff0c;一般…

【云原生系列】Kubernetes知识点

目录 概念 基础架构 单master节点 多master节点 组件 Master节点核心组件 其他组件 请求发送流程 插件 核心资源 调度资源 Pod 创建pod组件间调用流程 pod生命周期&#xff1a; 初始化容器 镜像拉取策略 重启策略 钩子函数 探针 探针的实现方式 DownwardAP…

Git的介绍和下载安装

Git的介绍和下载安装 概述 Git是一个分布式版本控制工具, 通常用来管理项目中的源代码文件(Java类、xml文件、html页面等)进行管理,在软件开发过程中被广泛使用 Git可以记录文件修改的历史记录并形成备份从而实现代码回溯, 版本切换, 多人协作, 远程备份的功能Git具有廉价的…

FPGA falsh相关知识总结

1.存储容量是128M/8 Mb16MB 2.有256个sector扇区*每个扇区64KB16MB 3.一页256Byte 4.页编程地址0256 5&#xff1a;在调试SPI时序的时候一定注意&#xff0c;miso和mosi两个管脚只要没发送数据就一定要悬空&#xff08;处于高组态&#xff09;&#xff0c;不然指令会通过两…

年终好价节入手什么数码合适?盘点23年度值得入手的数码好物

各位科技控和数码迷&#xff01;时间过得飞快&#xff0c;一眨眼2023年就要过去了&#xff0c;说到年底&#xff0c;当然少不了年终好价节啦&#xff01;这时候正是更新你的数码装备、升级生活品质的绝佳时机。别管你是不是科技控&#xff0c;工作狂还是生活追求者&#xff0c;…

JavaWeb服务器详解和后端分层解耦

JavaWeb HTTP协议请求数据格式响应数据格式协议解析 Web服务器请求响应请求参数的接收响应 分层解耦IOC&DI入门IOC详解 HTTP协议 超文本传输协议&#xff0c;规定了浏览器和服务器之间数据传输的规则 特点&#xff1a; 基于TCP协议&#xff1a;面向连接&#xff0c;安全 …

npm WARN npm npm does not support Node.js v13.9.0

Microsoft Windows [版本 10.0.19045.2965] (c) Microsoft Corporation。保留所有权利。C:\Users\Administrator>node -v v13.9.0C:\Users\Administrator>npm -v npm WARN npm npm does not support Node.js v13.9.0 npm WARN npm You should probably upgrade to a newe…