实体类的使用

1. 实体类的定义

实体类是smartdao用来和数据库表做一一映射关系的类,一张表对应一个实体类。下面就是要给实体类的示例

@Entity
@Table(name="rule_condition")
public class Condition{

    @Id
    @AutoIncrease
    private Long id;
    
    // 默认情况smartdao开启了下划线转驼峰的功能,所以如果实体类字段正好是转驼峰后的结果,就不用加@Column注解。可以通过实现MyBatisConfigManager接口的方式关闭下划线转驼峰的功能。
    @Column(name="count_rule_id")
    private Long countRuleId;
    
    private Operator oper;
    
    private String field;
    
    private String patten;
    
    //getter and setters
}

这里我们看到有很多个注解,依次解释一下:

注解 说明
@Entity 必须有的注解,加在类上面,标注这个类是一个实体类,否则在保存数据时会报错
@Table 用来表面实体类对应的数据库表的表名,通过name属性设置,如果实体类没有@Table注解,默认对应的数据库表名和实体类名相同
@Id 用户标注一个字段是表的主键字段,每个实体类必须有且只有一个@Id注解的字段
@AutoIncrease 表示Id的产生方式是数据库自增,如果不是数据库自增,而是业务系统赋值,那么不需要加该注解,如果使用数据库的序列产生id,需要加@Sequence注解,Sequence的name属性为序列名称
@Column 标识实体类的字段对应数据库字段名称,通过name属性设置。如果不加该注解,则默认对应的数据库表字段名称和实体类字段的名称一样(注:由于smartdao默认开启了下划线转驼峰的功能,所以如果数据库字段有下划线的,且实体类的字段名也符合转驼峰后的写法,那么Column注解可以不用。并且推荐不写,以免引起误解)

2. 实体类支持的字段类型

目前支持的字段类型有 Integer , Long , Float ,Double , Boolean (对应数据库 bit), Date,String,枚举。上例中的字段类型Operator就是一个枚举类型。需要注意的是,类型必须是装箱类型不能是int,long,float等,否则会报错的哦。

3. transient 关键字

实体有时需要实现Serializable接口,这时实体类中会多一个字段

  private static final long serialVersionUID = 9031528552445081773L;

这时如果保存实体类数据,会报错说serialVersionUID没有对应的数据库表字段,显然这个问题需要解决,serialVersionUID其实是不需要保存到数据库的,对于这类字段,smartdao通过transient关键字来实现

private static final transient long serialVersionUID = 9031528552445081773L;

由此,即可完美的解决这个问题,在实际的使用过程中,要注意合理妙用transient关键字哦。

4. 实体类的继承

在实际项目过程中,我们会遇到这样的场景:没张表都有一个必要的字段如addtime,last_modify_time,delete_flag,modify_uid等。这样我们的每个实体类中都需要有这些公共的字段,为了方便我们会将公共字段抽取到父类中。smartdao是支持这样使用的方式的。

@Entity
@Table(name="rule_condition")
public class Condition extends BaseEntity{

    @Id
    @AutoIncrease
    private Long id;
    
    @Column(name="count_rule_id")
    private Long countRuleId;
    
    private Operator oper;
    
    private String field;
    
    private String patten;
}
public class BaseEntity {

    private Date addtime;
    
    @Column(name="delete_flag")
    private Integer deleteFlag;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,875评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,569评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,475评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,459评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,537评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,563评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,580评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,326评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,773评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,086评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,252评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,921评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,566评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,190评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,435评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,129评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,125评论 2 352

推荐阅读更多精彩内容

  • rljs by sennchi Timeline of History Part One The Cognitiv...
    sennchi阅读 7,319评论 0 10
  • The Inner Game of Tennis W Timothy Gallwey Jonathan Cape ...
    网事_79a3阅读 12,008评论 3 20
  • 那年夏天的一个夜晚,我跟老婆为了屁大一点事,闹了点小别扭。 “滚出去!”她扬言要“清理床户。”无奈,好男不跟女斗,...
    天涯佳音阅读 267评论 1 3
  • 1、什么时间段健身最好?有人说早上空腹锻炼,可以让一整天都精神充沛,还可以减脂;有些人说中午到19点是人体体温最高...
    好听的暖阳阅读 137评论 2 4
  • 这一段时间,发生了太多的事情。家里,工作里,都有不如愿的事情发生。 想想人到中年,真是有压力!加上很多的不可预知随...
    箜溪晓阅读 351评论 2 5