sqlite有两种方式操作数据库:
第一种就是像oracle一样直接写sql语句
第二种就是借助工具,只写关键代码
下面将对这两种方式进行演示:
1,在xml中创建按钮,进行 查询和 固定的删除,修改,添加,
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" > <TextView android:id="@+id/textView1" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_alignParentTop="true" android:layout_marginTop="130dp" /> <Button android:id="@+id/button1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:layout_below="@+id/textView1" android:layout_marginLeft="18dp" android:layout_marginTop="44dp" android:onClick="optionuser" android:text="添加" /> <Button android:id="@+id/button2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignBottom="@+id/button1" android:layout_marginLeft="46dp" android:layout_toRightOf="@+id/button1" android:onClick="optionuser" android:text="删除" /> <Button android:id="@+id/button3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignLeft="@+id/button1" android:layout_below="@+id/button1" android:layout_marginTop="22dp" android:onClick="optionuser" android:text="修改" /> <Button android:id="@+id/button4" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignBaseline="@+id/button3" android:layout_alignBottom="@+id/button3" android:layout_alignLeft="@+id/button2" android:onClick="optionuser" android:text="查询" /> </RelativeLayout>
2,创建数据库的表的类
public class HelperDemo extends SQLiteOpenHelper{ public HelperDemo(Context context, String name, CursorFactory factory, int version) { //参数一:上下文 //参数二:数据库的名字 //参数三:游标 没有游标就为null //参数四:数据库的版本号 版本号不能小于当前的版本号 super(context, name, factory, version); // TODO Auto-generated constructor stub } @Override public void onCreate(SQLiteDatabase db) { //创建表 String sql="create table user(_id integer primary key autoincrement,userphone txet,username text)"; db.execSQL(sql); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { // TODO Auto-generated method stub } }
分析:
创建数据库 需要继承SQLiteOpenHelper 并重写里面的onCreate()和onUpgrade()方法;
onCreate()方法;创建表 回调函数 在程序执行时需要操作该表时,如发现没有该表就会回调onCreate方法创建表;该方法只会执行一次
onUpgrade();当版本号更新时,会回调该函数
3,实现增删改查的操作(两种方式);
/** * * @author Administrator 数据库的操作 */ public class DemoDB extends Activity { //v1显示查询的结果 //t1,t2,t3,t4分别是增删改查按钮 private TextView v1; private Button t1; private Button t2; private Button t3; private Button t4; private HelperDemo demo; 获取数据库对象 private SQLiteDatabase database; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main_db); //实例化数据库对象 demo = new HelperDemo(this, "user_contacts", null, 1); //获得xml的组件 v1 = (TextView) this.findViewById(R.id.textView1); t1 = (Button) this.findViewById(R.id.button1); t2 = (Button) this.findViewById(R.id.button2); t3 = (Button) this.findViewById(R.id.button3); t4 = (Button) this.findViewById(R.id.button4); } // 数据库的操作 public void optionuser(View v) { switch (v.getId()) { case R.id.button1:// 添加数据 database = demo.getWritableDatabase(); //获得写数据的对象 //判断是否可以写数据等操作 if (database == null) { Toast.makeText(this, "不能添加数据", Toast.LENGTH_SHORT).show(); } else { // 第一个方式 String sql = "insert into user values(null,'12345','长沙')"; database.execSQL(sql); // 第二种方式 // 参数一:表名 // 参数二:null // 参数三:使用ContentValues赋值 // ContentValues values = new ContentValues(); // values.put("userphone", "123"); // values.put("username", "value"); // // database.insert("user", null, values); selectuser(); } break; case R.id.button2:// 删除 database = demo.getWritableDatabase(); if (database == null) { Toast.makeText(this, "不能删除数据数据", Toast.LENGTH_SHORT).show(); } else { // //第一种方式 // String sql ="delete from user where _id=?"; // String[] str= {"1"}; // database.execSQL(sql, str); // 第二种方式 // 参数一:表名 // 参数二:条件 // 参数三:条件的值 String whereClause = "_id=?"; String[] whereArgs = { "2" }; database.delete("user", whereClause, whereArgs); } selectuser(); break; case R.id.button3:// 修改 database = demo.getWritableDatabase(); if (database == null) { Toast.makeText(this, "不能修改数据", Toast.LENGTH_SHORT).show(); } else { // 第一种方式 // String sql="update user set username='武汉' where _id=6"; // database.execSQL(sql); // 参数一:表名 // 参数二:更新的值 // 参数三:?的字段名 // 参数四:?字段名的值 ContentValues values = new ContentValues(); values.put("username", "北京"); String whereClause = "_id=?"; String[] whereArgs = { "5" }; database.update("user", values, whereClause, whereArgs); } selectuser(); break; case R.id.button4:// 查询 selectuser(); break; } } // 查询 public void selectuser() { SQLiteDatabase database2 = demo.getReadableDatabase(); // // 第一种方式 // String sql = "select * from user order by _id desc"; // Cursor c = database2.rawQuery(sql, null); // StringBuffer buffer = new StringBuffer(); // while (c.moveToNext()) { // int id = c.getInt(c.getColumnIndex("_id")); // String phone = c.getString(c.getColumnIndex("userphone")); // String name = c.getString(c.getColumnIndex("username")); // buffer.append(id + "\t姓名:\t" + name + "<><>电话:\t" + phone + "\r\n"); // } // v1.setText(buffer); //第二种方式 //参数一:表名 //查询数据会返回一个游标对象,遍历游标对象就得到值 Cursor c=database2.query("user", null, null, null, null, null, null); StringBuffer buffer = new StringBuffer(); while (c.moveToNext()) { int id = c.getInt(c.getColumnIndex("_id")); String phone = c.getString(c.getColumnIndex("userphone")); String name = c.getString(c.getColumnIndex("username")); buffer.append(id + "\t姓名:\t" + name + "<><>电话:\t" + phone + "\r\n"); } v1.setText(buffer); } }
分析:
增删改;需要判断数据库的表是否可以进行写的操作;
database = demo.getWritableDatabase();
if (database == null) {
Toast.makeText(this, "不能修改数据", Toast.LENGTH_SHORT).show();
}
相关推荐
根据提供的文档信息,我们可以深入探讨如何在Android应用中利用SQLite数据库来实现基本的数据增删改查(CRUD:Create, Read, Update, Delete)操作。 ### 标题:Android之SQLite实现增删改查 #### 知识点一:...
本教程将详细介绍如何在Android中利用SQLite进行数据库的增删改查操作,以及介绍两种不同的实现方法。 ### 一、SQLite数据库基本概念 SQLite数据库由三部分组成:SQLite引擎、SQL语句和SQLite数据库文件。在...
封装了一个mysqlUtils工具包, 专门用于创建数据库连接(其中包含两种连接方式, 简单的createConnection方式和createPool创建连接池的方式), 同时对数据库实现增删改查, 登录等功能的SQL语句进行处理, 并且对返回结果...
"SQLiteDemo"可能是一个示例项目或库,它可能提供了一种更直观的方式来执行这些SQLite操作。在实际开发中,我们通常会使用编程语言(如Python、Java、C#等)的SQLite库,通过编写代码来与数据库交互,而不是直接在...
本项目是一个针对Android平台的新闻应用,它涵盖了Android开发中的基础功能和核心知识点,包括用户注册、登录以及新闻数据的增删改查操作。这个期末大作业旨在帮助学生掌握Android应用开发的基本技能,提升实际项目...
这个"ASP.NET增删改查例子(作业)"是一个针对初学者的教程,旨在教授如何在ASP.NET环境中实现基本的数据操作功能,即创建(Create)、读取(Read)、更新(Update)和删除(Delete),简称CRUD。 在ASP.NET中,CRUD...
综上所述,"Test多表联合增删改查,struts两个JAVABEAN"这个主题涵盖了Struts框架的使用、JavaBean的设计、SSH框架的集成、Android开发的基础、数据库管理和设计模式的应用等多个IT领域的重要知识点。通过深入学习和...
本文将深入探讨C#语言与数据库操作,特别是增删改查(CRUD)操作,以及如何结合SQLite和SQL Server数据库实现这些功能。 首先,C#是一种面向对象的编程语言,广泛应用于Windows平台上的应用程序开发。在本系统中,...
本示例将详细介绍如何使用C#调用SQLite进行增删改查操作,并包含了一个实际的项目工程,供开发者参考学习。 首先,SQLite数据库引擎(sqlite3.exe)是一个独立的可执行文件,无需安装,可以直接在项目中引用。在C#...
在"SQLite的增删改查"这一主题中,我们将探讨如何在SQLite数据库中执行基本的操作,包括创建表、插入数据(增加)、查询数据、更新数据(修改)以及删除数据。 1. 创建表:在SQLite中,我们首先需要定义数据表结构...
总结来说,SQLite在Android中的应用主要涉及创建数据库和表、执行SQL语句进行数据的增删改查操作。了解并熟练掌握这些基本操作对于Android开发者至关重要,因为本地数据存储通常是应用程序不可或缺的部分。通过合理...
本示例将详细介绍如何在Android中进行SQLite数据库的增删改查操作。 1. **创建数据库和表** 在Android中,我们通常通过继承`SQLiteOpenHelper`类来创建和管理数据库。`SQLiteOpenHelper`提供了`onCreate()`和`...
【简易留言板基本的增删改查PHP】是一个基础的PHP应用程序,主要功能是实现一个简单的用户交互系统,允许用户在网站上发布留言、编辑、删除和查看留言。在这个系统中,PHP作为服务器端脚本语言,负责处理用户请求并...
SQLite支持SQL语法,使得我们能够方便地进行数据的增删改查操作。在这个主题中,我们将深入探讨如何在Android应用中使用SQLite数据库,并将数据展示在ListView上,同时优化ListView的性能。 首先,我们需要创建一个...
PDO提供了两种错误模式:异常和错误代码。在上述示例中,我们使用了异常模式。另一种是设置错误模式为`PDO::ERRMODE_WARNING`,会抛出警告而不是异常。 8. **游标** PDOStatement对象可以配置不同的游标类型,如...
- Intent有两种类型:显式Intent和隐式Intent。显式Intent通过指定组件的完整类名来启动特定的组件,而隐式Intent则根据指定的动作、数据和类别来寻找能够处理它的组件。 2. **创建Activity**: - 在实现通信录...
在本文中,我们将深入探讨如何使用C#编程语言与XML(可扩展标记语言)结合,实现数据的增、删、改、查操作。C#是一种广泛应用于开发Windows应用程序、Web服务以及游戏等领域的面向对象的编程语言,而XML则是一种用于...
本文将详细介绍如何在Android中使用SQLite进行增删改查操作,并涉及数据库版本管理。 首先,SQLite数据库支持五种基本数据类型:NULL、INTEGER、REAL、TEXT和BLOB。尽管它的数据类型有限,但在实际使用中,SQLite...
这个压缩包中的源码提供了一个基础的Android应用示例,展示了如何进行SQLite数据库的增、删、查、改(CRUD)操作。以下是关于这个主题的详细讲解。 首先,要使用SQLite,我们需要在Android应用中创建一个...
本文将深入探讨一个使用Qt框架构建的登录系统,该系统采用Avl树作为数据结构进行增删改查操作,是计算机专业学生理想的毕业设计案例。Qt是一个跨平台的C++图形用户界面应用程序开发框架,它提供了一系列工具和库,使...