xUtils系列之DbUtils-开启Sqlite3外键约束

实际使用中发现,Android Sqlite3数据库的外键约束不起作用,

查了一些资料发现:

SQLite在3.6.19版本中开始支持外键约束,但是为了兼容以前的程序,默认并没有启用该功能,如果要启用该功能 需要使用如下语句:
PRAGMA foreign_keys = ON 
在Android中 2.1以前的版本使用的SQLite版本是3.5.9, 在2.2版本中使用的是3.6.22.


如果需要在DbUtils中打开外键约束,需要执行如下操作:

@Override
protected void onCreate(Bundle savedInstanceState) {
	super.onCreate(savedInstanceState);
	ViewUtils.inject(this);
	DbUtils db=DbUtils.create(this);
	db.configAllowTransaction(true);
	db.configDebug(true);
	
	try {
		db.execNonQuery("PRAGMA foreign_keys=ON;");
	} catch (DbException e) {
		// TODO Auto-generated catch block
		e.printStackTrace();
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值