summaryrefslogtreecommitdiffstats
path: root/models
diff options
context:
space:
mode:
authorLunny Xiao <xiaolunwen@gmail.com>2023-04-17 21:22:10 +0800
committerGitHub <noreply@github.com>2023-04-17 21:22:10 +0800
commitcda84bec87f18fa5cbbbd62fc72bc3d997aba66c (patch)
tree63e39cd88f8b16456a781d9a8cc743f833ff3694 /models
parentdcde4701a5b31c88b3120722c3163af4214264d2 (diff)
downloadgitea-cda84bec87f18fa5cbbbd62fc72bc3d997aba66c.tar.gz
gitea-cda84bec87f18fa5cbbbd62fc72bc3d997aba66c.zip
Support converting varchar to nvarchar for mssql database (#24105)
Diffstat (limited to 'models')
-rw-r--r--models/db/convert.go27
1 files changed, 27 insertions, 0 deletions
diff --git a/models/db/convert.go b/models/db/convert.go
index b17e68c87e..112c8575ca 100644
--- a/models/db/convert.go
+++ b/models/db/convert.go
@@ -42,6 +42,33 @@ func ConvertUtf8ToUtf8mb4() error {
return nil
}
+// ConvertVarcharToNVarchar converts database and tables from varchar to nvarchar if it's mssql
+func ConvertVarcharToNVarchar() error {
+ if x.Dialect().URI().DBType != schemas.MSSQL {
+ return nil
+ }
+
+ sess := x.NewSession()
+ defer sess.Close()
+ res, err := sess.QuerySliceString(`SELECT 'ALTER TABLE ' + OBJECT_NAME(SC.object_id) + ' MODIFY SC.name NVARCHAR(' + CONVERT(VARCHAR(5),SC.max_length) + ')'
+FROM SYS.columns SC
+JOIN SYS.types ST
+ON SC.system_type_id = ST.system_type_id
+AND SC.user_type_id = ST.user_type_id
+WHERE ST.name ='varchar'`)
+ if err != nil {
+ return err
+ }
+ for _, row := range res {
+ if len(row) == 1 {
+ if _, err = sess.Exec(row[0]); err != nil {
+ return err
+ }
+ }
+ }
+ return err
+}
+
// Cell2Int64 converts a xorm.Cell type to int64,
// and handles possible irregular cases.
func Cell2Int64(val xorm.Cell) int64 {