mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
util.sql: Ignore if tables and indices already exist on creation (fixes #1064)
Tested with SQLite3 3.16.2 and 3.27.2 and Postgres 11. MySQL does not support IF NOT EXISTS for indices so not handled here.
This commit is contained in:
parent
cabd5216b4
commit
c2576aea62
1 changed files with 6 additions and 0 deletions
|
@ -238,6 +238,9 @@ function engine:transaction(...)
|
|||
end
|
||||
function engine:_create_index(index)
|
||||
local sql = "CREATE INDEX \""..index.name.."\" ON \""..index.table.."\" (";
|
||||
if self.params.driver ~= "MySQL" then
|
||||
sql = sql:gsub("^CREATE INDEX", "%1 IF NOT EXISTS");
|
||||
end
|
||||
for i=1,#index do
|
||||
sql = sql.."\""..index[i].."\"";
|
||||
if i ~= #index then sql = sql..", "; end
|
||||
|
@ -256,6 +259,9 @@ function engine:_create_index(index)
|
|||
end
|
||||
function engine:_create_table(table)
|
||||
local sql = "CREATE TABLE \""..table.name.."\" (";
|
||||
do
|
||||
sql = sql:gsub("^CREATE TABLE", "%1 IF NOT EXISTS");
|
||||
end
|
||||
for i,col in ipairs(table.c) do
|
||||
local col_type = col.type;
|
||||
if col_type == "MEDIUMTEXT" and self.params.driver ~= "MySQL" then
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue