Restore compatibility with SQLServer 2008 R2 in migrations (#16638)
This fixes two problems with MSSQL: * `ALTER TABLE DROP ... IF EXISTS ...` is only supported in SQL Server >16. The `IF EXISTS` here is a belt-and-braces and does not need to be present. Therefore can be dropped. Also stop attempting to drop the indexes as constraints as they're indexes! * System tables like: `sys.indexes` should be lowercase not uppercase because of collation issues. Fix #13615 Signed-off-by: Andrew Thornton <art27@cantab.net> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
This commit is contained in:
		
							parent
							
								
									1a2256bf44
								
							
						
					
					
						commit
						428d58f8da
					
				
					 1 changed files with 3 additions and 6 deletions
				
			
		|  | @ -836,7 +836,7 @@ func dropTableColumns(sess *xorm.Session, tableName string, columnNames ...strin | ||||||
| 			} | 			} | ||||||
| 			cols += "`" + strings.ToLower(col) + "`" | 			cols += "`" + strings.ToLower(col) + "`" | ||||||
| 		} | 		} | ||||||
| 		sql := fmt.Sprintf("SELECT Name FROM SYS.DEFAULT_CONSTRAINTS WHERE PARENT_OBJECT_ID = OBJECT_ID('%[1]s') AND PARENT_COLUMN_ID IN (SELECT column_id FROM sys.columns WHERE lower(NAME) IN (%[2]s) AND object_id = OBJECT_ID('%[1]s'))", | 		sql := fmt.Sprintf("SELECT Name FROM sys.default_constraints WHERE parent_object_id = OBJECT_ID('%[1]s') AND parent_column_id IN (SELECT column_id FROM sys.columns WHERE LOWER(name) IN (%[2]s) AND object_id = OBJECT_ID('%[1]s'))", | ||||||
| 			tableName, strings.ReplaceAll(cols, "`", "'")) | 			tableName, strings.ReplaceAll(cols, "`", "'")) | ||||||
| 		constraints := make([]string, 0) | 		constraints := make([]string, 0) | ||||||
| 		if err := sess.SQL(sql).Find(&constraints); err != nil { | 		if err := sess.SQL(sql).Find(&constraints); err != nil { | ||||||
|  | @ -847,17 +847,14 @@ func dropTableColumns(sess *xorm.Session, tableName string, columnNames ...strin | ||||||
| 				return fmt.Errorf("Drop table `%s` default constraint `%s`: %v", tableName, constraint, err) | 				return fmt.Errorf("Drop table `%s` default constraint `%s`: %v", tableName, constraint, err) | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		sql = fmt.Sprintf("SELECT DISTINCT Name FROM SYS.INDEXES INNER JOIN SYS.INDEX_COLUMNS ON INDEXES.INDEX_ID = INDEX_COLUMNS.INDEX_ID AND INDEXES.OBJECT_ID = INDEX_COLUMNS.OBJECT_ID WHERE INDEXES.OBJECT_ID = OBJECT_ID('%[1]s') AND INDEX_COLUMNS.COLUMN_ID IN (SELECT column_id FROM sys.columns WHERE lower(NAME) IN (%[2]s) AND object_id = OBJECT_ID('%[1]s'))", | 		sql = fmt.Sprintf("SELECT DISTINCT Name FROM sys.indexes INNER JOIN sys.index_columns ON indexes.index_id = index_columns.index_id AND indexes.object_id = index_columns.object_id WHERE indexes.object_id = OBJECT_ID('%[1]s') AND index_columns.column_id IN (SELECT column_id FROM sys.columns WHERE LOWER(name) IN (%[2]s) AND object_id = OBJECT_ID('%[1]s'))", | ||||||
| 			tableName, strings.ReplaceAll(cols, "`", "'")) | 			tableName, strings.ReplaceAll(cols, "`", "'")) | ||||||
| 		constraints = make([]string, 0) | 		constraints = make([]string, 0) | ||||||
| 		if err := sess.SQL(sql).Find(&constraints); err != nil { | 		if err := sess.SQL(sql).Find(&constraints); err != nil { | ||||||
| 			return fmt.Errorf("Find constraints: %v", err) | 			return fmt.Errorf("Find constraints: %v", err) | ||||||
| 		} | 		} | ||||||
| 		for _, constraint := range constraints { | 		for _, constraint := range constraints { | ||||||
| 			if _, err := sess.Exec(fmt.Sprintf("ALTER TABLE `%s` DROP CONSTRAINT IF EXISTS `%s`", tableName, constraint)); err != nil { | 			if _, err := sess.Exec(fmt.Sprintf("DROP INDEX `%[2]s` ON `%[1]s`", tableName, constraint)); err != nil { | ||||||
| 				return fmt.Errorf("Drop table `%s` index constraint `%s`: %v", tableName, constraint, err) |  | ||||||
| 			} |  | ||||||
| 			if _, err := sess.Exec(fmt.Sprintf("DROP INDEX IF EXISTS `%[2]s` ON `%[1]s`", tableName, constraint)); err != nil { |  | ||||||
| 				return fmt.Errorf("Drop index `%[2]s` on `%[1]s`: %v", tableName, constraint, err) | 				return fmt.Errorf("Drop index `%[2]s` on `%[1]s`: %v", tableName, constraint, err) | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue