mirror of
https://github.com/gnosygnu/xowa.git
synced 2024-10-27 20:34:16 +00:00
78 lines
3.1 KiB
Java
78 lines
3.1 KiB
Java
/*
|
|
XOWA: the XOWA Offline Wiki Application
|
|
Copyright (C) 2012 gnosygnu@gmail.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 <http://www.gnu.org/licenses/>.
|
|
*/
|
|
package gplx.dbs; import gplx.*;
|
|
import gplx.dbs.metas.*;
|
|
public class Db_conn_utl {
|
|
public static Db_conn Conn__new(String url_rel) {
|
|
Db_conn_bldr.Instance.Reg_default_mem();
|
|
return Db_conn_bldr.Instance.Get_or_new(Io_url_.mem_fil_("mem/" + url_rel)).Conn();
|
|
}
|
|
public static void Tbl__new(Db_conn conn, String tbl, Dbmeta_fld_itm[] flds, Object[]... rows) {
|
|
conn.Meta_tbl_create(Dbmeta_tbl_itm.New(tbl, flds));
|
|
int rows_len = rows.length;
|
|
Db_stmt stmt = conn.Stmt_insert(tbl, Dbmeta_fld_itm.To_str_ary(flds));
|
|
for (int i = 0; i < rows_len; ++i) {
|
|
Object[] row = rows[i];
|
|
int dat_len = row.length;
|
|
stmt.Clear();
|
|
for (int j = 0; j < dat_len; ++j) {
|
|
Dbmeta_fld_itm fld = flds[j];
|
|
String fld_name = fld.Name();
|
|
Object val = row[j];
|
|
switch (fld.Type().Tid_ansi()) {
|
|
case Dbmeta_fld_tid.Tid__bool: stmt.Val_bool_as_byte (fld_name, Bool_.cast(val)); break;
|
|
case Dbmeta_fld_tid.Tid__byte: stmt.Val_byte (fld_name, Byte_.cast(val)); break;
|
|
case Dbmeta_fld_tid.Tid__int: stmt.Val_int (fld_name, Int_.cast(val)); break;
|
|
case Dbmeta_fld_tid.Tid__long: stmt.Val_long (fld_name, Long_.cast(val)); break;
|
|
case Dbmeta_fld_tid.Tid__float: stmt.Val_float (fld_name, Float_.cast(val)); break;
|
|
case Dbmeta_fld_tid.Tid__double: stmt.Val_double (fld_name, Double_.cast(val)); break;
|
|
case Dbmeta_fld_tid.Tid__str: stmt.Val_str (fld_name, String_.cast(val)); break;
|
|
case Dbmeta_fld_tid.Tid__bry: stmt.Val_bry (fld_name, Bry_.cast(val)); break;
|
|
}
|
|
}
|
|
stmt.Exec_insert();
|
|
}
|
|
}
|
|
public static void Insert(Db_conn conn, String tbl_name, String[] flds, Object[]... rows) {
|
|
Db_stmt stmt = Db_stmt_.new_insert_(conn, tbl_name, flds);
|
|
int flds_len = flds.length;
|
|
int rows_len = rows.length;
|
|
for (int i = 0; i < rows_len; ++i) {
|
|
Object[] row = rows[i];
|
|
stmt.Clear();
|
|
for (int j = 0; j < flds_len; ++j)
|
|
Db_stmt_.Val_by_obj(stmt, flds[j], row[j]);
|
|
stmt.Exec_insert();
|
|
}
|
|
}
|
|
public static Object[][] Select(Db_conn conn, Db_qry qry) {
|
|
List_adp rv = List_adp_.New();
|
|
Db_rdr rdr = conn.Stmt_new(qry).Exec_select__rls_auto();
|
|
try {
|
|
while (rdr.Move_next()) {
|
|
int fld_len = rdr.Fld_len();
|
|
Object[] row = new Object[fld_len];
|
|
for (int i = 0; i < fld_len; ++i)
|
|
row[i] = rdr.Read_at(i);
|
|
rv.Add(row);
|
|
}
|
|
} finally {rdr.Rls();}
|
|
return (Object[][])rv.To_ary_and_clear(Object[].class);
|
|
}
|
|
}
|