二:03:AHibernate简介(二)

首先声明,很多东西是来自AHibernate框架作者博客中,因为每个人都有自己的浏览喜好,对自己规整了一下文本内容,自己以后看着稍微舒服点,在这还要感谢AHibernate框架作者给我们一个那么优秀的框架。

 

本篇主要是怎么使用该框架

public class MainActivity extends Activity {
	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
 
		// 熟悉用接口的朋友注意哦,这里也可以定义为接口哦,见StudentDaoImpl.java中的注释.
		TeacherDaoImpl teacherDao = new TeacherDaoImpl(MainActivity.this);
		StudentDaoImpl studentDao = new StudentDaoImpl(MainActivity.this);
 
		// 添加
		Teacher teacher = new Teacher();
		teacher.setName("米老师");
		teacher.setAge(50);
		teacher.setTitle("教授");
		Long teacherId = teacherDao.insert(teacher);
 
		Student student1 = new Student();
		student1.setName("lk");
		student1.setAge(26);
		student1.setClasses("五");
		student1.setTeacherId(teacherId.intValue());
		Long studentId1 = studentDao.insert(student1);
 
		Student student2 = new Student();
		student2.setName("cls");
		student2.setAge(26);
		student2.setClasses("五");
		student2.setTeacherId(teacherId.intValue());
		Long studentId2 = studentDao.insert(student2);
 
		Student student3 = new Student();
		student3.setName("lb");
		student3.setAge(27);
		student3.setClasses("五期");
		student3.setTeacherId(teacherId.intValue());
		Long studentId3 = studentDao.insert(student3);
 
		Student student4 = new Student();
		student4.setId(1111);
		student4.setName("李坤");
		student4.setAge(26);
		student4.setClasses("五期提高班");
		student4.setTeacherId(teacherId.intValue());
		// 上面的示例中insert(entity)方法Id会自增.
		// 使用insert(entity,false)这样方式可以插入有固定Id的数据.
		Long studentId4 = studentDao.insert(student4, false);
		System.out.println("插入数据时可以不让主键自增,插入指定Id的数据值为=====" + studentId4);
		// 查询
		// 方式1:根据Id查询单个对象
		// 结果:student1Student [id=1, name=lk,age=26,teacherId=1, classes=五]
		Student student5 = studentDao.get(studentId1.intValue());
		System.out.println("student4" + student5);
 
		// 方式2:查询出表中的所有记录
		// 执行结果如下:
		// list1:Student [id=1, name=lk,age=26,teacherId=1, classes=五]
		// list1:Student [id=2, name=cls,age=26,teacherId=1, classes=五]
		// list1:Student [id=3, name=lb,age=27,teacherId=1, classes=五期]
		List<Student> list1 = studentDao.find();
		for (Student student : list1) {
			System.out.println("list1:" + student);
		}
 
		// 方式3:限制条件查询和查询结果
		// 执行结果:list2:Student [id=2, name=cls,age=0,teacherId=0, classes=null]
		List<Student> list2 = studentDao.find(new String[] { "id", "name" },
				" id = ? ", new String[] { studentId2.toString() }, null, null,
				null, null);
		for (Student student : list2) {
			System.out.println("list2:" + student);
		}
 
		// 方式4:使用sql查询出结果,此种方式是2,3,4中最灵活的.
		// 执行结果:
		// list3:Student [id=2, name=cls,age=26,teacherId=1, classes=五]
		// list3:Student [id=3, name=lb,age=27,teacherId=1, classes=五期]
		List<Student> list3 = studentDao.rawQuery(
				"select * from t_student where id in (?,?) ", new String[] {
						studentId2.toString(), studentId3.toString() });
		for (Student student : list3) {
			System.out.println("list3:" + student);
		}
		// 方式4:使用模糊查询.
		List<Student> list = studentDao.rawQuery(
				"select * from t_student t where t.classes like ?",
				new String[] { "%五%" });
		System.out.println(list.size());
 
		// 方式4进阶:如果想查询出米老师的学生,可以这样实现:
		// 执行结果:
		// list4:Student [id=1, name=lk,age=26,teacherId=1, classes=五]
		// list4:Student [id=2, name=cls,age=26,teacherId=1, classes=五]
		// list4:Student [id=3, name=lb,age=27,teacherId=1, classes=五期]
		List<Student> list4 = studentDao
				.rawQuery(
						"select s.* from t_student s join t_teacher t on s.teacher_id = t.id where t.name= ? ",
						new String[] { "米老师" });
		for (Student student : list4) {
			System.out.println("list4:" + student);
		}
 
		// 方式5:我只想知道姓名和年龄,查询得到List<Map<String,String>>形式.只查2个字会比查询所有字段并封装为对象效率高吧,尤其字段值很多时我们的手机更喜欢这种方式哦.
		// 结果:
		// listMap1: name:lk;age:26
		// listMap1: name:cls;age:26
		// listMap1: name:lb;age:27
		List<Map<String, String>> listMap1 = studentDao.query2MapList(
				"select name,Age from t_student ", null);
		for (Map<String, String> map : listMap1) {
			// 查询的List中的map以查询sql中的属性值的小写形式为key,注意是小写形式哦.
			System.out.println("listMap1: name:" + map.get("name") + ";age:"
					+ map.get("age"));
		}
 
		// 方式5进阶:我想知道前2名学生的姓名和班主任姓名,这种方式是不是超灵活啊,用其他的方式查询都没这种方式好用吧,哈哈.
		// 结果:
		// listMap2: student_name:lk;teacher_name:米老师
		// listMap2: student_name:cls;teacher_name:米老师
		List<Map<String, String>> listMap2 = studentDao
				.query2MapList(
						"select s.name sname,t.name tname from t_student s join t_teacher t on s.teacher_id = t.id limit ? ",
						new String[] { "2" });
		for (Map<String, String> map : listMap2) {
			System.out.println("listMap2: student_name:" + map.get("sname")
					+ ";teacher_name:" + map.get("tname"));
		}
 
		// 更新
		// 结果: Student [id=1, name=李坤,age=26,teacherId=1, classes=五期]
		student1 = studentDao.get(studentId1.intValue());
		student1.setName("李坤");
		student1.setClasses("五期");
		studentDao.update(student1);
		System.out.println(student1);
 
		// 删除:支持单个id删除,也支持多个id同时删除哦.
		studentDao.delete(studentId1.intValue());
		studentDao.delete(new Integer[] { studentId2.intValue(),
				studentId3.intValue() });
		studentDao.delete(1111);
 
		// 支持执行sql语句哦.
		teacherDao.execSql("insert into t_teacher(name,age) values('米教授',50)",
				null);
 
	}

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值