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的结合使用的更多相关文章

  1. Android开发的小技巧,在Android Studio中使用Designtime Layout Attributes

    在编写xml文件时,为了预览效果,经常会使用默认填上一些内容,比如TextView时,随便写上一个text <TextView ... android:text="Name:" ...

  2. Android ImageView 不显示JPEG图片 及 Android Studio中怎样引用图片资源

    Android ImageView 不显示JPEG图片 今天在写一个小实例,ImageView在xml里面设置的是INVISIBLE,在代码里须要设置成setVisibility(View.VISIB ...

  3. android studio 中移除module和恢复module

    一.移除Android Studio中module 在Android Studio中想要删除某个module时,在Android Studio中选中module,右键发现没有delete,如图: An ...

  4. Android Studio中Button等控件的Text中字符串默认大写的解决方法

    初学Android的时候,在Android Studio中xml里面添加一个Button.EditText等控件后,它的Text总是会显示大写,即使你输入的字符串是小写也不行,控制字符串大小写的属性是 ...

  5. .Net程序员之不学Java做安卓开发:Android Studio中的即时调试窗口

    对学.Net的人来说,JAVA开发是一场噩梦. .net中的即时窗口,调试时直接在里面写代码,对程序中的各种方法/属性进行调用,很方便. Android Studio中找了好久,参考如下网址,也有类似 ...

  6. 如何将Eclipse中的项目迁移到Android Studio 中

    如何将Eclipse中的项目迁移到Android Studio 中 如果你之前有用Eclipse做过安卓开发,现在想要把Eclipse中的项目导入到Android Studio的环境中,那么首先要做的 ...

  7. 在android studio 中使用applicationid的问题

    现在我需要对项目app的某个功能做性能测试,主要测试耗电量的多少. 1.我想到的方式是,我需要在同一台手机测试,同一个应用,需要安装在手机两次,第二次安装不覆盖第一次的安装. 在android stu ...

  8. Android studio 中的配置编译错误总结

    1.编译Andorid 工程的时候,有时候出现gradle 报下面的错误. Error:(1, 0) Cause: com/android/build/gradle/LibraryPlugin : U ...

  9. Android Studio中清单文件改versionCode和versionName没效果的原因

    在Android Studio中,项目的versionCode 和versionName 的控制不是在AndroidManifest.xml清单文件中更改的,而是在项目的build.gradle中更改 ...

随机推荐

  1. mysql的sql_mode合理设置

    mysql的sql_mode合理设置 sql_mode是个很容易被忽视的变量,默认值是空值,在这种设置下是可以允许一些非法操作的,比如允许一些非法数据的插入.在生产环境必须将这个值设置为严格模式,所以 ...

  2. python基础-range用法_python2.x和3.x的区别

    #range帮助创建连续的数字,通过设置步长来指定不连续 python2.7 #直接就在内存中创建出来(0-99) >>> range(100)[0, 1, 2, 3, 4, 5, ...

  3. git diff命令

    1. 比较两次提交的差异 2. 两个分支之间的比较 3. 暂存区和版本库的比较

  4. 【BZOJ 3735】苹果树 树上莫队(树分块+离线莫队+鬼畜的压行)

    2016-05-09 UPD:学习了新的DFS序列分块,然后发现这个东西是战术核导弹?反正比下面的树分块不知道要快到哪里去了 #include<cmath> #include<cst ...

  5. MathType给公式加三角着重号的方法

    MathType是一款出色的数学公式编辑器,不仅可以兼容word,还与PPT也兼容.它也可以在PPT中编辑出非常漂亮的公式,再加上PPT本身所具有的动画.颜色.显示等功能,在演示数学公式时非常的精美. ...

  6. JQuery 判断浏览器及其版本

    JQuery 中用 方法 jQuery.browser 来判断浏览器,返回值可以为: safari opera msie mozilla. 当然有时候我们还需要区分版本 这就要用到 jQuery.br ...

  7. 【codevs1012】最大公约数和最小公倍数

    题目描述 Description 输入二个正整数x0,y0(2<=x0<100000,2<=y0<=1000000),求出满足下列条件的P,Q的个数 条件:  1.P,Q是正整 ...

  8. 【bzoj3156】 防御准备

    http://www.lydsy.com/JudgeOnline/problem.php?id=3156 (题目链接) 题意 给出n个防御节点,每个节点有两种选择,可以花费a[i]建立一个防御塔,或者 ...

  9. bzoj2588 Count on a tree

    题意:给定一棵树,有点权,不带修改,询问路径点权第K大,强制在线. 这道题建主席树的方法好机智.按照BFS/DFS序建树,对于每个点,建出"这个点到根节点的路径上的点"组成的权值线 ...

  10. joomla \libraries\joomla\session\session.php 反序列化截断畸形字符串导致对象注入漏洞

    catalog . 漏洞描述 . PHP SESSION持久化 . PHP 序列化/反序列化内核实现 . 漏洞代码分析 . POC构造技巧 . 防御方案 . Code Pathc方案 1. 漏洞描述 ...