Merge 3b92d1d047fe

This commit is contained in:
Heng Sin Low 2013-02-13 17:36:22 +08:00
commit 06ebc462b8
7 changed files with 204 additions and 168 deletions

View File

@ -14,13 +14,13 @@ declare
begin begin
if datatype is not null then if datatype is not null then
select pg_type.typname, format_type(pg_type.oid, pg_attribute.atttypmod) select pg_type.typname, format_type(pg_type.oid, pg_attribute.atttypmod)
into typename, sqltype into typename, sqltype
from pg_class, pg_attribute, pg_type from pg_class, pg_attribute, pg_type
where relname = lower(tablename) where relname = lower(tablename)
and relkind = 'r' and relkind = 'r'
and pg_class.oid = pg_attribute.attrelid and pg_class.oid = pg_attribute.attrelid
and attname = lower(columnname) and attname = lower(columnname)
and atttypid = pg_type.oid; and atttypid = pg_type.oid;
sqltype_short := sqltype; sqltype_short := sqltype;
if typename = 'numeric' then if typename = 'numeric' then
sqltype_short := replace(sqltype, ',0', ''); sqltype_short := replace(sqltype, ',0', '');
@ -31,28 +31,41 @@ begin
end if; end if;
if lower(datatype) <> sqltype and lower(datatype) <> sqltype_short then if lower(datatype) <> sqltype and lower(datatype) <> sqltype_short then
i := 0; i := 0;
for v in select a.relname, a.oid for v in
from pg_class a, pg_depend b, pg_depend c, pg_class d, pg_attribute e with recursive depv(relname, viewoid, depth) as (
where a.oid = b.refobjid select distinct a.relname, a.oid, 1
and b.objid = c.objid from pg_class a, pg_depend b, pg_depend c, pg_class d, pg_attribute e
and b.refobjid <> c.refobjid where a.oid = b.refobjid
and b.deptype = 'n' and b.objid = c.objid
and c.refobjid = d.oid and b.refobjid <> c.refobjid
and d.relname = lower(tablename) and b.deptype = 'n'
and d.relkind = 'r' and c.refobjid = d.oid
and d.oid = e.attrelid and d.relname = lower(tablename)
and e.attname = lower(columnname) and d.relkind = 'r'
and c.refobjsubid = e.attnum and d.oid = e.attrelid
and a.relkind = 'v' and e.attname = lower(columnname)
loop and c.refobjsubid = e.attnum
and a.relkind = 'v'
union all
select distinct dependee.relname, dependee.oid, depv.depth+1
from pg_depend
join pg_rewrite on pg_depend.objid = pg_rewrite.oid
join pg_class as dependee on pg_rewrite.ev_class = dependee.oid
join pg_class as dependent on pg_depend.refobjid = dependent.oid
join pg_attribute ON pg_depend.refobjid = pg_attribute.attrelid and pg_depend.refobjsubid = pg_attribute.attnum and pg_attribute.attnum > 0
join depv on dependent.relname = depv.relname
)
select relname, viewoid, max(depth) from depv group by relname, viewoid order by 3 desc
loop
i := i + 1; i := i + 1;
viewtext[i] := pg_get_viewdef(v.oid); viewtext[i] := pg_get_viewdef(v.viewoid);
viewname[i] := v.relname; viewname[i] := v.relname;
end loop; end loop;
if i > 0 then if i > 0 then
begin begin
for j in 1 .. i loop for j in 1 .. i loop
command := 'drop view ' || viewname[j]; command := 'drop view ' || viewname[j];
raise notice 'executing -> %', command;
execute command; execute command;
dropviews[j] := viewname[j]; dropviews[j] := viewname[j];
end loop; end loop;
@ -60,20 +73,23 @@ begin
when others then when others then
i := array_upper(dropviews, 1); i := array_upper(dropviews, 1);
if i > 0 then if i > 0 then
for j in 1 .. i loop for j in reverse i .. 1 loop
command := 'create or replace view ' || dropviews[j] || ' as ' || viewtext[j]; command := 'create or replace view ' || dropviews[j] || ' as ' || viewtext[j];
raise notice 'executing -> %', 'create view ' || dropviews[j];
execute command; execute command;
end loop; end loop;
end if; end if;
raise exception 'Failed to recreate dependent view'; raise exception 'Failed to recreate dependent view. SQLERRM=%', SQLERRM;
end; end;
end if; end if;
command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' type ' || lower(datatype); command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' type ' || lower(datatype);
raise notice 'executing -> %', command;
execute command; execute command;
i := array_upper(dropviews, 1); i := array_upper(dropviews, 1);
if i > 0 then if i > 0 then
for j in 1 .. i loop for j in reverse i .. 1 loop
command := 'create or replace view ' || dropviews[j] || ' as ' || viewtext[j]; command := 'create or replace view ' || dropviews[j] || ' as ' || viewtext[j];
raise notice 'executing -> %', 'create view ' || dropviews[j];
execute command; execute command;
end loop; end loop;
end if; end if;
@ -86,24 +102,29 @@ begin
else else
command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' set default ''' || defaultclause || ''''; command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' set default ''' || defaultclause || '''';
end if; end if;
raise notice 'executing -> %', command;
execute command; execute command;
end if; end if;
if nullclause is not null then if nullclause is not null then
if lower(nullclause) = 'not null' then if lower(nullclause) = 'not null' then
command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' set not null'; command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' set not null';
raise notice 'executing -> %', command;
execute command; execute command;
elsif lower(nullclause) = 'null' then elsif lower(nullclause) = 'null' then
command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' drop not null'; command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' drop not null';
raise notice 'executing -> %', command;
execute command; execute command;
end if; end if;
end if; end if;
end; end;
$$ language plpgsql; $$ language plpgsql;
/*
create table t_alter_column create table t_alter_column
( tablename name, columnname name, datatype name, nullclause varchar(10), defaultclause varchar(200)); ( tablename name, columnname name, datatype name, nullclause varchar(10), defaultclause varchar(200));
create rule alter_column_rule as on insert to t_alter_column create rule alter_column_rule as on insert to t_alter_column
do instead select altercolumn(new.tablename, new.columnname, new.datatype, new.nullclause, do instead select altercolumn(new.tablename, new.columnname, new.datatype, new.nullclause,
new.defaultclause); new.defaultclause);
*/

View File

@ -38,3 +38,6 @@ INSERT INTO AD_Message (AD_Client_ID,AD_Message_ID,AD_Message_UU,AD_Org_ID,Creat
INSERT INTO AD_Message_Trl (AD_Language,AD_Message_ID, MsgText,MsgTip, IsTranslated,AD_Client_ID,AD_Org_ID,Created,Createdby,Updated,UpdatedBy,AD_Message_Trl_UU ) SELECT l.AD_Language,t.AD_Message_ID, t.MsgText,t.MsgTip, 'N',t.AD_Client_ID,t.AD_Org_ID,t.Created,t.Createdby,t.Updated,t.UpdatedBy,Generate_UUID() FROM AD_Language l, AD_Message t WHERE l.IsActive='Y' AND l.IsSystemLanguage='Y' AND l.IsBaseLanguage='N' AND t.AD_Message_ID=200138 AND NOT EXISTS (SELECT * FROM AD_Message_Trl tt WHERE tt.AD_Language=l.AD_Language AND tt.AD_Message_ID=t.AD_Message_ID) INSERT INTO AD_Message_Trl (AD_Language,AD_Message_ID, MsgText,MsgTip, IsTranslated,AD_Client_ID,AD_Org_ID,Created,Createdby,Updated,UpdatedBy,AD_Message_Trl_UU ) SELECT l.AD_Language,t.AD_Message_ID, t.MsgText,t.MsgTip, 'N',t.AD_Client_ID,t.AD_Org_ID,t.Created,t.Createdby,t.Updated,t.UpdatedBy,Generate_UUID() FROM AD_Language l, AD_Message t WHERE l.IsActive='Y' AND l.IsSystemLanguage='Y' AND l.IsBaseLanguage='N' AND t.AD_Message_ID=200138 AND NOT EXISTS (SELECT * FROM AD_Message_Trl tt WHERE tt.AD_Language=l.AD_Language AND tt.AD_Message_ID=t.AD_Message_ID)
; ;
SELECT register_migration_script('2013012430719_IDEMPIERE-90.sql') FROM dual
;

View File

@ -0,0 +1,4 @@
-- just for postgresql
SELECT register_migration_script('201302081954_IDEMPIERE-621_altercolumn.sql') FROM dual
;

View File

@ -38,3 +38,6 @@ INSERT INTO AD_Message (AD_Client_ID,AD_Message_ID,AD_Message_UU,AD_Org_ID,Creat
INSERT INTO AD_Message_Trl (AD_Language,AD_Message_ID, MsgText,MsgTip, IsTranslated,AD_Client_ID,AD_Org_ID,Created,Createdby,Updated,UpdatedBy,AD_Message_Trl_UU ) SELECT l.AD_Language,t.AD_Message_ID, t.MsgText,t.MsgTip, 'N',t.AD_Client_ID,t.AD_Org_ID,t.Created,t.Createdby,t.Updated,t.UpdatedBy,Generate_UUID() FROM AD_Language l, AD_Message t WHERE l.IsActive='Y' AND l.IsSystemLanguage='Y' AND l.IsBaseLanguage='N' AND t.AD_Message_ID=200138 AND NOT EXISTS (SELECT * FROM AD_Message_Trl tt WHERE tt.AD_Language=l.AD_Language AND tt.AD_Message_ID=t.AD_Message_ID) INSERT INTO AD_Message_Trl (AD_Language,AD_Message_ID, MsgText,MsgTip, IsTranslated,AD_Client_ID,AD_Org_ID,Created,Createdby,Updated,UpdatedBy,AD_Message_Trl_UU ) SELECT l.AD_Language,t.AD_Message_ID, t.MsgText,t.MsgTip, 'N',t.AD_Client_ID,t.AD_Org_ID,t.Created,t.Createdby,t.Updated,t.UpdatedBy,Generate_UUID() FROM AD_Language l, AD_Message t WHERE l.IsActive='Y' AND l.IsSystemLanguage='Y' AND l.IsBaseLanguage='N' AND t.AD_Message_ID=200138 AND NOT EXISTS (SELECT * FROM AD_Message_Trl tt WHERE tt.AD_Language=l.AD_Language AND tt.AD_Message_ID=t.AD_Message_ID)
; ;
SELECT register_migration_script('2013012430719_IDEMPIERE-90.sql') FROM dual
;

View File

@ -1,111 +1,125 @@
create or replace function altercolumn(tablename name, columnname name, datatype name, create or replace function altercolumn(tablename name, columnname name, datatype name,
nullclause varchar, defaultclause varchar) returns void as $$ nullclause varchar, defaultclause varchar) returns void as $$
declare declare
command text; command text;
viewtext text[]; viewtext text[];
viewname name[]; viewname name[];
dropviews name[]; dropviews name[];
i int; i int;
j int; j int;
v record; v record;
sqltype text; sqltype text;
sqltype_short text; sqltype_short text;
typename name; typename name;
begin begin
if datatype is not null then if datatype is not null then
select pg_type.typname, format_type(pg_type.oid, pg_attribute.atttypmod) select pg_type.typname, format_type(pg_type.oid, pg_attribute.atttypmod)
into typename, sqltype into typename, sqltype
from pg_class, pg_attribute, pg_type from pg_class, pg_attribute, pg_type
where relname = lower(tablename) where relname = lower(tablename)
and relkind = 'r' and relkind = 'r'
and pg_class.oid = pg_attribute.attrelid and pg_class.oid = pg_attribute.attrelid
and attname = lower(columnname) and attname = lower(columnname)
and atttypid = pg_type.oid; and atttypid = pg_type.oid;
sqltype_short := sqltype; sqltype_short := sqltype;
if typename = 'numeric' then if typename = 'numeric' then
sqltype_short := replace(sqltype, ',0', ''); sqltype_short := replace(sqltype, ',0', '');
elsif strpos(sqltype,'character varying') = 1 then elsif strpos(sqltype,'character varying') = 1 then
sqltype_short := replace(sqltype, 'character varying', 'varchar'); sqltype_short := replace(sqltype, 'character varying', 'varchar');
elsif sqltype = 'timestamp without time zone' then elsif sqltype = 'timestamp without time zone' then
sqltype_short := 'timestamp'; sqltype_short := 'timestamp';
end if; end if;
if lower(datatype) <> sqltype and lower(datatype) <> sqltype_short then if lower(datatype) <> sqltype and lower(datatype) <> sqltype_short then
i := 0; i := 0;
for v in select a.relname, a.oid for v in
from pg_class a, pg_depend b, pg_depend c, pg_class d, pg_attribute e with recursive depv(relname, viewoid, depth) as (
where a.oid = b.refobjid select distinct a.relname, a.oid, 1
and b.objid = c.objid from pg_class a, pg_depend b, pg_depend c, pg_class d, pg_attribute e
and b.refobjid <> c.refobjid where a.oid = b.refobjid
and b.deptype = 'n' and b.objid = c.objid
and c.refobjid = d.oid and b.refobjid <> c.refobjid
and d.relname = lower(tablename) and b.deptype = 'n'
and d.relkind = 'r' and c.refobjid = d.oid
and d.oid = e.attrelid and d.relname = lower(tablename)
and e.attname = lower(columnname) and d.relkind = 'r'
and c.refobjsubid = e.attnum and d.oid = e.attrelid
and a.relkind = 'v' and e.attname = lower(columnname)
loop and c.refobjsubid = e.attnum
i := i + 1; and a.relkind = 'v'
viewtext[i] := pg_get_viewdef(v.oid); union all
viewname[i] := v.relname; select distinct dependee.relname, dependee.oid, depv.depth+1
end loop; from pg_depend
if i > 0 then join pg_rewrite on pg_depend.objid = pg_rewrite.oid
begin join pg_class as dependee on pg_rewrite.ev_class = dependee.oid
for j in 1 .. i loop join pg_class as dependent on pg_depend.refobjid = dependent.oid
command := 'drop view ' || viewname[j]; join pg_attribute ON pg_depend.refobjid = pg_attribute.attrelid and pg_depend.refobjsubid = pg_attribute.attnum and pg_attribute.attnum > 0
execute command; join depv on dependent.relname = depv.relname
dropviews[j] := viewname[j]; )
end loop; select relname, viewoid, max(depth) from depv group by relname, viewoid order by 3 desc
exception loop
when others then i := i + 1;
i := array_upper(dropviews, 1); viewtext[i] := pg_get_viewdef(v.viewoid);
if i > 0 then viewname[i] := v.relname;
for j in 1 .. i loop end loop;
command := 'create or replace view ' || dropviews[j] || ' as ' || viewtext[j]; if i > 0 then
execute command; begin
end loop; for j in 1 .. i loop
end if; command := 'drop view ' || viewname[j];
raise exception 'Failed to recreate dependent view'; raise notice 'executing -> %', command;
end; execute command;
end if; dropviews[j] := viewname[j];
command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' type ' || lower(datatype); end loop;
execute command; exception
i := array_upper(dropviews, 1); when others then
if i > 0 then i := array_upper(dropviews, 1);
for j in 1 .. i loop if i > 0 then
command := 'create or replace view ' || dropviews[j] || ' as ' || viewtext[j]; for j in reverse i .. 1 loop
execute command; command := 'create or replace view ' || dropviews[j] || ' as ' || viewtext[j];
end loop; raise notice 'executing -> %', 'create view ' || dropviews[j];
end if; execute command;
end if; end loop;
end if; end if;
raise exception 'Failed to recreate dependent view. SQLERRM=%', SQLERRM;
if defaultclause is not null then end;
if lower(defaultclause) = 'null' then end if;
command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' drop default '; command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' type ' || lower(datatype);
else raise notice 'executing -> %', command;
command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' set default ''' || defaultclause || ''''; execute command;
end if; i := array_upper(dropviews, 1);
execute command; if i > 0 then
end if; for j in reverse i .. 1 loop
command := 'create or replace view ' || dropviews[j] || ' as ' || viewtext[j];
if nullclause is not null then raise notice 'executing -> %', 'create view ' || dropviews[j];
if lower(nullclause) = 'not null' then execute command;
command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' set not null'; end loop;
execute command; end if;
elsif lower(nullclause) = 'null' then end if;
command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' drop not null'; end if;
execute command;
end if; if defaultclause is not null then
end if; if lower(defaultclause) = 'null' then
end; command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' drop default ';
$$ language plpgsql; else
command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' set default ''' || defaultclause || '''';
/* end if;
create table t_alter_column raise notice 'executing -> %', command;
( tablename name, columnname name, datatype name, nullclause varchar(10), defaultclause varchar(200)); execute command;
end if;
create rule alter_column_rule as on insert to t_alter_column
do instead select altercolumn(new.tablename, new.columnname, new.datatype, new.nullclause, if nullclause is not null then
new.defaultclause); if lower(nullclause) = 'not null' then
*/ command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' set not null';
raise notice 'executing -> %', command;
execute command;
elsif lower(nullclause) = 'null' then
command := 'alter table ' || lower(tablename) || ' alter column ' || lower(columnname) || ' drop not null';
raise notice 'executing -> %', command;
execute command;
end if;
end if;
end;
$$ language plpgsql;
SELECT register_migration_script('201302081954_IDEMPIERE-621_altercolumn.sql') FROM dual
;

View File

@ -349,8 +349,7 @@ ORDER BY UPPER (columnname), columnname;
UPDATE AD_PROCESS_PARA UPDATE AD_PROCESS_PARA
SET columnname = (SELECT e.columnname SET columnname = (SELECT e.columnname
FROM AD_ELEMENT e FROM AD_ELEMENT e
-- WHERE UPPER (e.columnname) = UPPER (AD_PROCESS_PARA.columnname)) WHERE UPPER (e.columnname) = UPPER (AD_PROCESS_PARA.columnname))
WHERE e.columnname = AD_PROCESS_PARA.columnname) -- Temporary patch Fixed Assets are broking it
WHERE AD_PROCESS_PARA.iscentrallymaintained = 'Y' WHERE AD_PROCESS_PARA.iscentrallymaintained = 'Y'
AND AD_PROCESS_PARA.isactive = 'Y' AND AD_PROCESS_PARA.isactive = 'Y'
AND EXISTS ( AND EXISTS (

View File

@ -104,30 +104,23 @@ public class MTable extends X_AD_Table
MTable retValue = null; MTable retValue = null;
String sql = "SELECT * FROM AD_Table WHERE UPPER(TableName)=?"; String sql = "SELECT * FROM AD_Table WHERE UPPER(TableName)=?";
PreparedStatement pstmt = null; PreparedStatement pstmt = null;
ResultSet rs = null;
try try
{ {
pstmt = DB.prepareStatement (sql, null); pstmt = DB.prepareStatement (sql, null);
pstmt.setString(1, tableName.toUpperCase()); pstmt.setString(1, tableName.toUpperCase());
ResultSet rs = pstmt.executeQuery (); rs = pstmt.executeQuery ();
if (rs.next ()) if (rs.next())
retValue = new MTable (ctx, rs, null); retValue = new MTable (ctx, rs, null);
rs.close ();
pstmt.close ();
pstmt = null;
} }
catch (Exception e) catch (Exception e)
{ {
s_log.log(Level.SEVERE, sql, e); s_log.log(Level.SEVERE, sql, e);
} }
try finally
{ {
if (pstmt != null) DB.close(rs, pstmt);
pstmt.close (); rs = null; pstmt = null;
pstmt = null;
}
catch (Exception e)
{
pstmt = null;
} }
if (retValue != null) if (retValue != null)
@ -229,37 +222,30 @@ public class MTable extends X_AD_Table
return m_columns; return m_columns;
m_columnNameMap = new HashMap<String, Integer>(); m_columnNameMap = new HashMap<String, Integer>();
m_columnIdMap = new HashMap<Integer, Integer>(); m_columnIdMap = new HashMap<Integer, Integer>();
String sql = "SELECT * FROM AD_Column WHERE AD_Table_ID=? ORDER BY ColumnName"; String sql = "SELECT * FROM AD_Column WHERE AD_Table_ID=? AND IsActive='Y' ORDER BY ColumnName";
ArrayList<MColumn> list = new ArrayList<MColumn>(); ArrayList<MColumn> list = new ArrayList<MColumn>();
PreparedStatement pstmt = null; PreparedStatement pstmt = null;
ResultSet rs = null;
try try
{ {
pstmt = DB.prepareStatement (sql, get_TrxName()); pstmt = DB.prepareStatement (sql, get_TrxName());
pstmt.setInt (1, getAD_Table_ID()); pstmt.setInt (1, getAD_Table_ID());
ResultSet rs = pstmt.executeQuery (); rs = pstmt.executeQuery ();
while (rs.next ()) { while (rs.next ()) {
MColumn column = new MColumn (getCtx(), rs, get_TrxName()); MColumn column = new MColumn (getCtx(), rs, get_TrxName());
list.add (column); list.add (column);
m_columnNameMap.put(column.getColumnName().toUpperCase(), list.size() - 1); m_columnNameMap.put(column.getColumnName().toUpperCase(), list.size() - 1);
m_columnIdMap.put(column.getAD_Column_ID(), list.size() - 1); m_columnIdMap.put(column.getAD_Column_ID(), list.size() - 1);
} }
rs.close ();
pstmt.close ();
pstmt = null;
} }
catch (Exception e) catch (Exception e)
{ {
log.log(Level.SEVERE, sql, e); log.log(Level.SEVERE, sql, e);
} }
try finally
{ {
if (pstmt != null) DB.close(rs, pstmt);
pstmt.close (); rs = null; pstmt = null;
pstmt = null;
}
catch (Exception e)
{
pstmt = null;
} }
// //
m_columns = new MColumn[list.size ()]; m_columns = new MColumn[list.size ()];
@ -476,6 +462,7 @@ public class MTable extends X_AD_Table
finally finally
{ {
DB.close(rs, pstmt); DB.close(rs, pstmt);
rs = null; pstmt = null;
} }
return po; return po;
@ -581,21 +568,26 @@ public class MTable extends X_AD_Table
public static int getTable_ID(String tableName) { public static int getTable_ID(String tableName) {
int retValue = 0; int retValue = 0;
String SQL = "SELECT AD_Table_ID FROM AD_Table WHERE tablename = ?"; String SQL = "SELECT AD_Table_ID FROM AD_Table WHERE tablename = ?";
PreparedStatement pstmt = null;
ResultSet rs = null;
try try
{ {
PreparedStatement pstmt = DB.prepareStatement(SQL, null); pstmt = DB.prepareStatement(SQL, null);
pstmt.setString(1, tableName); pstmt.setString(1, tableName);
ResultSet rs = pstmt.executeQuery(); rs = pstmt.executeQuery();
if (rs.next()) if (rs.next())
retValue = rs.getInt(1); retValue = rs.getInt(1);
rs.close();
pstmt.close();
} }
catch (Exception e) catch (Exception e)
{ {
s_log.log(Level.SEVERE, SQL, e); s_log.log(Level.SEVERE, SQL, e);
retValue = -1; retValue = -1;
} }
finally
{
DB.close(rs, pstmt);
rs = null; pstmt = null;
}
return retValue; return retValue;
} }