You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@empire-db.apache.org by de...@apache.org on 2016/11/30 08:25:40 UTC

empire-db git commit: EMPIREDB-250

Repository: empire-db
Updated Branches:
  refs/heads/master 05ff572e4 -> 6e14aae47


EMPIREDB-250

Project: http://git-wip-us.apache.org/repos/asf/empire-db/repo
Commit: http://git-wip-us.apache.org/repos/asf/empire-db/commit/6e14aae4
Tree: http://git-wip-us.apache.org/repos/asf/empire-db/tree/6e14aae4
Diff: http://git-wip-us.apache.org/repos/asf/empire-db/diff/6e14aae4

Branch: refs/heads/master
Commit: 6e14aae470353760099bec6c9e6ce6fc9ba4a52c
Parents: 05ff572
Author: Jan Glaubitz <ja...@glaubitz.org>
Authored: Wed Nov 30 09:24:50 2016 +0100
Committer: Jan Glaubitz <ja...@glaubitz.org>
Committed: Wed Nov 30 09:24:50 2016 +0100

----------------------------------------------------------------------
 .../empire/db/mysql/MySQLDDLGenerator.java      | 52 ++++++++++++++++++++
 1 file changed, 52 insertions(+)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/empire-db/blob/6e14aae4/empire-db/src/main/java/org/apache/empire/db/mysql/MySQLDDLGenerator.java
----------------------------------------------------------------------
diff --git a/empire-db/src/main/java/org/apache/empire/db/mysql/MySQLDDLGenerator.java b/empire-db/src/main/java/org/apache/empire/db/mysql/MySQLDDLGenerator.java
index e54eb21..236923c 100644
--- a/empire-db/src/main/java/org/apache/empire/db/mysql/MySQLDDLGenerator.java
+++ b/empire-db/src/main/java/org/apache/empire/db/mysql/MySQLDDLGenerator.java
@@ -23,6 +23,8 @@ import java.util.Iterator;
 import org.apache.empire.commons.StringUtils;
 import org.apache.empire.data.DataType;
 import org.apache.empire.db.DBColumn;
+import org.apache.empire.db.DBCombinedCmd;
+import org.apache.empire.db.DBCommandExpr;
 import org.apache.empire.db.DBDDLGenerator;
 import org.apache.empire.db.DBDatabase;
 import org.apache.empire.db.DBExpr;
@@ -30,10 +32,16 @@ import org.apache.empire.db.DBIndex;
 import org.apache.empire.db.DBSQLScript;
 import org.apache.empire.db.DBTable;
 import org.apache.empire.db.DBTableColumn;
+import org.apache.empire.db.DBView;
 import org.apache.empire.db.DBDatabaseDriver.DBSeqTable;
+import org.apache.empire.exceptions.NotSupportedException;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
 
 public class MySQLDDLGenerator extends DBDDLGenerator<DBDatabaseDriverMySQL>
 {
+	private static final Logger log = LoggerFactory.getLogger(MySQLDDLGenerator.class);
+	
     public MySQLDDLGenerator(DBDatabaseDriverMySQL driver)
     {
         super(driver);
@@ -156,4 +164,48 @@ public class MySQLDDLGenerator extends DBDDLGenerator<DBDatabaseDriverMySQL>
         createTableIndexes(t, pk, script);        
     }
     
+    /**
+     * Appends the DDL-Script for creating the given view to an SQL-Script 
+     * @param v the view to create
+     * @param script the sql script to which to append the dll command(s)
+     */
+    protected void createView(DBView v, DBSQLScript script)
+    {
+        // Create the Command
+        DBCommandExpr cmd = v.createCommand();
+        if (cmd==null)
+        {   // Check whether Error information is available
+            log.error("No command has been supplied for view " + v.getName());
+            throw new NotSupportedException(this, v.getName() + ".createCommand");
+        }
+        // Make sure there is no OrderBy
+        cmd.clearOrderBy();
+
+        // Build String
+        StringBuilder sql = new StringBuilder();
+        sql.append( "CREATE VIEW ");
+        v.addSQL(sql, DBExpr.CTX_FULLNAME);
+        sql.append( " (" );
+        boolean addSeparator = false;
+        for(DBColumn c : v.getColumns())
+        {
+            if (addSeparator)
+                sql.append(", ");
+            // Add Column name
+            c.addSQL(sql, DBExpr.CTX_NAME);
+            // next
+            addSeparator = true;
+        }
+        sql.append(")\r\nAS\r\n");
+        if (cmd instanceof DBCombinedCmd)
+        {
+        	sql.append(cmd.getSelect());
+        } else
+        {
+        	cmd.addSQL( sql, DBExpr.CTX_DEFAULT);
+        }
+        // done
+        addCreateViewStmt(v, sql, script);
+    }
+    
 }