Welcome

首页 / 数据库 / SQLServer / 用注解编写创建表的SQL语句

今晚读了think in java 的章节,感觉很不错,我就敲了下来,贴上代码给以后一个回顾: 

建议提前读一下think in java 注解 。 

说明创建注解我在第一个注解说明下,以后的注解不在说明。‘ 
DBTable 注解: 


/*** Project Name:myannotation* File Name:DBTable.java* Package Name:com.iflytek.db* Date:2016-8-28下午08:20:54* Copyright (c) 2016, syzhao@iflytek.com All Rights Reserved.**/package com.iflytek.db;import java.lang.annotation.ElementType;import java.lang.annotation.Retention;import java.lang.annotation.RetentionPolicy;import java.lang.annotation.Target;/**@Target:   @Target说明了Annotation所修饰的对象范围:Annotation可被用于 packages、types(类、接口、枚举、Annotation类型)、类型成员(方法、构造方法、成员变量、枚举值)、方法参数和本地变量(如循环变量、catch参数)。在Annotation类型的声明中使用了target可更加明晰其修饰的目标。  作用:用于描述注解的使用范围(即:被描述的注解可以用在什么地方)  取值(ElementType)有:    1.CONSTRUCTOR:用于描述构造器    2.FIELD:用于描述域    3.LOCAL_VARIABLE:用于描述局部变量    4.METHOD:用于描述方法    5.PACKAGE:用于描述包    6.PARAMETER:用于描述参数    7.TYPE:用于描述类、接口(包括注解类型) 或enum声明 @Retention:  @Retention定义了该Annotation被保留的时间长短:某些Annotation仅出现在源代码中,而被编译器丢弃;而另一些却被编译在class文件中;编译在class文件中的Annotation可能会被虚拟机忽略,而另一些在class被装载时将被读取(请注意并不影响class的执行,因为Annotation与class在使用上是被分离的)。使用这个meta-Annotation可以对 Annotation的“生命周期”限制。  作用:表示需要在什么级别保存该注释信息,用于描述注解的生命周期(即:被描述的注解在什么范围内有效)  取值(RetentionPoicy)有:    1.SOURCE:在源文件中有效(即源文件保留)    2.CLASS:在class文件中有效(即class保留)    3.RUNTIME:在运行时有效(即运行时保留)  Retention meta-annotation类型有唯一的value作为成员,它的取值来自java.lang.annotation.RetentionPolicy的枚举类型值 */@Target(ElementType.TYPE)@Retention(RetentionPolicy.RUNTIME)public @interface DBTable{public String name() default "";}
Constraints 约束注解: 

/*** Project Name:myannotation* File Name:Constraints.java* Package Name:com.iflytek.db* Date:2016-8-28下午08:27:08* Copyright (c) 2016, syzhao@iflytek.com All Rights Reserved.**/package com.iflytek.db;import java.lang.annotation.ElementType;import java.lang.annotation.Retention;import java.lang.annotation.RetentionPolicy;import java.lang.annotation.Target;@Target(ElementType.FIELD)@Retention(RetentionPolicy.RUNTIME)public @interface Constraints{boolean primaryKey() default false;boolean allowNull() default true;boolean unique() default false;}
 SQLInteger int注解: 

/*** Project Name:myannotation* File Name:SQLInteger.java* Package Name:com.iflytek.db* Date:2016-8-29下午10:24:11* Copyright (c) 2016, syzhao@iflytek.com All Rights Reserved.**/package com.iflytek.db;import java.lang.annotation.ElementType;import java.lang.annotation.Retention;import java.lang.annotation.RetentionPolicy;import java.lang.annotation.Target;@Target(ElementType.FIELD)@Retention(RetentionPolicy.RUNTIME)public @interface SQLInteger{String name() default "";Constraints constraints() default @Constraints;}
 SQLString 字符注解: 
/*** Project Name:myannotation* File Name:SQLString.java* Package Name:com.iflytek.db* Date:2016-8-29下午10:28:04* Copyright (c) 2016, syzhao@iflytek.com All Rights Reserved.**/package com.iflytek.db;import java.lang.annotation.ElementType;import java.lang.annotation.Retention;import java.lang.annotation.RetentionPolicy;import java.lang.annotation.Target;@Target(ElementType.FIELD)@Retention(RetentionPolicy.RUNTIME)public @interface SQLString{int value() default 0;String name() default "";Constraints constraints() default @Constraints;}
 创建表的处理器:

/*** Project Name:myannotation* File Name:TableCreator.java* Package Name:com.iflytek.table* Date:2016-8-29下午10:57:52* Copyright (c) 2016, syzhao@iflytek.com All Rights Reserved.**/package com.iflytek.table;import java.lang.annotation.Annotation;import java.lang.reflect.Field;import java.util.ArrayList;import java.util.List;import com.iflytek.db.Constraints;import com.iflytek.db.DBTable;import com.iflytek.db.SQLInteger;import com.iflytek.db.SQLString;public class TableCreator{public static void main(String[] args){createTable(Member.class);}//创建表SQL语句private static void createTable(Class<?> cl){//获取DBTable注解DBTable dbTable = cl.getAnnotation(DBTable.class);//判断DBTable注解是否存在if (dbTable == null){System.out.println("没有找到关于DBTable");return;}//如果@DBTable注解存在获取表明 String tableName = dbTable.name();//判断表名是否存在if (tableName.length() < 1){//不存在,说明默认就是类名,通过 cl.getSimpleName()获取类名并且大写tableName = cl.getSimpleName().toUpperCase();}//定义获取column的容器List<String> columnDefs = new ArrayList<String>();//循环属性字段//说明:getDeclaredFields()获得某个类的所有申明的字段,即包括public、private和proteced,但是不包括父类的申明字段。 //getFields()获得某个类的所有的公共(public)的字段,包括父类。 for (Field field : cl.getDeclaredFields()){//定义表字段名称变量String columnName = null;//获取字段上的注解(现在字段允许多个注解,因此返回的是数组)Annotation[] anns = field.getDeclaredAnnotations();//判断属性是否存在注解if (anns.length < 1)continue;//判断是否是我们定义的数据类型if (anns[0] instanceof SQLInteger){//获取SQLInteger 注解SQLInteger sInt = (SQLInteger)anns[0];//判断是否注解的name是否有值if (sInt.name().length() < 1){//如果没有值,说明是类的属性字段,获取属性并转换大写columnName = field.getName().toUpperCase();}else{ //如果有值,获取设置的name值columnName = sInt.name();}//放到属性的容器内columnDefs.add(columnName + " INT " + getConstraints(sInt.constraints()));}//同上SQLInteger,这里不写注释了if (anns[0] instanceof SQLString){SQLString sString = (SQLString)anns[0];if (sString.name().length() < 1){columnName = field.getName().toUpperCase();}else{columnName = sString.name();}columnDefs.add(columnName + " VARCHAR(" + sString.value() + ")" + getConstraints(sString.constraints()));}//定义生成创建表的SQL语句StringBuilder createCommand = new StringBuilder("CREATE TABLE " + tableName + "(");//循环上面属性容器,for (String columnDef : columnDefs){//把属性添加到sql语句中createCommand.append("
" + columnDef + ",");//去掉最后一个逗号String tableCreate = createCommand.substring(0, createCommand.length() - 1) + ");";//打印System.out.println("Table creation SQL for " + cl.getName() + " is :
" + tableCreate);}}}private static String getConstraints(Constraints con){String constraints = "";//判断是否为nullif (!con.allowNull()){constraints += " NOT NULL ";}//判断是否是主键if (con.primaryKey()){constraints += " PRIMARY KEY ";}//是否唯一if (con.unique()){constraints += " UNIQUE ";}return constraints;}}
以上代码拷贝出来,就可以运行了! 

上面虽然是简单的创建表语句,但我们可以蔓延到hibernate的domain类里的注解,各种CURD ,何尝不是这样处理的呢,只是hibernate有很多东西,但是万变不离其宗,以后有机会研究一下hibernate 。 

收获: 

读了以后,对于注解知道为什么要这么用了,其实顾名思义就是一个注解,只是有一个处理器来处理这个注解,这对我以后用到注解方面应该有帮助的, 

时间不早了,就写到这里!

结果:


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。