用注解编写创建表的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("\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 。

收获:

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

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

结果:

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

时间: 2024-08-01 08:53:55

用注解编写创建表的SQL语句的相关文章

创建表的sql语句

本文章提供了三款创建表的sql语句实例代码,一一举例测试并说明了如何利用sql创建数据表与数据库教程说明实例. use [master] go if exists(select 1 from sysdatabases where name=n'hktemp') begin drop database hktemp --如果数据库存在先删掉数据库 end go create database hktemp on primary --创建主数据库文件 ( name='hktemp', filenam

使用PL/SQL developer 查看创建一张表的SQL语句

我们在使用PL/SQL developer中想创建一张表的SQL语句,该如何查看呢? 其实很简单的,我们只需要找到该表,然后右键–"DBMS_元数据"-"DDL",如下图:

select-如果某张表存在才去查询这张表,sql语句怎么写啊,一句话可以么

问题描述 如果某张表存在才去查询这张表,sql语句怎么写啊,一句话可以么 SELECT * FROM IF EXISTS A IF EXISTS A SELECT * FROM A 解决方案 可以,这个和数据库有关系,如果是oracle,你可以这样 select 1, decode( (select max(9) from user_tables where table_name='A'), 9, select 1 from A) from table 解决方案二: http://www.cnb

查询语句很复杂-mysql由四张表查出一张新的表,sql语句太复杂,求助!!!!

问题描述 mysql由四张表查出一张新的表,sql语句太复杂,求助!!!! 我要查出学生的学号,班级,姓名,选课题目,指导老师,下面是4张表的结构: 1. 学生信息表(tstudentInfo):ID,class,name 2.老师信息表(tteacherInfo):ID,name 3.课题表(tproject):teacherID ,projectID,projectName 4选课信息表(tchoiceInfo):studentID,firWish,secWish,firState,secT

sql语句 连表查询-连表查询 sql语句问题

问题描述 连表查询 sql语句问题 有个商品表,和商品属性表,一个商品,在商品属性表里有好几条,我想连表查出,一条商品对应的两个属性,两个属性在一行显示,怎么查,属性表的数据是这样 1 商品id 规格 2 商品id 厂家 我想要的结果: 1 商品id 规格 厂家 大能们,帮帮忙 解决方案 查询库中有多少表的SQL语句单表查询树形结构的SQL语句命名查询的sql语句的问题 解决方案二: 你select出来的结果当成colum

sqlserver中操作主从关系表的sql语句

sqlserver中操作主从关系表的sql语句,重点讲解,科目信息传递过后怎么处理.假设从表Tb_StudentSubject 存在StudentId,SubjectId两个字段.那么代码如下: 复制代码 代码如下: Create proc SaveInfo ( ---参数列表不再逐一书写 @subjectList varchar(400)) as begin tran --新增或修改主表 省略 DECLARE @subjectID int, @subjectIDsLen int,--科目长度

基于ORACLE数据库的循环建表及循环创建存储过程的SQL语句实现

一.概述 在实际的软件开发项目中,我们经常会遇到需要创建多个相同类型的数据库表或存储过程的时候.例如,如果按照身份证号码的尾号来分表,那么就需要创建10个用户信息表,尾号相同的用户信息放在同一个表中. 对于类型相同的多个表,我们可以逐个建立,也可以采用循环的方法来建立.与之相对应的,可以用一个存储过程实现对所有表的操作,也可以循环建立存储过程,每个存储过程实现对某个特定表的操作. 本文中,我们建立10个员工信息表,每个表中包含员工工号(8位)和年龄字段,以工号的最后一位来分表.同时,我们建立存储

创建索引对SQL语句执行的影响

一.创建索引对执行计划的影响 在SQL开始执行之前,Oracle会确定SQL语句的执行计划,并按照执行计划的步骤访问相应的表和索引. 一旦执行计划确定下来,Oracle会按照这个执行计划完成SQL语句的执行,在SQL语句执行开始之后建立的索引不会改变SQL语句的执行计划. 因此,创建索引不会对执行计划有任何的影响,也就不会对运行中的SQL语句有影响.下面通过一个例子简单验证一下: SQL> CREATE TABLE TEST (ID NUMBER, FID NUMBER, NAME VARCHA

MySql获取某个字段存在于哪个表的sql语句

本文为大家详细介绍下通过MySql查询某个字段所在表是哪一个,具体的sql语句如下,感兴趣的朋友可以参考下,希望对大家有所帮助   复制代码 代码如下: SELECT TABLE_SCHEMA,TABLE_NAME FROM information_schema.`COLUMNS` WHERE COLUMN_NAME = 'col1' col1为子段名.