android studio中ListView与SQLite的结合使用
Da.java
public class Db extends SQLiteOpenHelper {
    public Db(Context context) {
        super(context, "db", null, 1);
    }
    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL("CREATE TABLE user2(" +
                "_id INT DEFAULT 0," +
                "name TEXT DEFAULT \"\"," +
                "sex TEXT DEFAULT \"\")");
    }
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    }
}
MainActivity.java
public class MainActivity extends AppCompatActivity {
    private SimpleCursorAdapter mAdapter;
    private ListView listView;
    private Button btn_add;
    private Button btn_delete;
    private Button btn_back;
    private EditText et_id;
    private EditText et_name;
    private EditText et_sex;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        btn_add = (Button) findViewById(R.id.btn_add);
        btn_delete = (Button) findViewById(R.id.btn_delete);
        listView = (ListView) findViewById(R.id.list);
        btn_add.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                addData();
                refleshListView();
            }
        });
        btn_delete.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                deleteData();
                refleshListView();
            }
        });
        listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
//                Toast.makeText(MainActivity.this,""+position,Toast.LENGTH_SHORT).show();
                int positions = position + 1;
                Db db = new Db(MainActivity.this);
                SQLiteDatabase dbWrite = db.getWritableDatabase();
                dbWrite.delete("user2","_id=?",new String[]{""+positions});
                dbWrite.close();
                refleshListView();
            }
        });
    }
    public void addData() {
        btn_back = (Button) findViewById(R.id.btn_back);
        et_id = (EditText) findViewById(R.id.et_id);
        et_name = (EditText) findViewById(R.id.et_name);
        et_sex = (EditText) findViewById(R.id.et_sex);
        btn_add = (Button) findViewById(R.id.btn_add);
        btn_delete = (Button) findViewById(R.id.btn_delete);
        listView = (ListView) findViewById(R.id.list);
        btn_add.setVisibility(View.GONE);
        btn_delete.setVisibility(View.GONE);
        listView.setVisibility(View.GONE);
        btn_back.setVisibility(View.VISIBLE);
        et_id.setVisibility(View.VISIBLE);
        et_name.setVisibility(View.VISIBLE);
        et_sex.setVisibility(View.VISIBLE);
        btn_back.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                btn_add.setVisibility(View.VISIBLE);
                btn_delete.setVisibility(View.VISIBLE);
                listView.setVisibility(View.VISIBLE);
                btn_back.setVisibility(View.GONE);
                et_id.setVisibility(View.GONE);
                et_name.setVisibility(View.GONE);
                et_sex.setVisibility(View.GONE);
                String id = et_id.getText().toString(),
                        name =et_name.getText().toString(),
                        sex = et_sex.getText().toString();
                Db db = new Db(MainActivity.this);
                SQLiteDatabase dbWrite = db.getWritableDatabase();
                ContentValues cv = new ContentValues();
                cv.put("_id", id);
                cv.put("name", name);
                cv.put("sex", sex);
                dbWrite.insert("user2", null, cv);
                dbWrite.close();
                refleshListView();
            }
        });
//        String id = et_id.getText().toString(),
//               name =et_name.getText().toString(),
//               sex = et_sex.getText().toString();
//
//
//        Db db = new Db(MainActivity.this);
//        SQLiteDatabase dbWrite = db.getWritableDatabase();
//
//        ContentValues cv = new ContentValues();
//        cv.put("_id",id);
//        cv.put("name", name);
//        cv.put("sex", sex);
//        dbWrite.insert("user2", null, cv);
//
//        dbWrite.close();
    }
    public void deleteData() {
        Db db = new Db(MainActivity.this);
        SQLiteDatabase dbWrite = db.getWritableDatabase();
        dbWrite.delete("user2",null,new String[]{});
        dbWrite.close();
    }
    public void refleshListView() {
        Db db = new Db(MainActivity.this);
        SQLiteDatabase dbRead = db.getReadableDatabase();
        Cursor c = dbRead.query("user2", null, null, null, null, null, null);
        mAdapter = new SimpleCursorAdapter(MainActivity.this, R.layout.user_info, c,
                new String[]{"_id","name","sex"}, new int[]{R.id._id,R.id._name,R.id._sex});
        listView.setAdapter(mAdapter);
        dbRead.close();
    }
}
user_info.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal">
<TextView
android:id="@+id/_id"
android:textSize="20sp"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/_name"
android:textSize="20sp"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/_sex"
android:textSize="20sp"
android:layout_width="wrap_content"
android:layout_height="wrap_content" /> </LinearLayout>
activity_main.xml
<LinearLayout 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:orientation="vertical"
tools:context=".MainActivity"> <Button
android:id="@+id/btn_add"
android:text="Add"
android:textSize="20sp"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
<Button
android:id="@+id/btn_delete"
android:text="Delete"
android:textSize="20sp"
android:layout_width="match_parent"
android:layout_height="wrap_content" /> <ListView
android:id="@+id/list"
android:layout_width="match_parent"
android:layout_height="wrap_content"/> <Button
android:id="@+id/btn_back"
android:text="确定"
android:textSize="20sp"
android:layout_width="match_parent"
android:layout_height="wrap_content" /> <EditText
android:id="@+id/et_id"
android:visibility="gone"
android:layout_width="match_parent"
android:layout_height="40dp" />
<EditText
android:id="@+id/et_name"
android:visibility="gone"
android:layout_width="match_parent"
android:layout_height="40dp" />
<EditText
android:id="@+id/et_sex"
android:visibility="gone"
android:layout_width="match_parent"
android:layout_height="40dp" />
</LinearLayout>
android studio中ListView与SQLite的结合使用的更多相关文章
- Android开发的小技巧,在Android Studio中使用Designtime Layout Attributes
		
在编写xml文件时,为了预览效果,经常会使用默认填上一些内容,比如TextView时,随便写上一个text <TextView ... android:text="Name:" ...
 - Android ImageView 不显示JPEG图片 及 Android Studio中怎样引用图片资源
		
Android ImageView 不显示JPEG图片 今天在写一个小实例,ImageView在xml里面设置的是INVISIBLE,在代码里须要设置成setVisibility(View.VISIB ...
 - android studio 中移除module和恢复module
		
一.移除Android Studio中module 在Android Studio中想要删除某个module时,在Android Studio中选中module,右键发现没有delete,如图: An ...
 - Android Studio中Button等控件的Text中字符串默认大写的解决方法
		
初学Android的时候,在Android Studio中xml里面添加一个Button.EditText等控件后,它的Text总是会显示大写,即使你输入的字符串是小写也不行,控制字符串大小写的属性是 ...
 - .Net程序员之不学Java做安卓开发:Android Studio中的即时调试窗口
		
对学.Net的人来说,JAVA开发是一场噩梦. .net中的即时窗口,调试时直接在里面写代码,对程序中的各种方法/属性进行调用,很方便. Android Studio中找了好久,参考如下网址,也有类似 ...
 - 如何将Eclipse中的项目迁移到Android Studio 中
		
如何将Eclipse中的项目迁移到Android Studio 中 如果你之前有用Eclipse做过安卓开发,现在想要把Eclipse中的项目导入到Android Studio的环境中,那么首先要做的 ...
 - 在android studio 中使用applicationid的问题
		
现在我需要对项目app的某个功能做性能测试,主要测试耗电量的多少. 1.我想到的方式是,我需要在同一台手机测试,同一个应用,需要安装在手机两次,第二次安装不覆盖第一次的安装. 在android stu ...
 - Android studio 中的配置编译错误总结
		
1.编译Andorid 工程的时候,有时候出现gradle 报下面的错误. Error:(1, 0) Cause: com/android/build/gradle/LibraryPlugin : U ...
 - Android Studio中清单文件改versionCode和versionName没效果的原因
		
在Android Studio中,项目的versionCode 和versionName 的控制不是在AndroidManifest.xml清单文件中更改的,而是在项目的build.gradle中更改 ...
 
随机推荐
- hdu5481 Desiderium
			
链接 Desiderium 题意 给定n条线段,从中选取若干条,共有2n种选法(因为每一条线段有两种方法:选或者不选). 每一种选法都对应一个长度,也就是所选线段的并集长度. 求这2n种选法长度之和. ...
 - EPEL源
			
EPEL (Extra Packages for Enterprise Linux)是基于Fedora的一个项目,为“红帽系”的操作系统提供额外的软件包,适用于RHEL.CentOS和Scientif ...
 - Intent和Intent Filters
			
什么是Intent Intent是android开发中的重要对象,它作为一个信息承载对象存在. 我们可以在使用其他一些组件的时候从Intent获取行为响应的准则(即应该做什么东西,如何 ...
 - Django - 获取请求方式
			
//获取请过来得得请求类型 method = request.method 通过Django 的form 判断用户输入是否通过验证 check = forms.LoginFrom(request.PO ...
 - WEB界面onload前的加载流程❤❤
			
开始的流程: 1.先发请求给DNS进行域名解析获取服务器IP 2.向步骤1获取的服务器IP发送HTTP请求 //服务器的内部处理 3.服务器接收请求后,解析主机头对应的站点,把请求传送给站点 //返回 ...
 - bzoj1503
			
treap改了好长时间,erase写错了... #include<iostream> #include<cstdio> #include<cstdlib> usin ...
 - Mysql-通过case..when实现oracle decode()函数进行多值多结果判断
			
oracle的decode函数使用:http://www.cnblogs.com/hwaggLee/p/5335967.html case ..when 函数使用:http://www.cnblogs ...
 - 【POJ 1389】Area of Simple Polygons(线段树+扫描线,矩形并面积)
			
离散化后,[1,10]=[1,3]+[6,10]就丢了[4,5]这一段了. 因为更新[3,6]时,它只更新到[3,3],[6,6]. 要么在相差大于1的两点间加入一个值,要么就让左右端点为l,r的线段 ...
 - Yii2命名规则
			
module id /controller id/action id的规则PostManagerController=>post-manageractionAddValue =>add-v ...
 - 55.Android之AsyncTask介绍 (转)
			
AsyncTask和Handler对比 1 ) AsyncTask实现的原理,和适用的优缺点 AsyncTask,是android提供的轻量级的异步类,可以直接继承AsyncTask,在类中实现异步操 ...