zoukankan      html  css  js  c++  java
  • sqlite增删改查 SimpleCursorAdapter 事务

    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:id="@+id/activity_main"
        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.cunli.sqlite002.MainActivity">
    
        <EditText
            android:id="@+id/name"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:hint="姓名" />
    
        <EditText
            android:id="@+id/age"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_below="@id/name"
            android:hint="班级" />
    
        <RadioGroup
            android:id="@+id/radioGroup"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_below="@id/age">
    
            <RadioButton
                android:id="@+id/male"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:checked="true"
                android:text="男" />
    
            <RadioButton
                android:id="@+id/female"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="女" />
        </RadioGroup>
    
        <Button
            android:id="@+id/saveButton"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_below="@id/radioGroup"
            android:onClick="saveStudent"
            android:text="插入数据" />
        <Button
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/deleteData"
            android:onClick="deleteData"
            android:layout_marginLeft="20dp"
            android:text="删除全部数据"
            android:layout_toRightOf="@id/saveButton"
            android:layout_below="@id/radioGroup"/>
        <Button
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/sCursor"
            android:text="simplec"
            android:onClick="scursor"
            android:layout_toRightOf="@id/deleteData"
            android:layout_below="@id/radioGroup"
            android:layout_marginLeft="10dp"/>
    <EditText
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_below="@id/saveButton"
        android:hint="更新"
        android:id="@+id/updateData"/>
        <Button
            android:id="@+id/updateButton"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_below="@id/updateData"
            android:onClick="updateStudent"
            android:text="更新"
            android:layout_marginLeft="20dp"/>
        <Button
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="10dp"
            android:layout_toRightOf="@id/updateButton"
            android:layout_below="@id/updateData"
            android:text="取出数据"
            android:id="@+id/getData"
            android:onClick="getData"/>
        <Button
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:onClick="clearData"
            android:id="@+id/clearData"
            android:layout_below="@id/updateData"
            android:layout_toRightOf="@id/getData"
            android:text="清空表中所有数据"
            android:layout_marginLeft="10dp"/>
        <ScrollView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:id="@+id/s1"
            android:layout_below="@id/getData">
            <LinearLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:orientation="vertical"
                android:id="@+id/linerLayout"/>
    
        </ScrollView>
    
    </RelativeLayout>
    package com.example.cunli.sqlite002;
    
    import android.content.ContentValues;
    import android.content.Context;
    import android.content.Intent;
    import android.database.Cursor;
    import android.database.sqlite.SQLiteDatabase;
    import android.support.v7.app.AppCompatActivity;
    import android.os.Bundle;
    import android.util.Log;
    import android.view.View;
    import android.view.ViewGroup;
    import android.widget.BaseAdapter;
    import android.widget.EditText;
    import android.widget.LinearLayout;
    import android.widget.ListAdapter;
    import android.widget.ListView;
    import android.widget.RadioGroup;
    import android.widget.SimpleAdapter;
    import android.widget.SimpleCursorAdapter;
    import android.widget.TextView;
    import android.widget.Toast;
    
    import java.util.ArrayList;
    import java.util.HashMap;
    import java.util.List;
    import java.util.Map;
    
    public class MainActivity extends AppCompatActivity {
    EditText nameEt,ageEt;
        RadioGroup radioGroup;
        SQLiteDatabase db;
        boolean gender = true;
        ContentValues contentValues;//创建ContentValues
    
        private List<Long> ids = new ArrayList<>();
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
            contentValues = new ContentValues();
            nameEt = (EditText)findViewById(R.id.name);
            ageEt = (EditText)findViewById(R.id.age);
            radioGroup = (RadioGroup)findViewById(R.id.radioGroup);
            radioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
                @Override
                public void onCheckedChanged(RadioGroup group, int checkedId) {
                    if (checkedId == R.id.male){
                        gender = true;
                    }else {
                        gender = false;
                    }
                }
            });
            //以刻都写的方式打开或创建一个数据
            db = openOrCreateDatabase("school",SQLiteDatabase.OPEN_READWRITE,null);
            //建表的语句
            String createSQL = "CREATE TABLE IF NOT EXISTS Students (_id INTEGER NOT NULL,student_name CHAR(20) NOT NULL,age INTEGER,gender BOOLEAN,PRIMARY KEY(_id))";
            //执行建表SQL语句
            db.execSQL(createSQL);
        }
        //点击按钮事件处理
        public void saveStudent(View view){
            try{
                db.beginTransaction();//开启事务
                contentValues.put("student_name",nameEt.getText().toString());
                contentValues.put("age",Integer.parseInt(ageEt.getText().toString()));
                contentValues.put("gender",gender);
                //执行插入语句
                long id = db.insert("Students",null,contentValues);
                db.setTransactionSuccessful();//提交事务
                ids.add(id);
                //如果返回值为-1,则说明那个插入失败
                if (id != -1){
                    Toast.makeText(this,"插入数据成功",Toast.LENGTH_SHORT).show();
                }else {
                    Toast.makeText(this,"插入数据 失败",Toast.LENGTH_SHORT).show();
                }
            }catch (Exception e){
                e.printStackTrace();
            }finally {
                db.endTransaction();//终止事务
            }
    
        }
    
        @Override
        protected void onDestroy() {
            super.onDestroy();
            if (db!=null){
                db.close();//关闭数据库
            }
    
        }
    //    更新数据库
        public void updateStudent(View view){
            String updateData = ((EditText)findViewById(R.id.updateData)).getText().toString();
            contentValues.put("student_name",updateData);
            //更新数据
            int num = db.update("Students",contentValues,"_id=?",new String[]{""+1});
            Toast.makeText(MainActivity.this,"更新了"+num+"条数据。",Toast.LENGTH_SHORT).show();
        }
    //    查询数据
        public void getData(View view){
            LinearLayout linearLayout = (LinearLayout) findViewById(R.id.linerLayout);
            linearLayout.removeAllViews();//显示当前数据前,清除之前的数据
            Cursor cursor = db.query("Students",new String[]{"student_name","age","gender"},null,null,null,null,"age");
            if (cursor.getCount() > 0){
                //循环获取数据
                while (!cursor.isLast()){//退出循环的条件:是否到cursor的末尾
                    cursor.moveToNext();//向前移动,注意刚开始的时候,指针是在第一行数据之前的
                    String name = cursor.getString(0);
                    int age = cursor.getInt(1);
                    int gender = cursor.getInt(2);
                    TextView textView = new TextView(MainActivity.this);
                    textView.setText(name+":"+age+":"+(gender==1?"男":"女"));
    
                    linearLayout.addView(textView);
    
                }
            }else {
                Toast.makeText(MainActivity.this,"表中没有数据",Toast.LENGTH_SHORT).show();
            }
    
        }
    
        //    删除全部数据
        public void deleteData(View view){
            String[] arr = new String[ids.size()];
            for (int i = 0; i < ids.size(); i++) {
                int delId = db.delete("Students","_id = ? ",new String[]{ids.get(i).toString()});
                Log.e("log","----------------"+delId);
            }
            Toast.makeText(MainActivity.this,"全部数据已经删除",Toast.LENGTH_SHORT).show();
        }
    //    清空表中所有数据
        public void clearData(View view){
            int delId = db.delete("Students",null,null);
            Log.e("log","----------------"+delId);
    
            Toast.makeText(MainActivity.this,"表中全部数据已清空",Toast.LENGTH_SHORT).show();
        }
    
        public void scursor(View view) {
            Intent intent = new Intent(this,Main2Activity.class);
            startActivity(intent);
    
        }
    
    
    
    }
    package com.example.cunli.sqlite002;
    
    import android.content.Context;
    import android.database.Cursor;
    import android.database.sqlite.SQLiteDatabase;
    import android.support.v7.app.AppCompatActivity;
    import android.os.Bundle;
    import android.util.Log;
    import android.view.View;
    import android.view.ViewGroup;
    import android.widget.BaseAdapter;
    import android.widget.LinearLayout;
    import android.widget.ListAdapter;
    import android.widget.ListView;
    import android.widget.SimpleCursorAdapter;
    import android.widget.TextView;
    
    public class Main2Activity extends AppCompatActivity {
        Cursor cursor7;
        SQLiteDatabase db;
        ListView listView;
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main2);
            listView = (ListView)findViewById(R.id.listView);
            //以刻都写的方式打开或创建一个数据
            db = openOrCreateDatabase("school",SQLiteDatabase.OPEN_READWRITE,null);
            //建表的语句
            String createSQL = "CREATE TABLE IF NOT EXISTS Students (_id INTEGER NOT NULL,student_name CHAR(20) NOT NULL,age INTEGER,gender BOOLEAN,PRIMARY KEY(_id))";
            //执行建表SQL语句
            db.execSQL(createSQL);
    
            cursor7 = db.query("Students",new String[]{"_id","student_name","age","gender"},null,null,null,null,"age");
    
            while (!cursor7.isLast()){
                cursor7.moveToNext();
                Log.e("log","-----------"+cursor7.getInt(0)+" "+cursor7.getString(1)+" "+cursor7.getInt(2)+" "+cursor7.getInt(3));
            }
    
    
            ListAdapter adapter = new SimpleCursorAdapter(this,R.layout.student_item,cursor7,new String[]{"student_name","age","gender"},new int[]{R.id.textView1,R.id.textView2,R.id.textView3},0);
    //        SimpleCursorAdapter adapter = new SimpleCursorAdapter(MainActivity.this,R.layout.student_item,cursor7,new String[]{"student_name","age","gender"},new int[]{R.id.textView1,R.id.textView2,R.id.textView3},0);
    
            Log.e("log","------adapter----getCount------"+adapter.getCount());
    
    
    
            listView.setAdapter(adapter);
    //        listView.setAdapter(new Myap(this));
        }
    
    
        class Myap extends BaseAdapter {
            Context context;
    
            public Myap(Context context) {
                this.context = context;
            }
    
            @Override
            public int getCount() {
                return 20;
            }
    
            @Override
            public Object getItem(int position) {
                return position;
            }
    
            @Override
            public long getItemId(int position) {
                return position;
            }
    
            @Override
            public View getView(int position, View convertView, ViewGroup parent) {
                LinearLayout line = new LinearLayout(context);
                line.setLayoutParams(new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));
                TextView text = new TextView(context);
                text.setText("ok"+Math.random()*10);
                line.addView(text);
                return line;
            }
        }
    }
    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:id="@+id/activity_main2"
        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.cunli.sqlite002.Main2Activity">
        <ListView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:id="@+id/listView"/>
    </RelativeLayout>
    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:orientation="horizontal" android:layout_width="match_parent"
        android:layout_height="match_parent">
        <!--姓名-->
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Large Text"
        android:id="@+id/textView1"
        android:textAppearance="?android:attr/textAppearanceLarge"/>
        <!--年龄-->
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Medium Text"
            android:id="@+id/textView2"
            android:textAppearance="?android:attr/textAppearanceMedium"/>
    <!--性别-->
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Medium Text"
            android:id="@+id/textView3"
            android:textAppearance="?android:attr/textAppearanceMedium"/>
    </LinearLayout>
  • 相关阅读:
    敏捷开发
    Response.Write(js脚本)后 Response.redirect(...),为什么js脚本不执行,怎么解决!
    kaixin.com一波三折看SNS
    JavaScript数组的自定义 sort方法
    简单明了的SQL join解释
    [官方资料] 介绍 JSON
    SQL UNION 和 UNION ALL 操作符
    JavaScript frames 对象
    理解hasOwnProperty
    asp.net网站安全常见问题与防范
  • 原文地址:https://www.cnblogs.com/thankyouGod/p/6294782.html
Copyright © 2011-2022 走看看