亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

用注解編寫創(chuàng)建表的SQL語句

2024-08-31 01:04:08
字體:
供稿:網(wǎng)友

今晚讀了think in java 的章節(jié),感覺很不錯(cuò),我就敲了下來,貼上代碼給以后一個(gè)回顧: 

建議提前讀一下think in java 注解 。 

說明創(chuàng)建注解我在第一個(gè)注解說明下,以后的注解不在說明。‘ 

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所修飾的對(duì)象范圍:Annotation可被用于 packages、types(類、接口、枚舉、Annotation類型)、類型成員(方法、構(gòu)造方法、成員變量、枚舉值)、方法參數(shù)和本地變量(如循環(huán)變量、catch參數(shù))。在Annotation類型的聲明中使用了target可更加明晰其修飾的目標(biāo)?! ∽饔茫河糜诿枋鲎⒔獾氖褂梅秶矗罕幻枋龅淖⒔饪梢杂迷谑裁吹胤剑 ∪≈?ElementType)有:    1.CONSTRUCTOR:用于描述構(gòu)造器    2.FIELD:用于描述域    3.LOCAL_VARIABLE:用于描述局部變量    4.METHOD:用于描述方法    5.PACKAGE:用于描述包    6.PARAMETER:用于描述參數(shù)    7.TYPE:用于描述類、接口(包括注解類型) 或enum聲明 @Retention:  @Retention定義了該Annotation被保留的時(shí)間長短:某些Annotation僅出現(xiàn)在源代碼中,而被編譯器丟棄;而另一些卻被編譯在class文件中;編譯在class文件中的Annotation可能會(huì)被虛擬機(jī)忽略,而另一些在class被裝載時(shí)將被讀?。ㄕ?qǐng)注意并不影響class的執(zhí)行,因?yàn)锳nnotation與class在使用上是被分離的)。使用這個(gè)meta-Annotation可以對(duì) Annotation的“生命周期”限制?! ∽饔茫罕硎拘枰谑裁醇?jí)別保存該注釋信息,用于描述注解的生命周期(即:被描述的注解在什么范圍內(nèi)有效)  取值(RetentionPoicy)有:    1.SOURCE:在源文件中有效(即源文件保留)    2.CLASS:在class文件中有效(即class保留)    3.RUNTIME:在運(yùn)行時(shí)有效(即運(yùn)行時(shí)保留)  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;}

 創(chuàng)建表的處理器:

 

/*** 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);  }    //創(chuàng)建表SQL語句  private static void createTable(Class<?> cl)  {    //獲取DBTable注解    DBTable dbTable = cl.getAnnotation(DBTable.class);    //判斷DBTable注解是否存在    if (dbTable == null)    {      System.out.println("沒有找到關(guān)于DBTable");      return;    }        //如果@DBTable注解存在獲取表明     String tableName = dbTable.name();    //判斷表名是否存在    if (tableName.length() < 1)    {      //不存在,說明默認(rèn)就是類名,通過 cl.getSimpleName()獲取類名并且大寫      tableName = cl.getSimpleName().toUpperCase();    }        //定義獲取column的容器    List<String> columnDefs = new ArrayList<String>();    //循環(huán)屬性字段    //說明:getDeclaredFields()獲得某個(gè)類的所有申明的字段,即包括public、private和proteced,但是不包括父類的申明字段。     //getFields()獲得某個(gè)類的所有的公共(public)的字段,包括父類。     for (Field field : cl.getDeclaredFields())    {      //定義表字段名稱變量      String columnName = null;      //獲取字段上的注解(現(xiàn)在字段允許多個(gè)注解,因此返回的是數(shù)組)      Annotation[] anns = field.getDeclaredAnnotations();      //判斷屬性是否存在注解      if (anns.length < 1)        continue;            //判斷是否是我們定義的數(shù)據(jù)類型      if (anns[0] instanceof SQLInteger)      {        //獲取SQLInteger 注解        SQLInteger sInt = (SQLInteger)anns[0];        //判斷是否注解的name是否有值        if (sInt.name().length() < 1)        {          //如果沒有值,說明是類的屬性字段,獲取屬性并轉(zhuǎn)換大寫          columnName = field.getName().toUpperCase();        }        else        { //如果有值,獲取設(shè)置的name值          columnName = sInt.name();        }        //放到屬性的容器內(nèi)        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()));      }            //定義生成創(chuàng)建表的SQL語句      StringBuilder createCommand = new StringBuilder("CREATE TABLE " + tableName + "(");      //循環(huán)上面屬性容器,      for (String columnDef : columnDefs)      {        //把屬性添加到sql語句中        createCommand.append("/n  " + columnDef + ",");        //去掉最后一個(gè)逗號(hào)        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;  }}

以上代碼拷貝出來,就可以運(yùn)行了! 

上面雖然是簡單的創(chuàng)建表語句,但我們可以蔓延到hibernate的domain類里的注解,各種CURD ,何嘗不是這樣處理的呢,只是hibernate有很多東西,但是萬變不離其宗,以后有機(jī)會(huì)研究一下hibernate 。 

收獲: 

讀了以后,對(duì)于注解知道為什么要這么用了,其實(shí)顧名思義就是一個(gè)注解,只是有一個(gè)處理器來處理這個(gè)注解,這對(duì)我以后用到注解方面應(yīng)該有幫助的, 

時(shí)間不早了,就寫到這里!

結(jié)果:

注解創(chuàng)建表SQL語句,注解編寫創(chuàng)建表,SQL語句創(chuàng)建表

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持VeVb武林網(wǎng)。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MSSQL教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
欧美人与性动交α欧美精品| 国产福利电影| 在线观看色网站| 超碰超碰在线| 国产精品99久久久久久有的能看| 久久国产在线视频| 无码熟妇人妻av| 免费毛片a线观看| 在线观看日韩片| 日本在线播放一区二区三区| 麻豆视频网站在线观看| 亚洲在线国产日韩欧美| 成人综合电影| 亚洲www色| 三上悠亚作品在线观看| 三级av在线| 国产日韩高清一区二区三区在线| 亚洲**毛片| 欧美91视频| 在线观看免费p片视频网站地址| 亚洲精品人成网在线播放影院| 国产一区二区不卡| 中文字幕国产传媒| 青青草国产精品视频| 一本加勒比北条麻妃| 欧美成人免费播放| 国产香蕉精品视频一区二区三区| 亚洲午夜激情| 极品美妇后花庭翘臀娇吟小说| 欧美日韩国产精品一区| 久久日韩精品| 国产精品一区二区在线看| 日本久久久久久久| 国产精品国产精品国产专区不片| 欧美激情 国产精品| 久久久精品国产sm调教| 人妻视频一区二区三区| 欧美激情亚洲天堂| 91午夜精品亚洲一区二区三区| 99精品网站| 中文字幕乱码人妻无码久久| 久久久视频在线| 日韩视频一区二区三区在线播放免费观看| 丁香婷婷深情五月亚洲| 三级网站在线| 欧美日韩久久不卡| 日韩高清人体午夜| 国产又大又黑又粗| 国产传媒一区| 亚洲人成电影在在线观看网色| 久久这里只有精品一区二区| 国产人妖在线播放| 国产性猛交普通话对白| 亚洲高清视频一区二区| 亚洲激情在线播放| 国产福利第一视频| 久久国产成人精品国产成人亚洲| 男女精品视频| 中文字幕一区二区精品区| 免费日韩视频在线观看| 男女免费网站| 91社影院在线观看| 色窝窝无码一区二区三区成人网站| 久久久av电影| 欧美精品韩国精品| 大荫蒂性生交片| 精品国产精品久久一区免费式| 999久久久精品视频| 天天干天天草| 国产自产视频| 免费网站成人| 天堂一区在线观看| 一区二区高清视频在线观看| 欧美中文字幕一二三四区| 国产一区二区三区久久久久久久久| 欧美色图天堂网| 满满都是荷尔蒙韩剧在线观看| 精品成在人线av无码免费看| 亚洲一区在线看| 国产肉丝袜一区二区| 天天综合视频在线观看| 日本在线不卡一区| 欧美性猛交久久久乱大交小说| 欧美日韩高清不卡| eeuss影院在线| 天海翼在线观看视频| 99热手机在线观看| 欧美午夜aaaaaa免费视频| 亚洲国产欧美日韩| 黄网av在线| 网友自拍亚洲| 在线日韩av| 欧美日韩国产在线一区| 欧美日韩一区二区三区四区五区六区| 亚洲日本成人在线观看| 国产一区二区视频在线播放| 亚洲成年人电影在线观看| 亚洲日本精品一区| 久草成人在线视频| 亚洲黄色在线观看视频| 激情影院在线| 欧洲精品一区二区三区在线观看| 亚洲一区二区三区日韩| 欧美日韩激情在线观看| 成年人黄色大片在线| 欧美国产日本视频| free欧美性| 免费看黄色的视频| 国产黄色影视| 亚洲大黄网站| 两个人看的免费完整在线观看| 国产免费无遮挡| 92国产精品观看| 好吊妞无缓冲视频观看| 18深夜视频在线观看| 国产午夜一区二区| 国产高清视频免费最新在线| 日韩一区二区三区免费视频| 久久久久久久久久久综合| 亚洲一区二区三区在线| 伊人情人综合网| 国产欧美日韩| 少妇人妻无码专区视频| 男人的天堂久久久| 人九九综合九九宗合| 一本大道久久加勒比香蕉| 久久久久久9| 国产精品久久二区二区| 成人午夜无人区一区二区| 亚洲国产精品激情在线观看| 国产网址在线观看| 欧美精品999| 国产成人av电影在线播放| 黄色大全在线观看| 久久久午夜精品福利内容| 精品国产成人在线| 欧美精品制服第一页| 在线观看黄色片| 亚洲成av人片一区二区梦乃| 国产高清第一页| 国产目拍亚洲精品99久久精品| 日韩av在线资源| 国产精品视频看看| 亚洲乱亚洲乱妇| 老色鬼在线视频| 97人人做人人爱| 国产精品无码在线播放| 国产欧美日韩亚洲一区二区三区| 天堂成人国产精品一区| 亚洲精品无码专区| 国产在线麻豆精品观看| 国产直播在线| 中文字幕黄色网址| 欧美视频自拍偷拍| 国产真实精品久久二三区| 任你弄在线视频免费观看| 成人免费视频一区二区| 香蕉精品久久| 亚色视频在线播放| 在线视频中文字幕久| 欧美电影影音先锋| 午夜精彩国产免费不卡不顿大片| 免费在线观看黄色| 欧美性xxxxxbbbbbb精品| 亚洲视频在线观看一区| 日韩精品一区二区三区中文不卡| 精品熟妇无码av免费久久| 热99在线视频| 日韩欧美视频一区二区三区| 日本一区二区在线观看视频| 国产视频一二区| 日本一区二区三区在线免费观看| 美国一级片在线观看| 国产精品字幕| 97精品在线| 国产拍精品一二三| 97人妻精品一区二区三区视频| 欧美在线观看在线观看| 91偷拍与自偷拍精品| 精品无码一区二区三区蜜臀| 亚洲一卡2卡三卡4卡2021四卡| 精品国产一二三四区| 国产在线视频在线| 成人国产精品久久久久久亚洲| 在线视频 中文字幕| 91亚洲精品乱码久久久久久蜜桃| 四虎影视18库在线影院| 久久99精品久久久久久三级| 国内精品久久久久国产盗摄免费观看完整版| 色婷婷精品久久二区二区密| 99免费看香蕉视频| 国产毛片aaa| 精品欧美一区免费观看α√| 欧美高清性xxxx| 欧美日韩在线视频观看| 一道本一区二区| 久久99热只有频精品91密拍| 成人福利视频在线观看| 日本福利在线| 另类激情视频| 国产精品白丝jk喷水视频一区| 综合伊思人在钱三区| 麻豆国产精品一区二区三区| 妺妺窝人体色www在线下载| 久久综合激情网| 国产日韩欧美亚洲一区| 中文字幕第17页| 婷婷无套内射影院| 一本久道久久综合多人| 日韩中文欧美| 欧美亚洲日本一区二区三区| 好吊一区二区三区| 擼擼色在线看观看免费| 欧美tickling网站挠脚心| 91嫩草国产线观看亚洲一区二区| 国产欧美一区二| 成人嫩草影院免费观看| 精品一区亚洲| 欧美性受xxxx黑人| 91在线免费看片| 日韩高清不卡一区二区| 日韩久久一区二区| 日本一区二区免费视频| 免费黄色av电影| 国产一区2区在线观看| 四虎视频在线精品免费网址| 亚洲av成人精品日韩在线播放| 欧美一级专区免费大片| 成人免费高清在线| 亚洲一区二区在线免费观看视频| a中文字幕www| 91中文在线视频| 免费xxxx性欧美18vr| 阳光姐妹淘韩国版| www.黄色小说.com| 免费成人av电影| 午夜精品久久久久久久96蜜桃| 在线观看国产黄| 国产精品久久久久四虎| 天天曰天天操| 久久精品1区| 久色乳综合思思在线视频| 五月婷婷丁香激情| 亚洲欧美国产中文| 久久美女艺术照精彩视频福利播放| 97超级碰碰人国产在线观看| 欧美色网一区| 中文字幕在线观看一区二区三区| 日韩精品亚洲专区在线观看| 欧美怡春院一区二区三区| 国产在视频一区二区三区吞精| 麻豆av电影在线观看| 精品女人视频| 欧美大交乱xxxxxbbb| 国产成人久久久精品一区| 99精品视频免费全部在线| 先锋资源一区二区| 精品国产鲁一鲁一区二区张丽| 成人黄动漫网站| 久久久久久在线观看| 亚洲精品一区三区三区在线观看| 色天天综合狠狠色| 91黄色免费视频| 制服丝袜综合网| 一区 二区 三区| 日韩欧美成人一区二区| 成人免费看片网站| 五月花成人网| 激情久久av一区av二区av三区| 水莓100国产免费av在线播放| 狠狠躁夜夜躁av无码中文幕| 欧美videossex极品| 九七电影院97理论片久久tvb| 亚洲在线视频一区二区| 欧美亚洲图片小说| 欧美一区免费视频| 在线电影国产精品| 中文在线不卡视频| 精品福利在线导航| 亚洲大片精品永久免费| 亚洲欧洲av另类| 国产一区二区在线视频你懂的| 性xxxx欧美老肥妇牲乱| 亚洲一区黄色| 99精品视频在线看| 中文字幕中文字幕一区三区| 中文文字幕一区二区三三| 日本三级黄色大片| 欧美日韩电影一区二区| 国产资源在线免费观看| 国产白袜脚足j棉袜在线观看| 奇米777日韩| 少妇久久久久久被弄到高潮| 黄色网址在线免费播放| 蜜臀一区二区三区精品免费视频| 在线天堂中文www视软件| 91系列在线观看| 日韩高清一区在线| av电影免费看| 91网站最新地址| 在线免费观看羞羞视频一区二区| 九色视频在线观看免费| www红色一片_亚洲成a人片在线观看_| 久草视频在线资源站| 欧美一区二区三区综合| 久热中文字幕在线精品首页| 免费h网站在线观看| 波多野结衣国产精品| 亚洲精品一区中文字幕乱码| 日韩av中文字幕在线| 精品亚洲精品福利线在观看| 久久福利资源站| 国产调教打屁股xxxx网站| 日韩视频欧美视频| 四虎精品一区二区免费| 亚洲欧美在线免费| 丁香婷婷久久久综合精品国产| 999精品在线| 亚洲一区二区三区日韩| 欧美三级黄色大片| 久久不射影院| 在线观看成年人视频| 欧美色图一区二区三区| 欧美xxxx日本和非洲| 日韩精品久久久久久久| 亚洲国产日韩一区无码精品久久久| 欧美亚洲在线播放| 91精品国产自产91精品|