十三、注解(高琪java300集+java从入门到精通笔记)

博客介绍了Java注解相关知识,包括什么是注解、内置注解、自定义注解和元注解。通过代码示例展示了使用反射读取注解信息的流程,还说明了如何根据获得的表名、字段信息拼出DDL语句,利用JDBC在数据库中生成相关表。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

注解(Annotation)

什么是注解:

在这里插入图片描述
内置注解:

在这里插入图片描述
在这里插入图片描述

自定义注解:

在这里插入图片描述

元注解:

在这里插入图片描述

其中:@Target

在这里插入图片描述

@Retention

在这里插入图片描述

SOURCE反射读不到

RUNTIME运行时加载Annotation到JVM

在这里插入图片描述

* 使用反射读取注解的信息,模拟处理注解信息的流程

*/

public class Demo03 {

public static void main(String[] args) {

try {

Class clazz = Class.forName(“com.bjsxt.test.annotation.SxtStudent”);

@SxtTable(“tb_student”)//

@Target(value={ElementType.TYPE})//类

@Retention(RetentionPolicy.RUNTIME)

public @interface SxtTable {

String value();

}

public class SxtStudent {

@SxtField(columnName=“id”,type=“int”,length=10)//

@Target(value={ElementType.FIELD})

@Retention(RetentionPolicy.RUNTIME)

public @interface SxtField {

String columnName();//id

String type();//int

int length();//10

}

private int id;

@SxtField(columnName=“sname”,type=“varchar”,length=10)

private String studentName;

@SxtField(columnName=“age”,type=“int”,length=3)

private int age;

public int getId() {

return id;

}

public void setId(int id) {

this.id = id;

}

public String getStudentName() {

return studentName;

}

public void setStudentName(String studentName) {

this.studentName = studentName;

}

public int getAge() {

return age;

}

public void setAge(int age) {

this.age = age;

}

}

//获得类的所有有效注解

Annotation[] annotations=clazz.getAnnotations();

for (Annotation a : annotations) {

System.out.println(a);//@com.bjsxt.test.annotation.SxtTable(value=“tb_student”)

}

//获得类的指定的注解

SxtTable st = (SxtTable) clazz.getAnnotation(SxtTable.class);

System.out.println(st.value());//tb_student

//获得类的属性的注解

Field f = clazz.getDeclaredField(“studentName”);

SxtField sxtField = f.getAnnotation(SxtField.class);

System.out.println(sxtField.columnName()+"–"+sxtField.type()+"–"+sxtField.length());//sname–varchar–10

//根据获得的表名、字段的信息,拼出DDL语句,然后,使用JDBC执行这个SQL,在数据库中生成相关的表

} catch (Exception e) {

e.printStackTrace();

}

}

}
th());//sname–varchar–10

//根据获得的表名、字段的信息,拼出DDL语句,然后,使用JDBC执行这个SQL,在数据库中生成相关的表

} catch (Exception e) {

e.printStackTrace();

}

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值