2016.10.13-java利用注解实现数据库持久层仿照Hibernate

需求:有用户表,用户表中有userId,userName,password.sex,score

要求:封装注解,实现查询方法

思路,要实现面向对象的思想下的数据库操作。首先我们应该有一个父类,封装对数据库表的操作。

父类: 所有与数据库表格一 一对应的子类都要集成这个类。来集成到操作数据库的方法。

package Dao;
public class LHObject {
    public static String filter(Object obj) throws Exception{//根据传入的obj,封装查询语句
        return string();
    }
       public static String delete(Object obj) throws Exception{//根据传入的obj,封装删除语句
        return string();
    }
       public static String update(Object obj) throws Exception{//根据传入的obj,封装修改语句
        return string();
    }
       public static String insert(Object obj) throws Exception{//根据传入的obj,封装插入语句
        return string();
    }
}

子类:每个子类实现与一个表的连接和类涨属性与表中某一列的对应

package Dao;
@Table("t_user")//用@Table注解表明与那张表对应
public class User extends LHObject {
    @Colment("user_id")//用@Colment注解来表明属性与表中的那一列对应
    private int userId;
    @Colment("user_naem")
    private String userName;
    @Colment("passwrod")
    private String password;
    @Colment("sex")
    private String sex;
    @Colment("score")
    private float score;
    //省略setter getter方法
    public static void main(String[] args) throws Exception {
        User user = new User();
        user.setUserName("张珊珊");
        user.setScore(88.5f);
        user.setUserId(1);
        System.out.println(User.filter(user)) ;
    }
}

@Table:

package Dao;
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Target({ElementType.TYPE}) //作用于类和接口
@Retention(RetentionPolicy.RUNTIME)//runtime时生效
@Inherited//可以被继承
@Documented//可以生成java doc
public @interface Table {
    String value();
}

@Colment:

package Dao;
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Target({ElementType.FIELD})//作用于属性
@Retention(RetentionPolicy.RUNTIME)
@Inherited
@Documented
public @interface Colment {
    String value();
}

以上完成了基本类的准备工作,以实现父类中filter方法为例:

public class LHObject {
    public static String filter(Object obj) throws Exception{
        StringBuffer sb = new StringBuffer();
        //反射找到类
        Class c = obj.getClass();
        //找打对应的注解,如果有的话
        Annotation[] anns =  c.getAnnotations();
        for (Annotation annotation : anns) {
            if(annotation instanceof  Table){
                sb.append("select * from ").append(((Table) annotation).value());
                sb.append(" where 1=1");//防止没有查询条件时 sql报错
            }
        }
        if(sb.toString()==null || sb.toString().equals("")){
            return null;
        }
        //以上完成的是类与表的联系
        //下面完成添加查询条件
        //获得自定义的属性
        Field[] fields2 = c.getDeclaredFields();
        for (Field field : fields2) {
            //找到对应的表列名 
            Annotation[] fieldAnns = field.getAnnotations();
            for (Annotation annotation : fieldAnns) {
                //如果找到了列名
                if(annotation instanceof Colment){
                    //拼接get方法
                    String getMethodStr = "get"+ field.getName().substring(0, 1).toUpperCase()+field.getName().substring(1);
                    //调用get方法取值
                    Method method = c.getMethod(getMethodStr);
                    Object value = method.invoke(obj);
                    if(field.getType() == String.class){
                        if(value!=null && !value.equals("")){
                            sb.append(" and ").append(((Colment) annotation).value()).append("=").append("'").append(value).append("'");
                        }
                    }else if(field.getType() == int.class){
                        if((int)value!=0 ){
                            sb.append(" and ").append(((Colment) annotation).value()).append("=").append(value);
                        }
                    }else if(field.getType() == float.class){
                        if((float)value!=0.0 ){
                            sb.append(" and ").append(((Colment) annotation).value()).append("=").append(value);
                        }
                    }
                }
            }
        }
        return sb.toString();
    }
}

这样我们就实现了一个select语句的封装。只需要加入jdbc的封装 即可实现返回对象。

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

推荐阅读更多精彩内容