重复插入 解决办法:
1. 因为ContentProvider 所拥有的函数接口 比如:insert delete update onCreate 都已经固定 不支持自定义 所以我打算以patch的形式
2. 函数原型
public class ResolverUtility { /* - insertUnique * - arguments: * * cr : ContentResolver instance to use * * uri : target w/ Uri format to insert * * cv : ContentValues to insert * * uid : unique column to replace * * - return:null */ public static void insertUnique(ContentResolver cr, Uri uri, ContentValues cv, String uid){ String scase = (String)cv.get(uid); String selection = "name = '"+scase+"'"; Cursor c = cr.query(uri, null, selection, null, null); if(c.getCount() > 0){ cr.update(uri, cv, selection, null); } else { cr.insert(uri, cv); } } }
2. 原理:
其实 原理很简单 即: 在新插入数据之前 先查询指定列的值 并以之为条件 查询是否存在 该数据 如果存在 则调用update() 方法更新目标 如果不存在 则调用insert()方法插入之
3. 如何使用:
ContentValues uvalues = new ContentValues(); uvalues.put(CHelper.NAME, "griffinshi"); uvalues.put(CHelper.NUMBER, 7686); uvalues.put(CHelper.HOME, "Jiangsu"); ResolverUtility.insertUnique(cResolver, CHelper.CONTENT_URI, uvalues, CHelper.NAME);
结束!
ListView在CHOICE_MODE_MULTIPLE下实现多选和删除, 要注意ListView的getCheckItemIds()方法,在删除前调用
long[] id = list.getCheckItemIds(),发现如果你之前点选某个item再取消,此item的id还是在数组id中,不知道为什么这样~ 所以只能这样实现了
for (int i=0;i<list.getCount();i++)
{
if (list.isItemChecked(i)){
cursor.moveToPosition(i);
int id = cursor.getInt(0);
db.delete("_id="+id, null);
}
}
这个很久之前搞的,具体我都忘了。。。 long[] id = list.getCheckItemIds(),应该可以吧
今天突然想起这个问题 然后试了一下其实也不难
public class UpsideDownText extends TextView {
@Override
protected void onDraw(Canvas canvas) {
// TODO Auto-generated method stub
canvas.save();
float py = this.getHeight()/2.0f;
float px = this.getWidth()/2.0f;
canvas.rotate(180, px, py);
super.onDraw(canvas);
canvas.restore();
}
public UpsideDownText(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
// TODO Auto-generated constructor stub
}
public UpsideDownText(Context context, AttributeSet attrs) {
super(context, attrs);
// TODO Auto-generated constructor stub
}
public UpsideDownText(Context context) {
super(context);
// TODO Auto-generated constructor stub
}
}