public void onCreate(SQLiteDatabase db);// 该函数在数据库第一次被建立时调用 public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion);// 数据库更新升级操作
import java.util.Random;
import android.R.bool;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
public class DBHelper extends SQLiteOpenHelper {
// 设置数据库默认版本
private static final int VERSON = 1;
// 自定义数据库名,可以随便取名字
private static final String DBNAME = "mydb";
// 继承SQLiteOpenHelper类的类必须有自己的构造函数
// 该构造函数4个参数,直接调用父类的构造函数。其中第一个参数为该类本身;第二个参数为数据库的名字;
public DBHelper(Context context, String name, CursorFactory factory,
int version) {
super(context, name, factory, version);
}
// 该构造函数有3个参数,因为它把上面函数的第3个参数固定为null了
public DBHelper(Context context, String name, int verson) {
this(context, name, null, verson);
}
// 该构造函数只有2个参数,在上面函数 的基础上将版本号固定了
public DBHelper(Context context, String name) {
this(context, name, VERSON);
}
// 该构造函数只有1个参数,固定默认数据库,在这里我们实现增删改查为了方便,就用它了
public DBHelper(Context context) {
this(context, DBNAME, null, VERSON);
}
// 该函数在数据库第一次被建立时调用
public void onCreate(SQLiteDatabase db) {
System.out.println("create a sqlite database");
//建表语句(注意:因为在绑定数据时,Cursor对象返回的记录集中必须包含一个"_id"字段,否则无法完成数据绑定
String sql = "CREATE TABLE [test]("+
"[_id] AUTOINC,"+
"[name] varchar(20),"+
"[age] varchar(20),"+
"PRIMARY KEY ([_id]))";
db.execSQL(sql);
//向test表中插入10条数据
for (int i = 1; i <= 10; i++) {
String name = "Jepson";
name+=i;
String age = "age";
age+=i;
db.execSQL("insert into test(name,age) values(?,?)",new Object[]{name,age});
}
}
// 数据库更新操作
public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {
System.out.println("update a sqlite database");
}
//自定义query方法,用以执行查询语句,返回Cursor对象
public Cursor query(String sql,String[] args){
//调用 getReadableDatabase方法时,如果数据库文件不存在,会调用 onCreate方法
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.rawQuery(sql, args);
return cursor;
}
}
<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:background="#FFFFFF" android:orientation="vertical" tools:context=".MainActivity" > <ListView android:id="@android:id/list" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_weight="1" android:divider="#6b6f74" android:dividerHeight="1px" > </ListView> </LinearLayout>
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:background="#FFFFFF"> <!-- 大字体TextView,用以展示 name姓名 --> <TextView android:id="@+id/tvName" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="Large" android:textColor="#000000" android:textSize="20dp" /> <!-- 小字体TextView,用以展示 age年龄 --> <TextView android:id="@+id/tvAge" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="Small" android:textColor="#000000" android:textSize="14dp" /> </LinearLayout>
import android.os.Bundle;
import android.app.Activity;
import android.app.ListActivity;
import android.database.Cursor;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.Menu;
import android.widget.Toast;
public class MainActivity extends ListActivity {
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
}
public void initView(){
//调用只有1个参数的构造函数,实例化dbHelper
DBHelper dbHelper = new DBHelper(this);
//新建Cursor对象来保存query查询方法返回的结果,查询test表中所有记录
Cursor cursor = dbHelper.query("select * from test", null);
//创建SimpleCursorAdapter对象,5个参数,
//第一个是context,就写当前this就行
//第二个是布局文件,我这里是自定义的布局文件user_list_cell.xml
//第三个就是Cursor对象
//第四个对应就是,cursor查询后,需要显示出来的字段名,比如我要显示姓名name和年龄age
//第五个就是对应列表项布局中的控件ID了
SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(this,
R.layout.user_list_cell, cursor,
new String[] { "name", "age" }, new int[] { R.id.tvName,
R.id.tvAge });
setListAdapter(simpleCursorAdapter);
Toast.makeText(this, "查询成功", Toast.LENGTH_SHORT).show();
}
}
import android.os.Bundle;
import android.app.Activity;
import android.app.ListActivity;
import android.database.Cursor;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.Menu;
import android.widget.Toast;
public class MainActivity extends ListActivity {
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
}
public void initView(){
//执行添加操作
DBHelper dbHelper = new DBHelper(this);
//获得写入权限getWritableDatabase
SQLiteDatabase db = dbHelper.getWritableDatabase();
//新建contentvalues保存insert数据
ContentValues cv = new ContentValues();
cv.put("name", "11");
cv.put("age", "22");
db.insert("test", null, cv);
Toast.makeText(this, "添加成功", Toast.LENGTH_SHORT).show();
////查询操作
////调用只有1个参数的构造函数,实例化dbHelper
//DBHelper dbHelper = new DBHelper(this);
////新建Cursor对象来保存query查询方法返回的结果,查询test表中所有记录
//Cursor cursor = dbHelper.query("select * from test", null);
////创建SimpleCursorAdapter对象,5个参数,
////第一个是context,就写当前this就行
////第二个是布局文件,我这里是自定义的布局文件user_list_cell.xml
////第三个就是Cursor对象
////第四个对应就是,cursor查询后,需要显示出来的字段名,比如我要显示姓名name和年龄age
////第五个就是对应列表项布局中的控件ID了
//SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(this,
// R.layout.user_list_cell, cursor,
// new String[] { "name", "age" }, new int[] { R.id.tvName,
// R.id.tvAge });
//setListAdapter(simpleCursorAdapter);
//Toast.makeText(this, "查询成功", Toast.LENGTH_SHORT).show();
}
}
import android.os.Bundle;
import android.app.Activity;
import android.app.ListActivity;
import android.database.Cursor;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.Menu;
import android.widget.Toast;
public class MainActivity extends ListActivity {
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
}
public void initView(){
//解析Cursor对象的查询操作
DBHelper dbHelper = new DBHelper(this);
SQLiteDatabase db = dbHelper.getWritableDatabase();
Cursor cursor = db.query("test", null, null, null, null, null, null,
null);
//定义结果字符串
String result = "";
// 判断cursor不为空 这个很重要
if (cursor != null) {
while (cursor.moveToNext()) {
String name = cursor.getString(cursor.getColumnIndex("name"));// 获取name列的值
String age = cursor.getString(cursor.getColumnIndex("age"));// 获取age列的值
result += "姓名:" + name + ",年龄:" + age + "\n";
}
}
cursor.close();
db.close();
System.out.println(result);
Toast.makeText(this, result, Toast.LENGTH_SHORT).show();
// //执行添加操作
// DBHelper dbHelper = new DBHelper(this);
// //获得写入权限getWritableDatabase
// SQLiteDatabase db = dbHelper.getWritableDatabase();
// //新建contentvalues保存insert数据
// ContentValues cv = new ContentValues();
// cv.put("name", "11");
// cv.put("age", "22");
// db.insert("test", null, cv);
// Toast.makeText(this, "添加成功", Toast.LENGTH_SHORT).show();
////查询操作
////调用只有1个参数的构造函数,实例化dbHelper
//DBHelper dbHelper = new DBHelper(this);
////新建Cursor对象来保存query查询方法返回的结果,查询test表中所有记录
//Cursor cursor = dbHelper.query("select * from test", null);
////创建SimpleCursorAdapter对象,5个参数,
////第一个是context,就写当前this就行
////第二个是布局文件,我这里是自定义的布局文件user_list_cell.xml
////第三个就是Cursor对象
////第四个对应就是,cursor查询后,需要显示出来的字段名,比如我要显示姓名name和年龄age
////第五个就是对应列表项布局中的控件ID了
//SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(this,
// R.layout.user_list_cell, cursor,
// new String[] { "name", "age" }, new int[] { R.id.tvName,
// R.id.tvAge });
//setListAdapter(simpleCursorAdapter);
//Toast.makeText(this, "查询成功", Toast.LENGTH_SHORT).show();
}
}
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有