android数据库简单操作
1.DbOpenHelper
package com.example.dbtest.dbHelper; import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper; //继承SQLiteOpenHelper类
public class DbOpenHelper extends SQLiteOpenHelper { public DbOpenHelper(Context context) {
//Context 上下文
//name 数据库名
//CursorFactory 游标工厂模式 当为null时 使用默认值
//version 数据库版本 版本号从1开始
super(context, "test.db", null, 1);
} /**
* 第一次访问数据库 执行方法
* */
@Override
public void onCreate(SQLiteDatabase db) {
//创建表结构
String sql = "create table person(id integer primary key autoincrement,name varchar(20),age int,phone varchar(11))";
db.execSQL(sql); } @Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { } }
2.实体
package com.example.dbtest.domain;
public class Person {
private int id;
private String name;
private int age;
private String phone;
public Person(){}
public Person(int id, String name, int age, String phone) {
super();
this.id = id;
this.name = name;
this.age = age;
this.phone = phone;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
@Override
public String toString() {
return "个人信息[id=" + id + ", name=" + name + ", age=" + age
+ ", phone=" + phone + "]";
}
}
3.personDao
package com.example.dbtest.dao; import java.util.ArrayList;
import java.util.List; import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase; import com.example.dbtest.dbHelper.DbOpenHelper;
import com.example.dbtest.domain.Person; public class PersonDao { private DbOpenHelper helper; public PersonDao(Context context)
{
helper = new DbOpenHelper(context);
} //添加一条记录
public void add(Person p)
{
SQLiteDatabase db = helper.getWritableDatabase();
String sql = "insert into person(name,age,phone) values(?,?,?)";
db.execSQL(sql, new Object[]{p.getName(),p.getAge(),p.getPhone()}); } //修改一条记录
public void update(Person p)
{
SQLiteDatabase db = helper.getWritableDatabase();
String sql = "update person set age=?,phone=? where name=?";
db.execSQL(sql, new Object[]{p.getAge(),p.getPhone(),p.getName()}); } //删除一条记录
public void delete(String name)
{
SQLiteDatabase db = helper.getWritableDatabase();
String sql = "delete from person where name=?";
db.execSQL(sql,new Object[]{name});
} public Person findByName(String name)
{ SQLiteDatabase db = helper.getReadableDatabase();
String sql = "select * from person where name=?";
Cursor cursor = db.rawQuery(sql, new String[]{name});
Person p = null;
while(cursor.moveToNext())
{
int id = cursor.getInt(cursor.getColumnIndex("id"));
String phone = cursor.getString(cursor.getColumnIndex("phone"));
int age = cursor.getInt(cursor.getColumnIndex("age"));
p = new Person(id,name,age,phone);
}
return p;
} public List<Person> findAll(String name)
{ SQLiteDatabase db = helper.getReadableDatabase();
String sql = "select * from person where name=?";
Cursor cursor = db.rawQuery(sql, new String[]{name});
List<Person> list = new ArrayList();
while(cursor.moveToNext())
{
int id = cursor.getInt(cursor.getColumnIndex("id"));
String phone = cursor.getString(cursor.getColumnIndex("phone"));
int age = cursor.getInt(cursor.getColumnIndex("age"));
Person p = new Person(id,name,age,phone);
list.add(p);
}
return list;
} }
4.activity.xml
<RelativeLayout 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: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.dbtest.MainActivity" > <Button
android:id="@+id/btn_createDB"
android:onClick="createDB"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="创建数据库" /> <TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/btn_createDB"
android:layout_below="@+id/btn_createDB"
android:text="姓名" /> <EditText
android:id="@+id/et_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/textView1"
android:layout_below="@+id/textView1"
android:layout_marginLeft="21dp"
android:layout_marginTop="24dp"
android:ems="10"
/> <TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/btn_createDB"
android:layout_below="@+id/et_name"
android:text="电话" /> <EditText
android:id="@+id/et_phone"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/textView2"
android:layout_below="@+id/textView2"
android:layout_marginLeft="21dp"
android:layout_marginTop="24dp"
android:ems="10"
/> <Button
android:id="@+id/btn_save"
android:onClick="save"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/et_phone"
android:text="保存" />
<Button
android:id="@+id/btn_update"
android:onClick="update"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/btn_save"
android:text="修改" />
<Button
android:id="@+id/btn_find"
android:onClick="findOne"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/btn_update"
android:text="查询" />
<Button
android:id="@+id/btn_delete"
android:onClick="delete"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/btn_find"
android:text="删除" /> </RelativeLayout>
5.activity对应点击事件
package com.example.dbtest; import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.text.TextUtils;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.EditText;
import android.widget.Toast; import com.example.dbtest.dao.PersonDao;
import com.example.dbtest.dbHelper.DbOpenHelper;
import com.example.dbtest.domain.Person; public class MainActivity extends ActionBarActivity { @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
} public void createDB(View v)
{
DbOpenHelper db = new DbOpenHelper(this);
//该句才真正创建数据库
db.getWritableDatabase();
Toast.makeText(this, "数据库创建成功", 0).show(); } public void save(View v)
{
EditText nameText = (EditText)this.findViewById(R.id.et_name);
EditText phoneText = (EditText)this.findViewById(R.id.et_phone);
String name = nameText.getText().toString();
String phone = phoneText.getText().toString();
if(TextUtils.isEmpty(name) || TextUtils.isEmpty(phone))
{
Toast.makeText(this, "姓名和电话不能为空", 0).show();
return;
}
PersonDao dao = new PersonDao(this);
Person p = new Person();
p.setName(name);
p.setPhone(phone);
dao.add(p);
Toast.makeText(this, "保存成功", 0).show(); } public void update(View v)
{
EditText nameText = (EditText)this.findViewById(R.id.et_name);
EditText phoneText = (EditText)this.findViewById(R.id.et_phone);
String name = nameText.getText().toString();
String phone = phoneText.getText().toString(); PersonDao dao = new PersonDao(this);
Person p = new Person();
p.setName(name);
p.setPhone(phone);
dao.update(p);
Toast.makeText(this, "修改成功", 0).show(); } public void delete(View v)
{
EditText nameText = (EditText)this.findViewById(R.id.et_name);
EditText phoneText = (EditText)this.findViewById(R.id.et_phone);
String name = nameText.getText().toString();
String phone = phoneText.getText().toString(); PersonDao dao = new PersonDao(this);
dao.delete(name);
Toast.makeText(this, "删除成功", 0).show(); } }
android数据库简单操作的更多相关文章
- MongoDB数据库简单操作
之前学过的有mysql数据库,现在我们学习一种非关系型数据库 一.简介 MongoDB是一款强大.灵活.且易于扩展的通用型数据库 MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数 ...
- MySQL数据库简单操作
title date tags layout MySQL简单操作 2018-07-16 Linux post 登录mysql mysql -h 主机名 -u 用户名 -p 查看所有数据库 show d ...
- SQL数据库简单操作
sql语言简介 (1)数据库是文件系统,使用标准sql对数据库进行操作 * 标准sql,在mysql里面使用语句,在oracle.db2都可以使用这个语句 (2)什么是sql * Structured ...
- Android基础之sqlite 数据库简单操作
尽管很简单,但是也存下来,以后直接粘过去就能用了. public class DBHelper extends SQLiteOpenHelper { private static final ...
- Oracle 数据库简单操作
现在大型企业一般都用Oracle数据库,Oracle数据库在一般采用expdp,impdp 导出导入数据,但是在操作中经常会遇到一些问题.下面来浅析这些问题. 1. 导出数据 一般导出数据的时候需要建 ...
- 使用SQLiteOpenHelper类对数据库简单操作
实现数据库基本操作 数据库创建的问题解决了,接下来就该使用数据库实现应用程序功能的时候了.基本的操作包括创建.读取.更新.删除,即我们通常说的CRUD(Create, Read, Upda ...
- Java 数据库简单操作类
数据库操作类,将所有连接数据库的配置信息以及基本的CRUD操作封装在一个类里,方便项目里使用,将连接数据库的基本信息放在配置文件 "dbinfo.properties" 中,通过类 ...
- oracle数据库简单操作
导入某用户所有表和数据:imp sgp/sgp@192.168.0.99:1521/orcl file=sgp20161025.dmp full=y 导出指定表及数据:exp sgp/sgp@192. ...
- SQL Server 的数据库简单操作
--创建数据库--create database 数据库名称[on [primary](name='主数据逻辑文件名',filename='完整的路径.文件名和拓展名'[,size=文件大小][,fi ...
随机推荐
- js 算數(Math)對象
算數對象不需要聲明,可以直接使用, Math對象方法及作用: round()四捨五入: random()生成0到1的隨機數: max()選擇較大的數: min()返回較小的數:
- luogu3107
洛谷P3107题面 相对较为模板化的代码 f[i][j][bo1][bo2]记录到第i位,数字num出现了x次(j初始为20,若当前数字不为num,j++:否则j--:最后只要记录j<=20的总 ...
- POJ1942-Paths On a Grid-组合数学
从n+m步中挑选min(n,m)步向上走,剩下的就是向下走. 求解n+mCmin(n,m)时,要一边计算一边约分. #include <cstdio> #include <algor ...
- Java生成多数值二元运算结果集
看之前大学写过的24点程序中用到的核心计算算法——计算四个值能否计算出24,当时用的c++写的,现用Java重写一遍 程序实现了多个数值(可重复),每个数值只能运算一次,二元运算的条件下获得所有结果集 ...
- UVa - 10341
Solve the equation:p ∗ e ^−x + q ∗ sin(x) + r ∗ cos(x) + s ∗ tan(x) + t ∗ x ^2 + u = 02 + u = 0where ...
- php laravel 多条件筛选
效果如图,点击的条件出现在已选择的地方,点击已选择的条件可以删除当前点击的条件 语言是php 框架是laravel. 一.html <div class="doctor-conditi ...
- 04 Zabbix4.0系统配置触发器trigger
点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 04 Zabbix4.0系统配置触发器trigger 请点击查看Zabbix3.0.8版本trig ...
- 18 Zabbix 新增map中的icon图标
点击返回:自学Zabbix之路 18 Zabbix 新增map中的icon图标 zabbix系统默认会带有许多的icon图标,但对于特殊需求人群可能无法满足,那就需要新增icon图标. 通过Admin ...
- Selenium之WebDriver元素定位方法
Selenium WebDriver 只是 Python 的一个第三方框架, 和 Djangoweb 开发框架属于一个性质. webdriver 提供了八种元素定位方法,python语言中也有对应的方 ...
- centos6.5之Hadoop1.2.1完全分布式部署安装
0. 说明 系统中首先要安装好jdk环境. 已经配置ssh免密码登录. 设置好防火墙,或者关闭防火墙. 如果集群内机器的环境完全一样,可以在一台机器上配置好,然后把master配置好的软件即hadoo ...