package com.lidaochen.phonecall;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper; public class MyOpenHelper extends SQLiteOpenHelper { /**
*
* @param context 上下文
* name:数据库的名字
* factory 目的创建cursor对象
*
* version 数据库的版本 从1开始
*/
public MyOpenHelper(Context context)
{
super(context, "liDaochen.db", null, 4);
} /**
* Called when the database is created for the first time.
* 当数据库第一次创建的时候调用
* 那么这个方法特别适合做表结构的初始化 创建表就是写sql语句
*/
@Override
public void onCreate(SQLiteDatabase db)
{
// id 一般以_id
db.execSQL("create table info(_id integer primary key autoincrement,name varchar(20),phone varchar(20))");
} /**
* Called when the database needs to be upgraded
* 当数据库版本升级的时候调用
*
* 这个方法适合做 表结构的更新
*/
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVwesion)
{
db.execSQL("alter table info add phone varchar(20)");
}
}
package com.lidaochen.phonecall;

import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View; public class MainActivity extends AppCompatActivity{
private MyOpenHelper myOpenHelper;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
myOpenHelper = new MyOpenHelper(getApplicationContext()); } // 打开或者创建数据库 如果是第一次就创建
// SQLiteDatabase db = myOpenHelper.getWritableDatabase();
// 打开或者创建数据库 如果是第一次就创建 如果磁盘满了就返回只读的
// SQLiteDatabase sqLiteDatabase = myOpenHelper.getReadableDatabase() // 点击按钮增加一条记录
public void add(View v)
{
// 获取数据库对象
SQLiteDatabase db = myOpenHelper.getWritableDatabase();
// 执行增加一条sql语句
db.execSQL("insert into info(name,phone) values(?,?)", new Object[]{"张三", "13888888"});
// 数据库用完需要关闭
db.close();
}
// 删除
public void delete(View v)
{
// 获取数据库对象
SQLiteDatabase db = myOpenHelper.getWritableDatabase();
// 执行删除一条sql语句
db.execSQL("delete from info where name=?", new Object[]{"张三"});
// 数据库用完需要关闭
db.close();
}
// 更新
public void update(View v)
{
// 获取数据库对象
SQLiteDatabase db = myOpenHelper.getWritableDatabase();
// 执行删除一条sql语句
db.execSQL("update info set phone=? where name=? ", new Object[]{"138888888", "张三"});
// 数据库用完需要关闭
db.close();
}
// 查找
public void find(View v)
{
// 获取数据库对象
SQLiteDatabase db = myOpenHelper.getWritableDatabase();
Cursor cursor = db.rawQuery("select * from info", null);
if (cursor != null && cursor.getCount() > 0)
{
while (cursor.moveToNext())
{
// columnIndex代表列的索引
String name = cursor.getString(1);
String phone = cursor.getString(2);
System.out.println(name + ": " + phone);
}
}
}
}

最新文章

  1. 用jQuery基于原生js封装的轮播
  2. 安卓actionbar源码
  3. spark Streaming的Receiver和Direct的优化对比
  4. Unity学习资源
  5. sqlite数据库执行full outer join
  6. USB DATA Toggle
  7. java jvm学习笔记十二(访问控制器的栈校验机制)
  8. ADO.NET 快速入门(二):执行命令
  9. android146 360 病毒查杀
  10. AD DIV 层的知识 和 行为特效
  11. C程序设计语言练习题1-4
  12. Android 源码编译环境搭建(64位Ubuntu)各种依赖包安装
  13. Java中的函数对象
  14. TortoiseSVN使用
  15. Scipy教程 - 统计函数库scipy.stats
  16. Angular2入门:TypeScript的接口
  17. 20165310 NetSec2019 Week5 Exp3 免杀原理与实践
  18. MySQL Replication--修改主键为NULL导致的异常
  19. 内网服务器通过Squid代理访问外网
  20. Linux命令对应的英文及整体学习法

热门文章

  1. @Value()读取配置文件属性,读出值为null的问题
  2. 工具的更新换代 总是要折腾一下Windows10下Java Web 开发环境的配置
  3. XHProf报告字段含义
  4. [System.Serializable],
  5. Unity学习笔记_控制人物移动+摄像机跟随
  6. 蓝牙AT模式
  7. 【FFMPEG】Ubuntu上安装FFMPEG
  8. gx_dlms 的杂乱记录
  9. PDF转任意格式 & 做动画效果
  10. 洛谷 题解 P3942 【将军令】