aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-db/src/main/java/org/sonar/db/charset/ColumnDef.java
diff options
context:
space:
mode:
Diffstat (limited to 'sonar-db/src/main/java/org/sonar/db/charset/ColumnDef.java')
-rw-r--r--sonar-db/src/main/java/org/sonar/db/charset/ColumnDef.java92
1 files changed, 92 insertions, 0 deletions
diff --git a/sonar-db/src/main/java/org/sonar/db/charset/ColumnDef.java b/sonar-db/src/main/java/org/sonar/db/charset/ColumnDef.java
new file mode 100644
index 00000000000..45d4b017546
--- /dev/null
+++ b/sonar-db/src/main/java/org/sonar/db/charset/ColumnDef.java
@@ -0,0 +1,92 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2016 SonarSource SA
+ * mailto:contact AT sonarsource DOT com
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser 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
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+package org.sonar.db.charset;
+
+import java.sql.ResultSet;
+import java.sql.SQLException;
+import javax.annotation.concurrent.Immutable;
+
+/**
+ * Result of standard SQL command "select * from INFORMATION_SCHEMA" (columns listed in {@link #SELECT_COLUMNS}).
+ */
+@Immutable
+public class ColumnDef {
+
+ public static final String SELECT_COLUMNS = "select table_name, column_name, character_set_name, collation_name, data_type, character_maximum_length, is_nullable ";
+
+ private final String table;
+ private final String column;
+ private final String charset;
+ private final String collation;
+ private final String dataType;
+ private final long size;
+ private final boolean nullable;
+
+ public ColumnDef(String table, String column, String charset, String collation, String dataType, long size, boolean nullable) {
+ this.table = table;
+ this.column = column;
+ this.charset = charset;
+ this.collation = collation;
+ this.dataType = dataType;
+ this.size = size;
+ this.nullable = nullable;
+ }
+
+ public String getTable() {
+ return table;
+ }
+
+ public String getColumn() {
+ return column;
+ }
+
+ public String getCharset() {
+ return charset;
+ }
+
+ public String getCollation() {
+ return collation;
+ }
+
+ public String getDataType() {
+ return dataType;
+ }
+
+ public long getSize() {
+ return size;
+ }
+
+ public boolean isNullable() {
+ return nullable;
+ }
+
+ public enum ColumnDefRowConverter implements SqlExecutor.RowConverter<ColumnDef> {
+ INSTANCE;
+
+ @Override
+ public ColumnDef convert(ResultSet rs) throws SQLException {
+ String nullableText = rs.getString(7);
+ boolean nullable = "YES".equalsIgnoreCase(nullableText);
+
+ return new ColumnDef(
+ rs.getString(1), rs.getString(2), rs.getString(3), rs.getString(4), rs.getString(5), rs.getLong(6), nullable);
+ }
+ }
+}