创建表的SQL语句是什么,涉及哪些知识点
Admin 2022-07-15 群英技术资讯 698 次浏览
今天这篇我们来学习和了解“创建表的SQL语句是什么,涉及哪些知识点”,下文的讲解详细,步骤过程清晰,对大家进一步学习和理解“创建表的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 。
收获:
读了以后,对于注解知道为什么要这么用了,其实顾名思义就是一个注解,只是有一个处理器来处理这个注解,这对我以后用到注解方面应该有帮助的,
时间不早了,就写到这里!
结果:

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在数据查询中,从2008开始SQLServer提供了一个新的数据类型hierarchyid,专门用来操作层次型数据结构。hierarchyid 类型对层次结构树中有关单个节点的信息进行逻...
今天用time Like '2008-06-01%'语句来查询该天的所有数据,被提示语句错误。查了一下才发现该模糊查询只能用于String类型的字段。 自己也查阅了一些资料。关于时间的模糊查询有以下三种方法: 1.Convert转成Stri
这篇文章主要介绍了SqlServer编写数据库表的操作方式(建库、建表、修改语句)的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
SQL ALTER TABLE 语句用于在现有表中添加、删除或修改列。有不少朋友对此感兴趣,下面小编给大家整理和分享了相关知识和资料,易于大家学习和理解,有需要的朋友可以借鉴参考,下面我们一起来了解一下吧。
文本给大家分享的是关于sqlserver日志传送的内容,主要介绍sqlserver日志传送的概念、优点、方法等等,具有一定的参考价值,感兴趣的朋友就跟随小编一起看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008