微型 ORM 框架

本文介绍了一个微型ORM框架的实现方法,通过Java的反射和注解技术,将实体类映射为数据库建表语句,无需直接操作数据库,只需关注代码中的实体类。文章详细阐述了思路,并提供了相关注解的定义,如类注解、字段注解等,最终展示了如何将这些注解转换为相应的SQL创建语句。
摘要由CSDN通过智能技术生成

微型 ORM 框架

要求

使用反射和注解实现一个微型的 ORM 框架,不用操作数据库,只需要将代码中的实体类映射为数据库建表语句即可(也就是通过代码生成 SQL 语句)。

思路

  1. 类注解 → CREATE TABLE USER

  2. 字段注解:

    username 、password 、createtime → username 、password 、createtime。

  3. 属性注解

    int → INT(4)

    String → VARCHAR(32)

    Date → TIMESTAMP

  4. 使用 JavaToSQL ,运行后将映射完成。

  5. JavaToSQL 中,使用反射技术获取类的注解,在哪种注解下就执行哪种映射转换。

解答

直接上代码

  1. 表头注解

package com.xxm.advanced_camp.great_mission2_orc;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * @author xxm
 * 表头注解
 */

@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)

public @interface Table {
   
    String tableName() default "";
}
  1. 表格注解

package com.xxm.advanced_camp.great_mission2_orc;


import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * @author xxm
 * 表格注解
 */
@Target({
   ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
public @interface TableColumn {
   
    String name() default "空";

    //表格内容的类型
    ColumnType columnType() default @ColumnType;

    //表格内容的文字
    ColumnName columnName() default @ColumnName;

    //表格内转化成SQL语句后的长度
    ColumnSize columnSize() default @ColumnSize;

    //是否可以为 NULL
    NotNull nullAllowed() default @NotNull;

    //是否自增
    AutoIncrement autoIncrement() default @AutoIncrement;

    //是否为主键
    PrimaryKey primaryKey() default @PrimaryKey;

    //是否有其它注释
    OtherNotes otherNotes() default @OtherNotes;

}

  1. 表格数据类型的枚举类

package com.xxm.advanced_camp.great_mission2_orc;

import java.util.Date;

public enum Type {
   
    INTEGER,STRING,DATE;
}

  1. 表格数据类型注解

package com.xxm.advanced_camp.great_mission2_orc;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值