/* * ToroDB * Copyright © 2014 8Kdata Technology (www.8kdata.com) * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package com.torodb.backend.postgresql.tables; import com.torodb.backend.postgresql.tables.records.PostgreSqlMetaDocPartRecord; import com.torodb.backend.tables.MetaDocPartTable; import edu.umd.cs.findbugs.annotations.SuppressFBWarnings; import org.jooq.Field; import org.jooq.Table; import org.jooq.TableField; import org.jooq.impl.DSL; import org.jooq.impl.SQLDataType; import org.jooq.util.postgres.PostgresDataType; @SuppressFBWarnings(value = {"EQ_DOESNT_OVERRIDE_EQUALS", "HE_HASHCODE_NO_EQUALS"}) public class PostgreSqlMetaDocPartTable extends MetaDocPartTable<String[], PostgreSqlMetaDocPartRecord> { private static final long serialVersionUID = -550698624070753099L; /** * The singleton instance of <code>torodb.collections</code> */ public static final PostgreSqlMetaDocPartTable DOC_PART = new PostgreSqlMetaDocPartTable(); @Override public Class<PostgreSqlMetaDocPartRecord> getRecordType() { return PostgreSqlMetaDocPartRecord.class; } /** * Create a <code>torodb.collections</code> table reference */ public PostgreSqlMetaDocPartTable() { this(TABLE_NAME, null); } /** * Create an aliased <code>torodb.collections</code> table reference */ public PostgreSqlMetaDocPartTable(String alias) { this(alias, PostgreSqlMetaDocPartTable.DOC_PART); } private PostgreSqlMetaDocPartTable(String alias, Table<PostgreSqlMetaDocPartRecord> aliased) { this(alias, aliased, null); } private PostgreSqlMetaDocPartTable(String alias, Table<PostgreSqlMetaDocPartRecord> aliased, Field<?>[] parameters) { super(alias, aliased, parameters); } /** * {@inheritDoc} */ @Override public PostgreSqlMetaDocPartTable as(String alias) { return new PostgreSqlMetaDocPartTable(alias, this); } /** * Rename this table */ public PostgreSqlMetaDocPartTable rename(String name) { return new PostgreSqlMetaDocPartTable(name, null); } @Override protected TableField<PostgreSqlMetaDocPartRecord, String> createDatabaseField() { return createField(TableFields.DATABASE.fieldName, SQLDataType.VARCHAR.nullable(false), this, ""); } @Override protected TableField<PostgreSqlMetaDocPartRecord, String> createCollectionField() { return createField(TableFields.COLLECTION.fieldName, SQLDataType.VARCHAR.nullable(false), this, ""); } @Override protected TableField<PostgreSqlMetaDocPartRecord, String[]> createTableRefField() { return createField(TableFields.TABLE_REF.fieldName, SQLDataType.VARCHAR.getArrayDataType() .nullable(false), this, ""); } @Override protected TableField<PostgreSqlMetaDocPartRecord, String> createIdentifierField() { return createField(TableFields.IDENTIFIER.fieldName, PostgresDataType.VARCHAR.nullable(false), this, ""); } @Override protected TableField<PostgreSqlMetaDocPartRecord, Integer> createLastRidField() { return createField(TableFields.LAST_RID.fieldName, SQLDataType.INTEGER.nullable(false), this, ""); } @Override protected Field<Integer> createDidField() { return DSL.field(DocPartTableFields.DID.fieldName, SQLDataType.INTEGER.nullable(false)); } @Override protected Field<Integer> createRidField() { return DSL.field(DocPartTableFields.RID.fieldName, SQLDataType.INTEGER.nullable(false)); } @Override protected Field<Integer> createPidField() { return DSL.field(DocPartTableFields.PID.fieldName, SQLDataType.INTEGER.nullable(false)); } @Override protected Field<Integer> createSeqField() { return DSL.field(DocPartTableFields.SEQ.fieldName, SQLDataType.INTEGER.nullable(false)); } }