• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    用注解编写创建表的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的容器
        ListString> columnDefs = new ArrayListString>();
        //循环属性字段
        //说明: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("\n  " + columnDef + ",");
            //去掉最后一个逗号
            String tableCreate = createCommand.substring(0, createCommand.length() - 1) + ");";
            //打印
            System.out.println("Table creation SQL for " + cl.getName() + " is :\n" + tableCreate);
          }
        }
      }
      
      private static String getConstraints(Constraints con)
      {
        String constraints = "";
        //判断是否为null
        if (!con.allowNull())
        {
          constraints += " NOT NULL ";
        }
        //判断是否是主键
        if (con.primaryKey())
        {
          constraints += " PRIMARY KEY ";
        }
        //是否唯一
        if (con.unique())
        {
          constraints += " UNIQUE ";
        }
        
        return constraints;
      }
    }
    
    

    以上代码拷贝出来,就可以运行了! 

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

    收获: 

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

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

    结果:

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

    您可能感兴趣的文章:
    • Java 中的注解详解及示例代码
    • Android 中的注解深入探究
    • 深入分析安卓(Android)中的注解
    • Spring学习笔记1之IOC详解尽量使用注解以及java代码
    • Spring MVC 注解自动扫描失效原因分析
    • 深入浅析Java注解框架
    • 全面解析Java中的注解与注释
    • 详解Java注解教程及自定义注解
    • 小议Java中@param注解与@see注解的作用
    • Android 中的注解详细介绍
    上一篇:SqlServer查询和Kill进程死锁的语句
    下一篇:SQL Server成功与服务器建立连接但是在登录过程中发生错误的快速解决方案
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    用注解编写创建表的SQL语句 用,注解,编写,创建,表,的,