数据库继承类mydbhelpe
import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import androidx.annotation.Nullable; public class mydbhelp extends SQLiteOpenHelper { public mydbhelp(@Nullable Context context) { super(context, "jwc.db", null, 1); } @Override public void onCreate(SQLiteDatabase db) { String sql = "CREATE TABLE cart(_id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), price VARCHAR(20), number VARCHAR(20))"; db.execSQL(sql); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { } }
list view适配器
import android.content.Context; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.TextView; import java.util.List; public class myadapter extends BaseAdapter { private List<dxl> list; private LayoutInflater layoutInflater; public myadapter(Context context, List<dxl> list){ this.layoutInflater = LayoutInflater.from(context); this.list = list; } @Override public int getCount() { Log.e("yanwenhua","list.size()--"+list.size()); return list.size(); } @Override public Object getItem(int position) { return null; } @Override public long getItemId(int position) { return 0; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder viewHolder; if (convertView==null){ convertView=layoutInflater.inflate(R.layout.list,null); viewHolder=new ViewHolder(convertView); convertView.setTag(viewHolder); }else { viewHolder=(ViewHolder) convertView.getTag(); } dxl dxl = list.get(position); viewHolder.tv_name.setText("商品名称:"+dxl.getName()); viewHolder.tv_price.setText("商品价格:"+dxl.getPrice()); viewHolder.tv_number.setText("商品数量:"+dxl.getNumber()); Log.e("yanwenhua","cartBean.getName()-"+dxl.getName()+" "+dxl.getPrice()+" "+dxl.getNumber()); return convertView; } class ViewHolder{ TextView tv_name; TextView tv_price; TextView tv_number; public ViewHolder(View view){ tv_name = (TextView) view.findViewById(R.id.tv_name); tv_price = (TextView) view.findViewById(R.id.tv_price); tv_number = (TextView) view.findViewById(R.id.tv_number); } } }
自定义面向对象封装类
package com.tianwengeek.zy1107; public class dxl { private String name; private String price; private String number; public String getName() { return name; } public void setName(String name) { this.name = name; } public String getPrice() { return price; } public void setPrice(String price) { this.price = price; } public String getNumber() { return number; } public void setNumber(String number) { this.number = number; } }
mainactivity。java
package com.tianwengeek.zy1107; import androidx.appcompat.app.AppCompatActivity; import android.content.ContentValues; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.os.Bundle; import android.util.Log; import android.view.View; import android.widget.Button; import android.widget.EditText; import android.widget.ListView; import android.widget.Toast; import java.util.ArrayList; import java.util.List; public class MainActivity extends AppCompatActivity implements View.OnClickListener { private EditText et_n,et_p,et_nu; private ListView listView; private String name,price,number; private mydbhelp mydb; private SQLiteDatabase db; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); def(); } public void def(){ et_n = (EditText)findViewById(R.id.et_name); et_p = (EditText)findViewById(R.id.et_price); et_nu = (EditText) findViewById(R.id.et_number); listView = (ListView)findViewById(R.id.listView); Button add = (Button)findViewById(R.id.add); Button query =(Button) findViewById(R.id.query); Button update =(Button) findViewById(R.id.update); Button delete = (Button)findViewById(R.id.delete); add.setOnClickListener(this); query.setOnClickListener(this); update.setOnClickListener(this); delete.setOnClickListener(this); mydb = new mydbhelp(this); } @Override public void onClick(View v) { switch (v.getId()){ case R.id.add: db = mydb.getWritableDatabase(); name = et_n.getText().toString(); price = et_p.getText().toString(); number = et_n.getText().toString(); ContentValues values = new ContentValues(); values.put("name", name); values.put("price", price); values.put("number", number); db.insert("cart", null, values); db.close(); Toast.makeText(this, "已添加购物车", Toast.LENGTH_SHORT).show(); break; case R.id.query: List<dxl> list = new ArrayList(); db = mydb.getWritableDatabase(); Cursor cursor = db.query("cart", null, null, null, null, null, null); if (cursor.getCount() == 0) { Toast.makeText(this, "商品不存在", Toast.LENGTH_SHORT).show(); } else { while (cursor.moveToNext()) { dxl dy = new dxl(); int nameIndex = cursor.getColumnIndex("name"); int priceIndex = cursor.getColumnIndex("price"); int numberIndex = cursor.getColumnIndex("number"); String name = cursor.getString(nameIndex); String price = cursor.getString(priceIndex); String number = cursor.getString(numberIndex); dy.setName(name); dy.setPrice(price); dy.setNumber(number); list.add(dy); } myadapter adapter = new myadapter(MainActivity.this,list); listView.setAdapter(adapter); adapter.notifyDataSetChanged(); } cursor.close(); db.close(); break; case R.id.update: name = et_n.getText().toString(); price = et_p.getText().toString(); number = et_n.getText().toString(); db = mydb.getWritableDatabase(); values = new ContentValues(); values.put("number",number); values.put("price",price); db.update("cart", values, "name=?", new String[]{name}); db.close(); Toast.makeText(this, "商品信息已修改", Toast.LENGTH_SHORT).show(); break; case R.id.delete: db = mydb.getWritableDatabase(); db.delete("cart", null, null); List<dxl> list2 = new ArrayList(); myadapter adapter = new myadapter(MainActivity.this,list2); listView.setAdapter(adapter); adapter.notifyDataSetChanged(); db.close(); Toast.makeText(this, "已清空购物车", Toast.LENGTH_SHORT).show(); break; } } }
UI布局
<?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:background="#E6E6E6" android:orientation="vertical" android:padding="10dp"> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="15dp" android:background="@android:color/white" android:orientation="horizontal"> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="15dp" android:layout_weight="1" android:background="@android:color/white" android:orientation="horizontal"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:padding="10dp" android:text="名称:" android:textColor="#000" android:textSize="20sp" /> <EditText android:id="@+id/et_name" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginLeft="5dp" android:background="@drawable/es" android:padding="10dp" android:maxLines="1"/> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="15dp" android:layout_weight="1" android:background="@android:color/white" android:orientation="horizontal"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:padding="10dp" android:text="价格:" android:textColor="#000" android:textSize="20sp" /> <EditText android:id="@+id/et_price" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginLeft="5dp" android:background="@drawable/es" android:padding="10dp" android:maxLines="1"/> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="10dp" android:layout_weight="1" android:background="@android:color/white" android:orientation="horizontal"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:padding="10dp" android:text="数量:" android:textColor="#000" android:textSize="20sp" /> <EditText android:id="@+id/et_number" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginLeft="5dp" android:background="@drawable/es" android:padding="10dp" android:maxLines="1"/> </LinearLayout> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" android:layout_marginTop="40dp"> <Button android:id="@+id/add" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@drawable/bs" android:layout_weight="1" android:text="添加"/> <Button android:id="@+id/query" android:layout_weight="1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@drawable/bs" android:text="查询"/> <Button android:id="@+id/update" android:layout_weight="1" android:background="@drawable/bs" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="修改"/> <Button android:id="@+id/delete" android:layout_weight="1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@drawable/bs" android:text="删除"/> </LinearLayout> <ListView android:id="@+id/listView" android:layout_marginTop="20sp" android:layout_width="wrap_content" android:layout_height="match_parent" android:background="#ffffff"> </ListView> </LinearLayout>
list-menu
<?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:padding="10dp"> <TextView android:id="@+id/tv_name" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="15sp"/> <TextView android:id="@+id/tv_price" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="3dp" android:textSize="15sp"/> <TextView android:id="@+id/tv_number" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="3dp" android:textSize="15sp"/> </LinearLayout>