SQLite数据库

SQLite数据库

1、 synchronized SQLiteDatabase getReadableDatabase();
作用:以读写的方式打开数据库对应的SQLiteDatabase类的对象
2、 synchronized SQLiteDatabase getWriteableDatabase();
作用:以写的方式创建或打开库对应的SQLiteDatabase类的对象
3、 abstract onCreate(SQLiteDatabase db);
作用:首次创建数据库时调方法。
4、 abstract onUpgrade(SQLiteDatabase db,int oldVersion,
int newVersion);
作用:数据库版本更新时调方法。
5、 synchronized void close();
作用:关闭所有打开的SQLiteDatabase对象。

定义MySQLiteOpenHelper,实现增、删、改操作

public MySQLite(Context context) {
super(context, "person.db", null, 1);
// TODO Auto-generated constructor stub
}

@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("create table person("+
"id Integer primary key autoincrement,"
+"name varchar(20),"
+"phone varchar(11));");
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

}
/**向数据库添加数据*/
public void insert(String sql,Object[] args){
//创建对象,以写方式打开数据库
SQLiteDatabase db = getWritableDatabase();
db.execSQL(sql, args);	
}
/**删除数据库中的数据*/
public void delete(String sql,String [] args){
//创建对象,以写方式打开数据库
SQLiteDatabase db=this.getWritableDatabase();
db.execSQL(sql,args);
}
/**更新数据库中的数据*/
public void update(String sql,String [] args){
//创建对象,以写方式打开数据库
SQLiteDatabase db=this.getWritableDatabase();
db.execSQL(sql,args);
}
/**查询数据库中的数据*/
public Cursor query(String sql,String [] args){
SQLiteDatabase db=getWritableDatabase();
return db.rawQuery(sql, args);
}

  

	Button bu1;
	Button bu2;
	Button bu3;
	Button bu4;
	MySQLite ms;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		// TODO Auto-generated method stub
		super.onCreate(savedInstanceState);
		setContentView(R.layout.sql);
		bu1=(Button) findViewById(R.id.bu1);
		bu2=(Button) findViewById(R.id.bu2);
		bu3=(Button) findViewById(R.id.bu3);
		bu4=(Button) findViewById(R.id.bu4);
		ms=new MySQLite(this);
		bu1.setOnClickListener(new OnClickListener() {
			
			@Override
			public void onClick(View v) {
				String sql=
				"insert into person(name,phone,email) values(?,?,?)";
				String [] args=new String []{"zs","123456","1425@qq.com"};
				ms.insert(sql, args);
				Toast.makeText(SQLImpl.this, "保存成功", 3000).show();
			}
		});
		bu2.setOnClickListener(new OnClickListener() {
			
			@Override
			public void onClick(View v) {
				String sql=
					"delete from person where id=?";
					String [] args=new String []{"1"};
					ms.insert(sql, args);
					Toast.makeText(SQLImpl.this, "删除成功", 3000).show();
			}
		});
		bu3.setOnClickListener(new OnClickListener() {
			
			@Override
			public void onClick(View v) {
				String sql=
					"update person set name=?,phone=? where id=1";
					String [] args=new String []{"zs","123456"};
					ms.insert(sql, args);
					Toast.makeText(SQLImpl.this, "更新成功", 3000).show();
			}
		});
		bu4.setOnClickListener(new OnClickListener() {
			
			@Override
			public void onClick(View v) {
				String sql="select * from person where id=?";
				String [] args=new String[]{"2"};
				Cursor cursor=ms.query(sql, args);
				if(cursor.moveToFirst()){
					int idIndex=cursor.getColumnIndex("id");
					String id=cursor.getString(idIndex);
					String name=cursor.getString(
						cursor.getColumnIndex("name"));
					String phone=cursor.getString(
						cursor.getColumnIndex("phone"));
					Toast.makeText(SQLImpl.this, id+name+phone
						, 3000).show();
				}
			}
		});
	}

  

转载于:https://www.cnblogs.com/ch123456/p/6953141.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值