Android SQLite数据库

效果图:

增:
在这里插入图片描述

更新【改】:
在这里插入图片描述
删:

在这里插入图片描述

MainActivity.java:

public class MainActivity extends AppCompatActivity {

    private MyDatabaseHelper dbHelper;
    private TextView textView;
    private String info="";    //结果

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        textView = findViewById(R.id.tv_show);
        dbHelper = new MyDatabaseHelper(this,"BookStore.db",null,3);
        Button createDatabase = findViewById(R.id.btn_create_database);
        createDatabase.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                dbHelper.getWritableDatabase();
            }
        });

        Button addData = (Button) findViewById(R.id.btn_add_data);
        /**
         *  增加数据
         */
        addData.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                SQLiteDatabase db = dbHelper.getWritableDatabase();
                ContentValues values = new ContentValues();
                //  开始组装第一条数据
                values.put("name", "蜡笔小新");
                values.put("pages", 630);
                values.put("price", 16.16);
                db.insert("Book",null, values);   // 插入第一条数据
                values.clear();
                //  开始组装第二条数据
                values.put("name", "哆啦A梦");
                values.put("pages", 490);
                values.put("price", 19.95);
                db.insert("Book",null, values);  //  插入第二条数据
            }
        });
        /**
         *  更新数据
         */
        Button updateData = findViewById(R.id.btn_update_data);
        updateData.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                SQLiteDatabase db = dbHelper.getWritableDatabase();
                ContentValues values = new ContentValues();
                values.put("price",10.99);
                /**
                 *  第一个参数是:表名
                 *  第二个参数是:名字等于谁?
                 *  第三个参数是:哆啦A梦
                 */
                db.update("Book", values,"name = ?",new String[]{ "哆啦A梦" });
            }
        });
        /**
         *  删除数据
         */
        Button deleteButton = findViewById(R.id.btn_dalete_data);
        deleteButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                SQLiteDatabase db = dbHelper.getWritableDatabase();
                /**
                 *  第一个参数是:表名
                 *  第二个参数是:页数大于几
                 *  第三个参数时:就是这个几的个数
                 */
                db.delete("Book","pages > ?", new String[]{ "500" });
            }
        });
        /**
         *  查询数据
         */

        Button queryButton = findViewById(R.id.btn_query_data);
        queryButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                textView.setText("");
                SQLiteDatabase db = dbHelper.getWritableDatabase();
                Cursor cursor = db.query("Book",null,null,null,null,null,null);
                if (cursor.moveToNext()){
                    do {
                        //  遍历 Curson 对象,取出数据并打印
                        String name = cursor.getString(cursor.getColumnIndex("name"));
                        int pages = cursor.getInt(cursor.getColumnIndex("pages"));
                        double price = cursor.getDouble(cursor.getColumnIndex("price"));
                        info += "姓名为:  " + name +  ",   页数为:   "+ pages + ",   价格为: " + price + "\n\n";
                    }while (cursor.moveToNext());
                }
                cursor.close();
                textView.setText(info);
            }
        });
    }
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity">

    <Button
        android:id="@+id/btn_create_database"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="创建数据库"/>

    <Button
        android:id="@+id/btn_add_data"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="添加数据"/>

    <Button
        android:id="@+id/btn_update_data"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="更新数据"/>

    <Button
        android:id="@+id/btn_dalete_data"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="删除数据"/>

    <Button
        android:id="@+id/btn_query_data"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="查看数据"/>

    <TextView
        android:id="@+id/tv_show"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginTop="20dp"/>

</LinearLayout>

教你们一个小技巧记住建表语句:


CREATE TABLE userq(_id INTEGER PRIMARY KEY AUTOINCREMENT

CREATE   	                — 		创建
TABLE      	                — 		表
userq	      	                — 		表名
INTEGER  	                —		整数  小写为:Integer
PRIMARY 	                — 		主     小写为:primary
KEY			  	                —  	    键	小写为: key
AUTOINCREMENT		—	    自动增量

点击运行即可!
最后,我真诚的希望能评论一句嘛,让我知道你来过,我会很开心的

  • 7
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

王睿丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值