- db=SQLiteDatabase.openOrCreateDatabase("/data/data/com.lingdududu.db/databases/stu.db",null);
private void createTable(SQLiteDatabase db){ //创建表SQL语句 String stu_table="create table usertable(_id integer primary key autoincrement,sname text,snumber text)"; //执行SQL语句 db.execSQL(stu_table); }
private void insert(SQLiteDatabase db) { //实例化常量值 ContentValues cValue = new ContentValues(); //添加用户名 cValue.put("sname","xiaoming"); //添加密码 cValue.put("snumber","01005"); //调用insert()方法插入数据 db.insert("stu_table",null,cValue); }
private void insert(SQLiteDatabase db){ //插入数据SQL语句 String stu_sql="insert into stu_table(sname,snumber) values('xiaoming','01005')"; //执行SQL语句 db.execSQL(sql); }
private void delete(SQLiteDatabase db) { //删除条件 String whereClause = "_id=?"; //删除条件参数 String[] whereArgs = {String.valueOf(2)}; //执行删除 db.delete("stu_table",whereClause,whereArgs); }
private void delete(SQLiteDatabase db) { //删除SQL语句 String sql = "delete from stu_table where _id = 6"; //执行SQL语句 db.execSQL(sql); }
private void update(SQLiteDatabase db) { //实例化内容值 ContentValues values = new ContentValues(); //在values中添加内容 values.put("snumber","101003"); //修改条件 String whereClause = "id=?"; //修改添加参数 String[] whereArgs={String.valuesOf(1)}; //修改 db.update("usertable",values,whereClause,whereArgs); }
private void update(SQLiteDatabase db){ //修改SQL语句 String sql = "update stu_table set snumber = 654321 where id = 1"; //执行SQL db.execSQL(sql); }
下面就是用Cursor来查询数据库中的数据,具体代码如下:
private void query(SQLiteDatabase db) { //查询获得游标 Cursor cursor = db.query ("usertable",null,null,null,null,null,null); //判断游标是否为空 if(cursor.moveToFirst() { //遍历游标 for(int i=0;i<cursor.getCount();i++){ cursor.move(i); //获得ID int id = cursor.getInt(0); //获得用户名 String username=cursor.getString(1); //获得密码 String password=cursor.getString(2); //输出用户信息 System.out.println(id+":"+sname+":"+snumber); } } }
7、删除指定表
编写插入数据的SQL语句,直接调用SQLiteDatabase的execSQL()方法来执行
private void drop(SQLiteDatabase db){ //删除表的SQL语句 String sql ="DROP TABLE stu_table"; //执行SQL db.execSQL(sql); }
在数据库第一次生成的时候会调用这个方法,也就是说,只有在创建数据库的时候才会调用,当然也有一些其它的情况,一般我们在这个方法里边生成数据库表。
2. onUpgrade(SQLiteDatabase,int,int)
当数据库需要升级的时候,Android系统会主动的调用这个方法。一般我们在这个方法里边删除数据表,并建立新的数据表,当然是否还需要做其他的操作,完全取决于应用的需求。
这是当打开数据库时的回调函数,一般在程序中不是很常使用。
package com.lingdududu.testSQLite; import com.lingdududu.testSQLiteDb.StuDBHelper; import android.app.Activity; import android.content.ContentValues; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; /* * @author lingdududu */ public class SQLiteActivity extends Activity { /** Called when the activity is first created. */ //声明各个按钮 private Button createBtn; private Button insertBtn; private Button updateBtn; private Button queryBtn; private Button deleteBtn; private Button ModifyBtn; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); //调用creatView方法 creatView(); //setListener方法 setListener(); } //通过findViewById获得Button对象的方法 private void creatView(){ createBtn = (Button)findViewById(R.id.createDatabase); updateBtn = (Button)findViewById(R.id.updateDatabase); insertBtn = (Button)findViewById(R.id.insert); ModifyBtn = (Button)findViewById(R.id.update); queryBtn = (Button)findViewById(R.id.query); deleteBtn = (Button)findViewById(R.id.delete); } //为按钮注册监听的方法 private void setListener(){ createBtn.setOnClickListener(new CreateListener()); updateBtn.setOnClickListener(new UpdateListener()); insertBtn.setOnClickListener(new InsertListener()); ModifyBtn.setOnClickListener(new ModifyListener()); queryBtn.setOnClickListener(new QueryListener()); deleteBtn.setOnClickListener(new DeleteListener()); } //创建数据库的方法 class CreateListener implements OnClickListener{ @Override public void onClick(View v) { //创建StuDBHelper对象 StuDBHelper dbHelper = new StuDBHelper(SQLiteActivity.this,"stu_db",null,1); //得到一个可读的SQLiteDatabase对象 SQLiteDatabase db =dbHelper.getReadableDatabase(); } } //更新数据库的方法 class UpdateListener implements OnClickListener{ @Override public void onClick(View v) { // 数据库版本的更新,由原来的1变为2 StuDBHelper dbHelper = new StuDBHelper(SQLiteActivity.this,"stu_db",null,2); SQLiteDatabase db =dbHelper.getReadableDatabase(); } } //插入数据的方法 class InsertListener implements OnClickListener{ @Override public void onClick(View v) { StuDBHelper dbHelper = new StuDBHelper(SQLiteActivity.this,"stu_db",null,1); //得到一个可写的数据库 SQLiteDatabase db =dbHelper.getWritableDatabase(); //生成ContentValues对象 //key:列名,value:想插入的值 ContentValues cv = new ContentValues(); //往ContentValues对象存放数据,键-值对模式 cv.put("id", 1); cv.put("sname", "xiaoming"); cv.put("sage", 21); cv.put("ssex", "male"); //调用insert方法,将数据插入数据库 db.insert("stu_table", null, cv); //关闭数据库 db.close(); } } //查询数据的方法 class QueryListener implements OnClickListener{ @Override public void onClick(View v) { StuDBHelper dbHelper = new StuDBHelper(SQLiteActivity.this,"stu_db",null,1); //得到一个可写的数据库 SQLiteDatabase db =dbHelper.getReadableDatabase(); //参数1:表名 //参数2:要想显示的列 //参数3:where子句 //参数4:where子句对应的条件值 //参数5:分组方式 //参数6:having条件 //参数7:排序方式 Cursor cursor = db.query("stu_table", new String[]{"id","sname","sage","ssex"}, "id=?", new String[]{"1"}, null, null, null); while(cursor.moveToNext()){ String name = cursor.getString(cursor.getColumnIndex("sname")); String age = cursor.getString(cursor.getColumnIndex("sage")); String sex = cursor.getString(cursor.getColumnIndex("ssex")); System.out.println("query------->" + "姓名:"+name+" "+"年龄:"+age+" "+"性别:"+sex); } //关闭数据库 db.close(); } } //修改数据的方法 class ModifyListener implements OnClickListener{ @Override public void onClick(View v) { StuDBHelper dbHelper = new StuDBHelper(SQLiteActivity.this,"stu_db",null,1); //得到一个可写的数据库 SQLiteDatabase db =dbHelper.getWritableDatabase(); ContentValues cv = new ContentValues(); cv.put("sage", "23"); //where 子句 "?"是占位符号,对应后面的"1", String whereClause="id=?"; String [] whereArgs = {String.valueOf(1)}; //参数1 是要更新的表名 //参数2 是一个ContentValeus对象 //参数3 是where子句 db.update("stu_table", cv, whereClause, whereArgs); } } //删除数据的方法 class DeleteListener implements OnClickListener{ @Override public void onClick(View v) { StuDBHelper dbHelper = new StuDBHelper(SQLiteActivity.this,"stu_db",null,1); //得到一个可写的数据库 SQLiteDatabase db =dbHelper.getReadableDatabase(); String whereClauses = "id=?"; String [] whereArgs = {String.valueOf(2)}; //调用delete方法,删除数据 db.delete("stu_table", whereClauses, whereArgs); } } }
package com.lingdududu.testSQLiteDb; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteDatabase.CursorFactory; import android.database.sqlite.SQLiteOpenHelper; import android.util.Log; public class StuDBHelper extends SQLiteOpenHelper { private static final String TAG = "TestSQLite"; public static final int VERSION = 1; //必须要有构造函数 public StuDBHelper(Context context, String name, CursorFactory factory, int version) { super(context, name, factory, version); } // 当第一次创建数据库的时候,调用该方法 public void onCreate(SQLiteDatabase db) { String sql = "create table stu_table(id int,sname varchar(20),sage int,ssex varchar(10))"; //输出创建数据库的日志信息 Log.i(TAG, "create Database------------->"); //execSQL函数用于执行SQL语句 db.execSQL(sql); } //当更新数据库的时候执行该方法 public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { //输出更新数据库的日志信息 Log.i(TAG, "update Database------------->"); } }
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="@string/hello" /> <Button android:id="@+id/createDatabase" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="创建数据库" /> <Button android:id="@+id/updateDatabase" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="更新数据库" /> <Button android:id="@+id/insert" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="插入数据" /> <Button android:id="@+id/update" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="更新数据" /> <Button android:id="@+id/query" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="查询数据" /> <Button android:id="@+id/delete" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="删除数据" /> </LinearLayout>
相关推荐
Android开发:Android Studio:数据存储方式:SharedPreferences与SQLite数据库.pdf
读书笔记:涉及到了sqlite图片存储http与服务器数据库的交互json解析等
Android 的 SQLite 中 DateTime 类型数据的存取问题 Android 平台中的 SQLite 数据库在存储 DateTime 类型的数据时会遇到一些问题。本文将详细介绍这些问题和解决方案。 日期类型数据的存储问题 -----------------...
" Android Studio开发实战:从零基础到App上线读书笔记模板 " 本书是一部Android开发的实战教程,由浅入深、由基础到高级,带领读者一步一步走进App开发的神奇世界。全书共分为16章,前8章是基础部分,主要讲解...
总之,这个案例涵盖了Android开发中关于SQLite数据库操作和ListView使用的基础知识,包括数据模型设计、数据库操作、UI交互和数据绑定。通过这个项目,开发者可以深入理解Android数据存储和UI组件的运用,为后续更...
在Android开发中,SQLite是一个非常重要的组成部分,它是一款轻量级的数据库系统,用于存储应用程序中的结构化数据。SQLite数据库引擎被集成到Android系统中,为开发者提供了方便的数据管理方式,无需额外安装服务。...
Android开发是全球最受欢迎的移动应用开发平台之一,广泛应用于智能手机、平板电脑以及各种智能设备上。这份"Android开发教程笔记完全版"涵盖了Android开发的基础到高级主题,旨在帮助开发者全面理解并掌握Android...
在本项目中,开发者实施了一个基于Android平台的记单词应用,使用SQLite数据库作为数据存储解决方案。以下是关于Android开发和SQLite数据库的关键知识点: 1. **SQLite数据库**:SQLite是Android系统内置的关系型...
基于 Android 操作系统的智能通信设备逐步走入千家万户,基于 Android 系统的程序开发已经成为了职业院校、IT 培训班的主要学习内容之一。 Android 系统下的 App 程序对运行中用到的数据源提供了多种存取方式,当...
在Android应用开发中,SQLite是一个重要的组成部分,它是一个轻量级的、开源的、嵌入式的SQL数据库引擎,被广泛用于存储和管理应用程序中的结构化数据。本案例聚焦于如何在Android环境中有效地利用SQLite来处理内置...
### Android开发学习教程—深入解析Android使用SQLite数据库 #### SQLite数据库概述 SQLite是一款轻量级、高性能的嵌入式数据库,被广泛应用于各种资源受限的环境中,如移动设备。它支持标准的SQL语言,占用内存极...
前情提要:Android 数据库(SQLite) 【简介、创建、使用(增删改查、事务、实战演练)、数据显示控件(ListView、Adapter、实战演练)】 https://blog.csdn.net/weixin_44949135/article/details/105955663 Android ...
在Android开发中,SQLite是一个非常重要的组成部分,它是一个轻量级的数据库系统,适用于移动设备。SQLite被集成到Android操作系统中,允许开发者在应用程序中存储和管理数据。本项目是针对初学者设计的一个完整的...
在Android开发中,ListView是一个非常常用的组件,常用于展示大量数据列表。本教程将指导你如何从SQLite数据库中获取数据并将其动态显示到ListView上。SQLite是一个轻量级的嵌入式数据库,适用于移动设备,它能高效...
在Android开发中,ArcGIS是一个强大的地理信息系统,它提供了丰富的地图和空间分析功能。而SQLite是一种轻量级的、开源的、嵌入式的关系型数据库,广泛应用于移动应用,包括Android。本教程将探讨如何在ArcGIS for ...
Android管理信息系统: 包括SQLite 数据库的增删改查,ListView的刷新,弹出对话框提示操作 ListView列表的优化 [注:本内容来自网络,在此分享仅为帮助有需要的网友,如果侵犯了您的权利,麻烦联系我,我会第一时间...
在Android开发中,SQLite是默认的数据存储解决方案,特别是在较低版本如4.2到4.4之间。开发者可能在尝试执行与SQLite相关的操作,如创建、查询或管理数据库时遇到“sqlite3:not found”的问题。这可能是由于以下...
在Android开发中,SQLite是一个至关重要的组件,它是一个轻量级的、自包含的、开源的SQL数据库引擎,被广泛用于存储和管理应用程序中的结构化数据。本文将深入探讨`sqlite3`命令行工具在Android环境下的应用,尤其是...
4. **数据存储**:Android提供了SQLite数据库、SharedPreferences、File存储等多种方式。理解它们各自的适用场景和操作方法,对于持久化数据至关重要。 5. **网络通信**:Android应用常常需要与服务器交互,因此...
在Android开发中,SQLite是一个非常重要的组件,它是一个轻量级的、开源的、嵌入式的SQL数据库引擎,被广泛用于存储和管理应用程序中的结构化数据。本篇将基于提供的"android存取Sqlite3数据库demo"进行详细的解析,...