作业11(增删改查listview)

package com.example.listview;






import java.util.ArrayList;

import java.util.List;

import com.example.listview.MyHelper;

import com.example.listview.R;
import com.example.listview.CartAdapter;
import com.example.listview.CartBean;
import com.example.listview.MainActivity;

import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.Toast;

public class MainActivity extends Activity implements View.OnClickListener {

private EditText et1,et2,et3;
private ListView listView1;
private Button button1,button2,button3,button4;
private SQLiteDatabase db;
private String name,price,number;
private  MyHelper myHelper;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        et1 = (EditText)findViewById(R.id.et1);
        et2 =  (EditText)findViewById(R.id.et2);
        et3 =  (EditText) findViewById(R.id.et3);
        listView1 = (ListView)findViewById(R.id.listView1);
        Button button1 = (Button)findViewById(R.id.button1);
        Button button2 =(Button) findViewById(R.id.button2);
        Button button3 =(Button) findViewById(R.id.button3);
        Button button4 = (Button)findViewById(R.id.button4);
        button1.setOnClickListener(this);
        button2.setOnClickListener(this);
        button3.setOnClickListener(this);
        button4.setOnClickListener(this);
        myHelper = new MyHelper(this);
    }

    @Override
    public void onClick(View v) {
        
        switch (v.getId()){
        case R.id.button1:
            db = myHelper.getWritableDatabase();
            name = et1.getText().toString();
            price = et2.getText().toString();
            number = et3.getText().toString();
            ContentValues values = new ContentValues();        //创建ContentValues对象
            values.put("name", name);             //将数据添加到ContentValues对象
            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.button2:
            Log.e("yanwenhua","123");
            List<CartBean> list = new ArrayList();
            db = myHelper.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()) {
                    CartBean cartBean = new CartBean();
                    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);
                    Log.e("yanwenhua","cursor.getCount();--"+cursor.getCount()+"name-"+name+"  "+price+"  "+number);
                    cartBean.setName(name);
                    cartBean.setPrice(price);
                    cartBean.setNumber(number);
                    list.add(cartBean);
                }
                CartAdapter adapter = new CartAdapter(MainActivity.this,list);
                listView1.setAdapter(adapter);
                adapter.notifyDataSetChanged();
            }
            cursor.close();
            db.close();
            break;
        case  R.id.button3:
            name = et1.getText().toString();
            price = et2.getText().toString();
            number = et3.getText().toString();
            db = myHelper.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.button4:
            db = myHelper.getWritableDatabase();
            db.delete("cart", null, null);
            List<CartBean> list2 = new ArrayList();
            CartAdapter adapter = new CartAdapter(MainActivity.this,list2);
            listView1.setAdapter(adapter);
            adapter.notifyDataSetChanged();
            db.close();
            Toast.makeText(this, "信息已删除", Toast.LENGTH_SHORT).show();
            break;
            
       }
    
    }

}


package com.example.listview;

public class CartBean {
    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;
    }
}


package com.example.listview;

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 CartAdapter extends BaseAdapter {
    private List<CartBean> list;
    private LayoutInflater layoutInflater;
    public CartAdapter(Context context, List<CartBean> 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.listview_item,null);
            viewHolder=new ViewHolder(convertView);
            convertView.setTag(viewHolder);
        }else {
            viewHolder=(ViewHolder) convertView.getTag();
        }
        CartBean cartBean = list.get(position);
        viewHolder.tv_name.setText("商品名称:"+cartBean.getName());
        viewHolder.tv_price.setText("商品价格:"+cartBean.getPrice());
        viewHolder.tv_number.setText("商品数量:"+cartBean.getNumber());
        Log.e("yanwenhua","cartBean.getName()-"+cartBean.getName()+"  "+cartBean.getPrice()+"  "+cartBean.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);
        }
    }

}
<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"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.example.listview.MainActivity" >

    <TextView
        android:id="@+id/tv1"
        android:layout_width="70dp"
        android:layout_height="30dp"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_marginLeft="20dp"
        android:layout_marginTop="52dp"
        android:text="名称:" 
        android:textSize="20sp"
        />

    <TextView
        android:id="@+id/tv2"
        android:layout_width="70dp"
        android:layout_height="30dp"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_marginLeft="20dp"
        android:layout_marginTop="82dp"
        android:text="价格:" 
        android:textSize="20sp"
        />

    <TextView
        android:id="@+id/tv3"
        android:layout_width="70dp"
        android:layout_height="30dp"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_marginLeft="20dp"
        android:layout_marginTop="112dp"
        android:text="个数:"
        android:textSize="20sp" />

    
    <EditText
         android:id="@+id/et1"
        android:layout_width="150dp"
        android:layout_height="40dp"
         android:layout_alignParentLeft="true"
         android:layout_alignParentTop="true"
        android:layout_marginTop="52dp"
        android:layout_marginLeft="90dp"
        />
    
    <EditText
         android:id="@+id/et2"
        android:layout_width="150dp"
        android:layout_height="40dp"
         android:layout_alignParentLeft="true"
         android:layout_alignParentTop="true"
        android:layout_marginTop="82dp"
        android:layout_marginLeft="90dp"
        />
    <EditText
         android:id="@+id/et3"
        android:layout_width="150dp"
        android:layout_height="40dp"
         android:layout_alignParentLeft="true"
         android:layout_alignParentTop="true"
        android:layout_marginTop="112dp"
        android:layout_marginLeft="90dp"
        />

    <Button
        android:id="@+id/button1"
        android:layout_width="60dp"
        android:layout_height="40dp"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_marginTop="152dp"
         android:layout_marginLeft="10dp"
        android:text="添加" />
    <Button
        android:id="@+id/button2"
        android:layout_width="60dp"
        android:layout_height="40dp"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_marginTop="152dp"
         android:layout_marginLeft="80dp"
        android:text="查询" />
    <Button
        android:id="@+id/button3"
        android:layout_width="60dp"
        android:layout_height="40dp"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_marginTop="152dp"
        android:layout_marginLeft="150dp"
        android:text="修改" />
    <Button
        android:id="@+id/button4"
        android:layout_width="60dp"
        android:layout_height="40dp"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_marginTop="152dp"
        android:layout_marginLeft="220dp"
        android:text="删除" />

    <ListView
        android:id="@+id/listView1"
        android:layout_width="300dp"
        android:layout_height="600dp"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_marginTop="250dp"
        android:background="#46A3FF"
        >
    </ListView>
    
</RelativeLayout>


<?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>
原文地址:https://www.cnblogs.com/gsfwxj1820/p/11830346.html