11.11

购物车程序

<?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="16dp" >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginTop="20dp" >

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="商品名称 :"
            android:textSize="18sp" />

        <EditText
            android:id="@+id/et_name"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:hint="请输入商品名称"
            android:textSize="16sp" />
    </LinearLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginBottom="10dp" >

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="价格:"
            android:textSize="18sp" />

        <EditText
            android:id="@+id/et_price"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:hint="输入价格"
            android:textSize="16sp" />
    </LinearLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"

        android:layout_marginBottom="10dp" >

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="数量:"
            android:textSize="18sp" />

        <EditText
            android:id="@+id/et_num"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:hint="输入数量"
            android:textSize="16sp" />
    </LinearLayout>
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content" >

        <Button
            android:id="@+id/btn_add"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_marginRight="2dp"
            android:layout_weight="1"
            android:background="#B9B9FF"
            android:onClick="add"
            android:text="添加"
            android:textSize="18sp" />

        <Button
            android:id="@+id/btn_query"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_marginRight="2dp"
            android:layout_weight="1"
            android:background="#DCB5FF"
            android:onClick="search"
            android:text="查询"
            android:textSize="18sp" />

        <Button
            android:id="@+id/btn_update"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_marginRight="2dp"
            android:layout_weight="1"
            android:background="#E6CAFF"
            android:onClick="update"
            android:text="修改"
            android:textSize="18sp" />

        <Button
            android:id="@+id/btn_delete"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:background="#ACD6FF"
            android:onClick="delete"
            android:text="删除"
            android:textSize="18sp" />
    </LinearLayout>



        <ListView
            android:id="@+id/tv_show"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginTop="25dp"
            android:textSize="20sp"
            />


</LinearLayout>
<?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="wrap_content"
    android:orientation="horizontal"
    android:padding="10dp">
    <ImageView
        android:layout_width="100dp"
        android:layout_height="120dp"
        android:src="@drawable/ic_launcher_background"/>
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:orientation="vertical">
        <TextView
            android:id="@+id/tv_id"
            android:layout_marginLeft="20dp"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:textSize="20sp"/>
        <TextView
            android:id="@+id/tv_name"
            android:layout_marginLeft="20dp"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:textSize="20sp"/>
        <TextView
            android:id="@+id/tv_price"
            android:layout_marginLeft="20dp"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginTop="3dp"
            android:textSize="20sp"/>
        <TextView
            android:id="@+id/tv_num"
            android:layout_marginLeft="20dp"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginTop="3dp"
            android:textSize="20sp"/>
    </LinearLayout>



</LinearLayout>
package com.example.myapplication;

import android.os.Bundle;
import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.view.Menu;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.BaseAdapter;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends Activity {
    List<Shopping> list  = new ArrayList<Shopping>();
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    public void add(View v) {
        StuOpenHelper helper = new StuOpenHelper(this);
        SQLiteDatabase db = helper.getWritableDatabase();
        String name = ((EditText) findViewById(R.id.et_name)).getText()
                .toString();
        int price = Integer.parseInt(((EditText) findViewById(R.id.et_price))
                .getText().toString());
        int num = Integer.parseInt(((EditText) findViewById(R.id.et_num))
                .getText().toString());
        // 原生sql操作,
        // db.execSQL("insert into stuinfo (name,age) values('lisi',22)");
        // db.execSQL("insert into stuinfo (name,age) values(?,?)",new
        // Object[]{"kitty",30});
        db.execSQL("insert into shoppinfo (name,price,num) values(?,?,?)", new Object[] {
                name, price,num });
        Toast.makeText(this, "ok", 0).show();

    }

    public void delete(View view) {
        StuOpenHelper helper = new StuOpenHelper(this);
        SQLiteDatabase db = helper.getWritableDatabase();
        String name = ((EditText) findViewById(R.id.et_name)).getText()
                .toString();
        db.execSQL("delete from shoppinfo where name=?", new Object[] { name });
        Toast.makeText(this, "删除成功", 0).show();

    }

    public void update(View view) {
        StuOpenHelper helper = new StuOpenHelper(this);
        SQLiteDatabase db = helper.getWritableDatabase();
        String name = ((EditText) findViewById(R.id.et_name)).getText()
                .toString();

        int price = Integer.parseInt(((EditText) findViewById(R.id.et_price))
                .getText().toString());
        int num = Integer.parseInt(((EditText) findViewById(R.id.et_num))
                .getText().toString());
        db.execSQL("update shoppinfo set price=?,num=? where name=?", new Object[] {
                price,num,name });
        Toast.makeText(this, "修改成功", 0).show();

    }

    public void search(View view) {
        StuOpenHelper helper = new StuOpenHelper(this);
        SQLiteDatabase db = helper.getWritableDatabase();
//        String s = "";
        Cursor cursor = db.rawQuery("select * from shoppinfo", null);
        if (cursor.getCount() != 0) {
            while (cursor.moveToNext()) {
                list.add(new Shopping(cursor.getInt(0),cursor.getString(1),cursor.getInt(2),cursor.getInt(3)));
            }
        }

        // Toast.makeText(this, s, 0).show();
//        ((TextView) (findViewById(R.id.tv_show))).setText(s);
        ListView li = (ListView) findViewById(R.id.tv_show);
        li.setAdapter(new shopAdapter());
    }
    class  shopAdapter  extends BaseAdapter{


        @Override
        public int getCount() {
            return list.size();
        }

        @Override
        public Object getItem(int i) {
            return null;
        }

        @Override
        public long getItemId(int i) {
            return 0;
        }

        @Override
        public View getView(int position, View converView, ViewGroup parent) {
            View view = View.inflate(MainActivity.this,R.layout.list_item,null);
            TextView id = (TextView) view.findViewById(R.id.tv_id);
            TextView name = (TextView) view.findViewById(R.id.tv_name);
            TextView price = (TextView) view.findViewById(R.id.tv_price);
            TextView num = (TextView) view.findViewById(R.id.tv_num);
            id.setText(list.get(position).getId()+"   ");
            name.setText(list.get(position).getName()+"   ");
            price.setText(list.get(position).getPrice()+"   ");
            num.setText(list.get(position).getNum()+"   ");
            return view;
        }

        }
    }
package com.example.myapplication;

public class Shopping {
    private  int id;
    private  String name;
    private  int price;
    private  int num;

    public Shopping(){

    }
    public Shopping(int id,String name,int price,int num){
        this.id=id;
        this.name=name;
        this.price=price;
        this.num=num;
    }
    public void setId(int id) {
        this.id = id;
    }

    public void setName(String name) {
        this.name = name;
    }

    public void setPrice(int price) {
        this.price = price;
    }

    public void setNum(int num) {
        this.num = num;
    }

    public int getNum() {
        return num;
    }

    public String getName() {
        return name;
    }

    public int getPrice() {
        return price;
    }

    public int getId() {
        return id;
    }
}
package com.example.myapplication;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;

public class StuOpenHelper extends SQLiteOpenHelper {

    public StuOpenHelper(Context context) {
        super(context, "shop.db", null, 1);
        // TODO Auto-generated constructor stub
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        // TODO Auto-generated method stub
        db.execSQL("create table shoppinfo(_id integer primary key autoincrement,name varchar(20),price integer,num integer)");

    }

    @Override
    public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {
        // TODO Auto-generated method stub

    }

}

 

 

用内容提供者读取信息

package com.example.test;

import android.content.ContentProvider;
import android.content.ContentValues;
import android.content.UriMatcher;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.net.Uri;

public class MyProvider extends ContentProvider {
    
    public static UriMatcher um=new UriMatcher(-1);
    static{
        //添加uri匹配规则
        um.addURI("com.gd.db.infodb", "query", 1);
        um.addURI("com.gd.db.infodb", "delete", 2);
        um.addURI("com.gd.db.infodb", "update", 3);
        um.addURI("com.gd.db.infodb", "add", 4);
        //content://com.gd.db.infodb/query  查询
        //content://com.gd.db.infodb/delete  删除
        //content://com.gd.db.infodb/update  修改
        //content://com.gd.db.infodb/add  添加
    }
    

    @Override
    public int delete(Uri arg0, String arg1, String[] arg2) {
        // TODO Auto-generated method stub
        return 0;
    }

    @Override
    public String getType(Uri arg0) {
        // TODO Auto-generated method stub
        return null;
    }

    @Override
    public Uri insert(Uri arg0, ContentValues arg1) {
        // TODO Auto-generated method stub
        return null;
    }

    @Override
    public boolean onCreate() {
        // TODO Auto-generated method stub
        return false;
    }

    @Override
    public Cursor query(Uri uri, String[] a, String b, String[] c,
            String d) {
        //uri:用户操作的路径
        int i=um.match(uri);
        if(i==1){
            MyHelper helper=new MyHelper(getContext());
            SQLiteDatabase db=helper.getWritableDatabase();
            return db.query("cart", a, b, c, null,null,d);
            
            
        }else{
            throw new RuntimeException("uri路径错误");
        }
        
    }

    @Override
    public int update(Uri arg0, ContentValues arg1, String arg2, String[] arg3) {
        // TODO Auto-generated method stub
        return 0;
    }

}

 

package com.example.other;

import android.net.Uri;
import android.os.Bundle;
import android.app.Activity;
import android.content.ContentResolver;
import android.database.Cursor;
import android.view.Menu;

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);        
        //使用内容提供者去访问数据
        ContentResolver resolver=getContentResolver();
        //利用解析器去获取数据
        
        Uri uri=Uri.parse("content://com.gd.db.infodb/query");
        Cursor cursor=resolver.query(uri, null, null, null, null);
        while(cursor.moveToNext()){
            int id=cursor.getInt(cursor.getColumnIndex("_id"));
            String name=cursor.getString(cursor.getColumnIndex("name"));
            System.out.println(id+"-"+name);
        }
        cursor.close();
    }



}

 

package com.example.test;
import android.content.ContentProvider;import android.content.ContentValues;import android.content.UriMatcher;import android.database.Cursor;import android.database.sqlite.SQLiteDatabase;import android.net.Uri;
public class MyProvider extends ContentProvider {public static UriMatcher um=new UriMatcher(-1);static{//添加uri匹配规则um.addURI("com.gd.db.infodb", "query", 1);um.addURI("com.gd.db.infodb", "delete", 2);um.addURI("com.gd.db.infodb", "update", 3);um.addURI("com.gd.db.infodb", "add", 4);//content://com.gd.db.infodb/query  查询//content://com.gd.db.infodb/delete  删除//content://com.gd.db.infodb/update  修改//content://com.gd.db.infodb/add  添加}
@Overridepublic int delete(Uri arg0, String arg1, String[] arg2) {// TODO Auto-generated method stubreturn 0;}
@Overridepublic String getType(Uri arg0) {// TODO Auto-generated method stubreturn null;}
@Overridepublic Uri insert(Uri arg0, ContentValues arg1) {// TODO Auto-generated method stubreturn null;}
@Overridepublic boolean onCreate() {// TODO Auto-generated method stubreturn false;}
@Overridepublic Cursor query(Uri uri, String[] a, String b, String[] c,String d) {//uri:用户操作的路径int i=um.match(uri);if(i==1){MyHelper helper=new MyHelper(getContext());SQLiteDatabase db=helper.getWritableDatabase();return db.query("cart", a, b, c, null,null,d);}else{throw new RuntimeException("uri路径错误");}}
@Overridepublic int update(Uri arg0, ContentValues arg1, String arg2, String[] arg3) {// TODO Auto-generated method stubreturn 0;}
}

posted @ 2020-11-15 13:23  ~~_~~  阅读(80)  评论(0编辑  收藏  举报