Esempio n. 1
0
  /**
   * カラム記述の{@link Comparator}を作成します。
   *
   * @param tableDesc テーブル記述
   * @return カラム記述の{@link Comparator}
   */
  protected Comparator<ColumnDescRef> createColumnDescRefComparator(TableDesc tableDesc) {
    final List<String> pkColumnNameList = new ArrayList<String>();
    if (tableDesc.getPrimaryKeyDesc() != null) {
      PrimaryKeyDesc primaryKeyDesc = tableDesc.getPrimaryKeyDesc();
      pkColumnNameList.addAll(primaryKeyDesc.getColumnNameList());
    }
    return new Comparator<ColumnDescRef>() {

      public int compare(ColumnDescRef o1, ColumnDescRef o2) {
        int index1 = pkColumnNameList.indexOf(o1.columnDesc.getName());
        int index2 = pkColumnNameList.indexOf(o2.columnDesc.getName());
        int ret = 0;
        if (index1 < 0) {
          if (index2 < 0) {
            ret = o1.index - o2.index;
          } else {
            ret = 1;
          }
        } else {
          if (index2 < 0) {
            ret = -1;
          } else {
            ret = index1 - index2;
          }
        }
        return ret;
      }
    };
  }
  /**
   * 主キー記述を処理します。
   *
   * @param entityMeta エンティティメタデータ
   * @param propertyMeta プロパティメタデータ
   * @param tableDesc テーブル記述
   * @param generator テーブルジェネレータ
   */
  protected void doPrimaryKeyColumn(
      EntityMeta entityMeta, TableDesc tableDesc, TableGenerator generator) {
    String pkColumnName = generator.pkColumnName();
    if (StringUtil.isEmpty(pkColumnName)) {
      pkColumnName = TableIdGenerator.DEFAULT_PK_COLUMN_NAME;
    }
    PrimaryKeyDesc primaryKeyDesc = new PrimaryKeyDesc();
    primaryKeyDesc.addColumnName(pkColumnName);
    tableDesc.setPrimaryKeyDesc(primaryKeyDesc);

    ColumnDesc columnDesc = new ColumnDesc();
    columnDesc.setName(pkColumnName);
    SqlType sqlType = dialect.getSqlType(Types.VARCHAR);
    columnDesc.setSqlType(sqlType);
    Column column = AnnotationUtil.getDefaultColumn();
    columnDesc.setDefinition(sqlType.getDataType(column.length(), 0, 0, false));
    tableDesc.addColumnDesc(columnDesc);
  }
Esempio n. 3
0
 /**
  * 一意キー記述を処理します。
  *
  * @param entityMeta エンティティメタデータ
  * @param tableDesc テーブル記述
  * @param table テーブル
  */
 protected void doUniqueKeyDesc(EntityMeta entityMeta, TableDesc tableDesc, Table table) {
   String singlePkColumnName = null;
   PrimaryKeyDesc primaryKeyDesc = tableDesc.getPrimaryKeyDesc();
   if (primaryKeyDesc != null && primaryKeyDesc.getColumnNameList().size() == 1) {
     singlePkColumnName = primaryKeyDesc.getColumnNameList().get(0);
   }
   for (ColumnDesc columnDesc : tableDesc.getColumnDescList()) {
     if (columnDesc.getName().equals(singlePkColumnName)) {
       continue;
     }
     UniqueKeyDesc uniqueKeyDesc = uniqueKeyDescFactory.getSingleUniqueKeyDesc(columnDesc);
     if (uniqueKeyDesc != null) {
       tableDesc.addUniqueKeyDesc(uniqueKeyDesc);
     }
   }
   for (UniqueConstraint uc : table.uniqueConstraints()) {
     UniqueKeyDesc uniqueKeyDesc = uniqueKeyDescFactory.getCompositeUniqueKeyDesc(uc);
     if (uniqueKeyDesc != null) {
       tableDesc.addUniqueKeyDesc(uniqueKeyDesc);
     }
   }
 }