xUtils系列之DbUtils-查询

其实DbUtils的代码已经很清楚了,所以举个例子 来描述具体用法.

首先,建立一个实体类Person:

package com.example.entities;

import com.lidroid.xutils.db.annotation.Column;
import com.lidroid.xutils.db.annotation.Table;

@Table(name="person")
public class Person {
	private int id;
	
	@Column(column="name")
	private String name;
	
	@Column(column="hobby")
	private String hobby;

	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 String getHobby() {
		return hobby;
	}

	public void setHobby(String hobby) {
		this.hobby = hobby;
	}
	
	@Override
	public String toString()
	{
		return "[id="+id+" name="+name+" hobby="+hobby+"]";
	}
	
}

新建一个MainActivity类,在onCreate函数里面可以这样用:

@Override
protected void onCreate(Bundle savedInstanceState){
	super.onCreate(savedInstanceState);
	ViewUtils.inject(this);
	initWebView();
	
	DbUtils db = DbUtils.create(this);
	try {
		db.dropTable(Person.class);
	} catch (DbException e1) {
		// TODO Auto-generated catch block
		e1.printStackTrace();
	}
	
	String[] names={"zhao","qian","sun","li","zhou","wu","zhen","wang"};
	String[] hobbys={"pingpong","pingpong","pingpong","football","football","basketball","basketball","basketball"};
	
	List<Person> list = new ArrayList<Person>();
	for(int i=0;i<8;++i)
	{
		Person p = new Person();
		p.setName(names[i]);
		p.setHobby(hobbys[i]);
		list.add(p);
	}
	
	try {
		db.saveAll(list);
		
		db.findAll(Child.class);
		db.findAll(Selector.from(Child.class).where("id", ">", 2));
		db.findById(Child.class, 1);
		db.findFirst(Child.class);
		db.findFirst(Selector.from(Child.class).where("id", ">", 2));
		
		db.findDbModelAll(DbModelSelector.from(Child.class).groupBy("hobby").having(WhereBuilder.b("id", ">", 2)));
		db.findDbModelFirst(DbModelSelector.from(Child.class).groupBy("hobby").having(WhereBuilder.b("id", ">", 2)));
		
		
		
		Cursor c = db.execQuery(new SqlInfo("select * from child;"));
		
		//findDbModelFirst和findDbModelAll相当是对execQuery做了再次封装,
		//返回的DbModel中,封装了通过列名获取value的方法,如:String getString(String columnName)等等.
		DbModel model = db.findDbModelFirst(new SqlInfo("select * from child;")); //采取原生sql语句,可以做多表查询操作
		List<DbModel> modellist = db.findDbModelAll(new SqlInfo("select * from child;"));

	} catch (DbException e) {
		// TODO Auto-generated catch block
		e.printStackTrace();
	}
	
}


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值