zoukankan      html  css  js  c++  java
  • Android ORMapping库

    自己用Java的注解实现了Android SQLite的ORM库,之前写过XML的,不过感觉不是很稳定,效率、鲁棒性各方面都不太好,今天花了一下午的时间,补全了所有的注解、注释,生成了javadoc,写了样例程序,并发布到了Github上,地址是:https://github.com/Steven-Luo/AnnotationDao,感兴趣的可以试着用用,比之前纯手动实现SQLite数据库的操作简单了许多,可扩展性也较好,用法如下:

     1 //实体类
     2 @Table(name = "dog")
     3 public class Dog {
     4     private boolean alive;
     5     private int id;
     6     private String name;
     7 
     8     public Dog() {
     9 
    10     }
    11 
    12     public Dog(boolean alive, String name) {
    13         this.alive = alive;
    14         this.name = name;
    15     }
    16 
    17     @Id(name = "id")
    18     @Column(name = "id", type = DataType.Integer)
    19     public int getId() {
    20         return id;
    21     }
    22 
    23     @Column(name = "name", type = DataType.Varchar, length = 20)
    24     public String getName() {
    25         return name;
    26     }
    27 
    28     @Column(name = "alive", type = DataType.Boolean)
    29     public boolean isAlive() {
    30         return alive;
    31     }
    32 
    33     public void setAlive(boolean alive) {
    34         this.alive = alive;
    35     }
    36 
    37     public void setId(int id) {
    38         this.id = id;
    39     }
    40 
    41     public void setName(String name) {
    42         this.name = name;
    43     }
    44 }
    45 
    46 //添加
    47 AnnotationDao dao = new AnnotationDao(this, Dog.class);
    48 
    49 String name = "dog1";
    50 boolean alive = true;
    51 
    52 Dog dog = new Dog(alive, name);
    53 dao.insert(dog);
    54 
    55 //查找
    56 //列出所有对象
    57 List list = dao.list();
    58 //根据ID查询
    59 dao.query(3);
    60 
    61 //删除
    62 dao.delete(dog);
    63 
    64 //更新,更新时需要保证id字段跟数据库中的值是对应的,也就是之前调用list或query取出来的
    65 dog.setName("dog2");
    66 dao.update(dog);

    这几天做一个项目,其中需要画一些曲线,虽然AChartEngine已经很好用了,但有几个图感觉还不太合意,最后决定自己画一个。其实主要是因为看了多看阅读上面的阅读时间曲线,觉得画得不错,所以我也就创新了一下,或者说山寨了一下,哈哈,效果如下图所示:

    等改天把注释写好了,也放到GitHub上去,好东西,大家要一起分享^_^

  • 相关阅读:
    poj2823单调队列认知
    有关二叉树的三序遍历的题目
    hdu4757 可持续字典树
    ZOJ2532判断边是否是割集中的边
    poj2455 k条路最小化最长边
    乘法逆元模板
    poj1699 KMP+壮压DP
    Innodb存储引擎——非聚集索引
    java集合框架笔记
    jvm垃圾回收
  • 原文地址:https://www.cnblogs.com/stevenluo/p/3873748.html
Copyright © 2011-2022 走看看