65 Star 397 Fork 128

admpub/nging

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
mysql_database.go 2.81 KB
一键复制 编辑 原始数据 按行查看 历史
/*
Nging is a toolbox for webmasters
Copyright (C) 2018-present Wenhui Shen <swh@admpub.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 <https://www.gnu.org/licenses/>.
*/
package mysql
import (
"database/sql"
"github.com/webx-top/com"
)
func (m *mySQL) createDatabase(dbName, collate string) *Result {
r := &Result{}
r.SQL = "CREATE DATABASE " + quoteCol(dbName)
if len(collate) > 0 {
r.SQL += " COLLATE " + quoteVal(collate)
}
return r.Exec(m.newParam())
}
func (m *mySQL) dropDatabase(dbName string) *Result {
r := &Result{}
r.SQL = "DROP DATABASE " + quoteCol(dbName)
return r.Exec(m.newParam())
}
func (m *mySQL) alterDatabase(dbName string, collation string) *Result {
r := &Result{}
r.SQL = "ALTER DATABASE " + quoteCol(dbName)
if reOnlyWord.MatchString(collation) {
r.SQL += " COLLATE " + collation
}
return r.Exec(m.newParam())
}
func (m *mySQL) renameDatabase(newName, collate string) []*Result {
rs := []*Result{}
r := m.createDatabase(newName, collate)
rs = append(rs, r)
if r.err != nil {
return rs
}
rGetTables := &Result{}
rGetTables.start()
tables, err := m.getTables()
rGetTables.end()
rGetTables.SQL = `SHOW TABLES`
rGetTables.err = err
if err != nil {
rGetTables.ErrorString = err.Error()
}
rs = append(rs, rGetTables)
if err != nil {
return rs
}
var sql string
newName = quoteCol(newName)
for key, table := range tables {
table = quoteCol(table)
if key > 0 {
sql += ", "
}
sql += table + " TO " + newName + "." + table
}
if len(sql) > 0 {
rRename := &Result{}
rRename.SQL = "RENAME TABLE " + sql
rRename = rRename.Exec(m.newParam())
err = rRename.err
rs = append(rs, rRename)
}
if err == nil {
rDrop := m.dropDatabase(m.dbName)
rs = append(rs, rDrop)
}
return rs
}
// 获取数据库列表
func (m *mySQL) getDatabases() ([]string, error) {
sqlStr := `SELECT SCHEMA_NAME FROM information_schema.SCHEMATA`
if com.VersionCompare(m.getVersion(), `5`) < 0 {
sqlStr = `SHOW DATABASES`
}
rows, err := m.newParam().SetCollection(sqlStr).Query()
if err != nil {
return nil, err
}
defer rows.Close()
ret := []string{}
for rows.Next() {
var v sql.NullString
err := rows.Scan(&v)
if err != nil {
return nil, err
}
ret = append(ret, v.String)
}
return ret, nil
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/admpub/nging.git
git@gitee.com:admpub/nging.git
admpub
nging
nging
v2.0.3

搜索帮助