设为首页 收藏本站
查看: 966|回复: 0

[经验分享] SQLite-Android平台对数据库的简单操作

[复制链接]

尚未签到

发表于 2016-12-1 08:29:31 | 显示全部楼层 |阅读模式
package com.lovose.SQLite;

import android.app.Activity;
import android.content.Context;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;

public class SOLiteTest extends Activity {
OnClickListener listener1 = null;
OnClickListener listener2 = null;
OnClickListener listener3 = null;
OnClickListener listener4 = null;
OnClickListener listener5 = null;

Button button01;
Button button02;
Button button03;
Button button04;
Button button05;
TextView msg;

private static final String DATABASE_NAME = "DbForSQLiteTest.db";
private static final int DATABASE_VERSION = 1;
private static final String TABLE_NAME = "diary";
private static final String TITLE = "title";
private static final String BODY = "body";

DatebaseHelper mOpenHelper;

private static class DatebaseHelper extends SQLiteOpenHelper{
DatebaseHelper(Context context){
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
// TODO Auto-generated method stub
String sql = "CREATE TABLE " + TABLE_NAME + " (" + TITLE
+ " text not null, " + BODY + " text not null " + ");";
Log.i("haiyang:createDB=", sql);
db.execSQL(sql);
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// TODO Auto-generated method stub
}
}

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        prepareListener();
        initLayout();
        mOpenHelper = new DatebaseHelper(this);
    }

private void initLayout() {
// TODO Auto-generated method stub
button01 = (Button)findViewById(R.id.Button01);
button01.setOnClickListener(listener1);

button02 = (Button)findViewById(R.id.Button02);
button02.setOnClickListener(listener2);

button03 = (Button)findViewById(R.id.Button03);
button03.setOnClickListener(listener3);

button04 = (Button)findViewById(R.id.Button04);
button04.setOnClickListener(listener4);

button05 = (Button)findViewById(R.id.Button05);
button05.setOnClickListener(listener5);

msg = (TextView)findViewById(R.id.TextView01);
}

private void prepareListener() {
// TODO Auto-generated method stub
listener1 = new OnClickListener(){
public void onClick(View v) {
// TODO Auto-generated method stub
createTable();
}
};
listener2 = new OnClickListener(){
public void onClick(View v) {
// TODO Auto-generated method stub
dropTable();
}
};
listener3 = new OnClickListener(){
public void onClick(View v){
insertItem();
}
};
listener4 = new OnClickListener(){
public void onClick(View v){
deleteItem();
}
};
listener5 = new OnClickListener(){
public void onClick(View v){
showItems();
}
};
}

//建立数据表
public void createTable() {
SQLiteDatabase db = mOpenHelper.getWritableDatabase();
String SQL = "CREATE TABLE "+TABLE_NAME+ " ( " + TITLE
+ " text not null, " + BODY + " text not null " + ");";
Log.i("haiyang:createDB=", SQL);
try{
db.execSQL("DROP TABLE IF EXISTS diary");
db.execSQL(SQL);
setTitle("数据表成功重建");
} catch (SQLException e) {
setTitle("数据表重建错误");
}
}
//删除数据表
public void dropTable(){
SQLiteDatabase db = mOpenHelper.getWritableDatabase();
String SQL = "drop table "+TABLE_NAME;
try {
db.execSQL(SQL);
setTitle("数据表成功删除:" + SQL);
} catch (SQLException e) {
setTitle("数据表删除错误");
}
}
//插入记录
public void insertItem() {
SQLiteDatabase db = mOpenHelper.getWritableDatabase();
String sql1 = "insert into " + TABLE_NAME + " (" + TITLE + ", " + BODY
+ ") values('haiyang', 'I test android');";
String sql2 = "insert into " + TABLE_NAME + " (" + TITLE + ", " + BODY
+ ") values('icesky', 'I test android too');";
String sql3 = "insert into " + TABLE_NAME + " (" + TITLE + ", " + BODY
+ ") values('wongxming', 'I test android three times');";
try {
db.execSQL(sql1);
db.execSQL(sql2);
db.execSQL(sql3);
setTitle("插入三条数据成功");
} catch (SQLException e) {
setTitle("插入三条数据失败");
}
}
//删除一条记录
public void deleteItem(){
try {
SQLiteDatabase db = mOpenHelper.getWritableDatabase();
db.delete(TABLE_NAME, " title = 'haiyang'", null);
setTitle("删除title为haiyang的一条记录");
} catch (SQLException e) {

}
}
//在屏幕的textView区域显示当前数据表当中的数据的条数。
public void showItems(){
SQLiteDatabase db = mOpenHelper.getWritableDatabase();
String col[] = { TITLE, BODY };
Cursor cur = db.query(TABLE_NAME, col, null, null, null, null, null);

Integer num = cur.getCount();
setTitle(Integer.toString(num) + " 条记录");
StringBuilder sb = new StringBuilder();
sb.append("\tTitle : body\n");
cur.moveToFirst();
do{
sb.append(cur.getString(0)+" : "+cur.getString(1)+"\n");
}while(cur.moveToNext());

msg.setText(sb.toString());
}
}

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-307896-1-1.html 上篇帖子: android中使用SQLite进行CRUD操作的实例 下篇帖子: androd SQLite 自己写的数据库操作类
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表