• 家庭记账本(三)


    content_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"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"
        tools:showIn="@layout/activity_main"
        tools:context=".MainActivity">
            <TextView
                android:id="@+id/tv_cost_total"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:textSize="15dp"
                android:text="账户余额:0"/>
            <ListView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:id="@+id/lv_main"/>
    
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true">
    
            <Button
                android:id="@+id/btn_add_in"
                android:layout_width="0dp"
                android:layout_height="match_parent"
                android:layout_weight="1"
                android:background="#8A7532EB"
                android:drawablePadding="3dp"
                android:gravity="center"
                android:text="收入" />
    
            <Button
                android:id="@+id/btn_add_out"
                android:layout_width="0dp"
                android:layout_height="match_parent"
                android:layout_weight="1"
                android:background="#9F03A9F4"
                android:drawablePadding="3dp"
                android:gravity="center"
                android:text="支出" />
    
            <Button
                android:id="@+id/btn_delete"
                android:layout_width="0dp"
                android:layout_height="match_parent"
                android:layout_weight="1"
                android:background="#86FFC107"
                android:drawablePadding="3dp"
                android:gravity="center"
                android:text="删除" />
    
            <Button
                android:id="@+id/btn_delete_all"
                android:layout_width="0dp"
                android:layout_height="match_parent"
                android:layout_weight="1"
                android:background="#79E91E63"
                android:drawablePadding="3dp"
                android:gravity="center"
                android:text="清空账单" />
    
        </LinearLayout>
    
    </RelativeLayout>

    DatabaseHelper.java

    package com.example.family;
    
    import android.content.ContentValues;
    import android.content.Context;
    import android.database.Cursor;
    import android.database.sqlite.SQLiteDatabase;
    import android.database.sqlite.SQLiteOpenHelper;
    import android.widget.TextView;
    
    import androidx.annotation.Nullable;
    
    
    public class DatabaseHelper extends SQLiteOpenHelper {
    
        public static final String COST_MONEY = "cost_money";
        public static final String COST_DATE = "cost_date";
        public static final String COST_TITLE = "cost_title";
        public static final String TABLE = "family";
    
        public DatabaseHelper(@Nullable Context context) {
            super(context, TABLE, null, 1);
        }
    
        @Override
        public void onCreate(SQLiteDatabase db) {
            db.execSQL("create table if not exists family("+
                    "id integer primary key autoincrement ,"+
                    "cost_title varchar,"+
                    "cost_date varchar,"+
                    "cost_money varchar)");
        }
    
        public void insertCost(CostBean costBean){
            SQLiteDatabase database=getWritableDatabase();
            ContentValues cv=new ContentValues();
            cv.put(COST_TITLE,costBean.costTitle);
            cv.put(COST_DATE,costBean.costDate);
            cv.put(COST_MONEY,costBean.costMoney);
            database.insert(TABLE,null,cv);
        }
    
        public void deleteCost(CostBean costBean){
            SQLiteDatabase database=getWritableDatabase();
            database.delete(TABLE,"cost_title=?",new String[]{costBean.costTitle});
        }
    
    //    public void deleteCost(int position){
    //        SQLiteDatabase database=getWritableDatabase();
    //        database.delete(TABLE,"id=?",new String[]{Integer.toString(position)});
    //    }
    
        public Cursor getAllCostData(){
            SQLiteDatabase database=getWritableDatabase();
            return database.query(TABLE,null,null,null,null,null,COST_DATE+" ASC");
        }
    
        public  void deleteAllData(){
            SQLiteDatabase database=getWritableDatabase();
            database.delete(TABLE,null,null);
        }
    
        public  int countTotalCost(){
            int sum=0;
            SQLiteDatabase database=getWritableDatabase();
            String sum_dbString="select sum(cost_money)from "+TABLE;
            Cursor cursor=database.rawQuery(sum_dbString,null);
            if (cursor!=null){
                if (cursor.moveToFirst()){
                    do{
                        sum=cursor.getInt(0);
                    }while (cursor.moveToNext());
                }
            }
            return sum;
        }
    
    
        @Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    
        }
    
    }
  • 相关阅读:
    2019年11月28日开发手记
    2019年11月26日开发手记
    2019年11月25日开发手记
    2019年11月24日开发手记
    2019年11月23日开发手记
    R学习
    python学习目录
    自动化测试appium
    python爬虫的进阶用法
    asyncio
  • 原文地址:https://www.cnblogs.com/wangdayang/p/14913927.html
Copyright © 2020-2023  润新知