<?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>

sqlite增删改查 SimpleCursorAdapter 事务的更多相关文章

  1. android 入门 006(sqlite增删改查)

    android 入门 006(sqlite增删改查) package cn.rfvip.feb_14_2_sqlite; import android.content.Context; import ...

  2. iOS sqlite 增删改查 简单封装(基于 FMDB)

    /** *  对 sqlite 的使用进行简单封装,仅涉及简单的单表 增删改查 * *  基于 FMDB * *  操作基于 model ,数据库表字段与 model 属性一一对应,对 model 整 ...

  3. ASP.NET C# 连接 Oracle数据库增删改查,事务

    一.知识介绍 ①ASP.NET 使用的是MVC模式,开发工具Visual studio ,语言C# ②Oracle是比较重型的数据库,这里主要介绍连接数据库,对数据进行具体的使用 ③Visual St ...

  4. C#Sqlite增删改查

    说到使用数据库的话,无非也就是对数据的增加,删除和修改以及查询.前文已经 创建好了程序,现在我们就可以来具体实现Sqlite的数据操作,增删改查. 第一步,创建连接字符串来连接数据库: private ...

  5. iOS SQLite 增删改查的封装(关系型)

    在工程里导入libsqlite3.tbd库(Xcode 7) #import <UIKit/UIKit.h> @interface AppDelegate : UIResponder &l ...

  6. C# 连接 Oracle数据库增删改查,事务

    一. 前情提要 一般.NET环境连接Oracle数据库,是通过 TNS/SQL.NET 配置文件,而 TNS 必须要 Oracle 客户端(如果连接的是服务器的数据库,本地还要装一个 client , ...

  7. Android学习---SQLite数据库的增删改查和事务(transaction)调用

    上一篇文章中介绍了手工拼写sql语句进行数据库的CRUD操作,本文将介绍调用sqlite内置的方法实现CRUD操作,其实质也是通过拼写sql语句. 首先,创建一个新的android项目: 其次,查看代 ...

  8. andorid SQLite数据库的增删改查 和事务操作

    .xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android ...

  9. Android学习笔记_9_SQLiteOpenHelper对象之数据库增删改查以及事务回滚操作

    一.SQLite数据库: 在Android平台上,集成了一个嵌入式关系型数据库—SQLite,SQLite3支持 NULL.INTEGER.REAL(浮点数字).TEXT(字符串文本)和BLOB(二进 ...

随机推荐

  1. UI自动化测试篇 :ReportNG替代TestNG自带html版测试报告初探

    转载http://www.cnblogs.com/chengtch/p/6071322.html “1.1.4版本的ReportNG是最后一个版本,之后不再做维护.作为一个简单的测试报告插件,它是创造 ...

  2. 使用终端shell命令批量改动一个文件下的全部文件的读写权限

    之前对openfire安装的目录就遇到过这个问题,今天再次遇到.须要改动一个目录以下的全部子目录以及文件的三个权限:本用户读写.管理员读写.全部人读写,三个都要需改为wr 步骤例如以下:比如我要改动/ ...

  3. 倍福TwinCAT(贝福Beckhoff)基础教程5.1 TwinCAT-4 获取本机名称和网卡名称

    使用命令FB_GetHostName来获取本机名称,返回的是一个字符串   使用命令FB_GetAdaptersInfo获取网卡信息(注意采集到的是一个非常复杂的类型,本身是一个数组,数组的每个元素又 ...

  4. 利用 getsockname 和 getpeername 来获取某一个链接的本地地址和远端地址

    在两台计算机上建立一个网络连接,需要五个要素:本机地址 本机端口 协议类型 远端端口 远端地址.那么如何从一个建立好的连接上获取这些信息呢.就需要用到 getsockname  和 getpeerna ...

  5. C2:抽象工厂 Abstract Factory

    提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类. 应用场景: 一系列相互依赖的对象有不同的具体实现.提供一种“封装机制”来避免客户程序和这种“多系列具体对象创建工作”的紧耦合 UM ...

  6. acd - 1403 - Graph Game(博弈 + 二分图最大匹配)

    题意:N与P在玩游戏,N有 n1 个点,P有 n2 个点,N的点与P的点之间有 m 条无向边.将一个石子放在当中一点.N先移动石子.沿边移动一次,石子移动前的点及与该点相连的边被删除.接着到P移动石子 ...

  7. JavaScript类数组转换为数组 面试题

    1.JavaScript类数组转换为数组 (1)方法一:借用slice (2)方法二:Array.from 2.代码 <!DOCTYPE html> <html lang=" ...

  8. jquery ui widget 源代码分析

    jquery ui 的全部组件都是基于一个简单,可重用的widget. 这个widget是jquery ui的核心部分,有用它能实现一致的API.创建有状态的插件,而无需关心插件的内部转换. $.wi ...

  9. 【Java】Java_18 方法

    方法(Method) 设计方法的原则:方法的本意是功能块,就是实现某个功能的语句块的集合.   我们设计方法的时候,最好保持方法的原子性,就是一个方法只完成1个功能,这样利于我们后期的扩展 方法的要点 ...

  10. Oracle 重置序列

    Oracle将自增sequence重置为初始值1时,若是删除再重建,那么依赖它的函数和存储过程将失效,需要重新编译. 这里利用相反的过程,利用负值步长参数,将递增值改为(sequence.NEXTVA ...