sql >> Databáze >  >> RDS >> Mysql

Jak vložit hodnoty do tabulky s dynamickými sloupci Jdbc/Mysql

K získání názvů sloupců můžete také použít databázová metadata. To má tu výhodu, že ani nepotřebujete znát názvy sloupců, ale jsou načteny dynamicky ve vašem kódu.

public static List<String> getColumns(String tableName, String schemaName) throws  SQLException{

    ResultSet rs=null;

    ResultSetMetaData rsmd=null;
    PreparedStatement stmt=null;
    List<String> columnNames =null;
    String qualifiedName = (schemaName!=null&&!schemaName.isEmpty())?(schemaName+"."+tableName):tableName;
    try{
        stmt=conn.prepareStatement("select * from "+qualifiedName+" where 0=1");
        rs=stmt.executeQuery();//you'll get an empty ResultSet but you'll still get the metadata
        rsmd=rs.getMetaData();
        columnNames = new ArrayList<String>(); 
        for(int i=1;i<=rsmd.getColumnCount();i++)
            columnNames.add(rsmd.getColumnLabel(i));    
    }catch(SQLException e){
        throw e;//or log it
    }
    finally{
        if(rs!=null)
            try {
                rs.close();
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                throw e
            }
        if(stmt!=null)
            try {
                stmt.close();
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                throw e
            }
    }
    return columnNames;
}

Jakmile budete mít názvy sloupců, můžete je použít jako obvykle (List.size() samozřejmě udává počet sloupců).

AKTUALIZACE:

//I will assume that your values (data to be inserted) is a List of Object types and that it is already populated



List<Object> data = new ArrayList<>();
    //you will populate this list

    //getting the column names
    List<String> columnNames = getColumns("MyTable", "MyDB");

    String insertColumns = ""; 
    String insertValues = "";

    if(columnNames != null && columnNames.size() > 0){
        insertColumns += columnNames.get(0);
        insertValues += "?";
    }


    for(int i = 1; i < columnNames.size();i++){
      insertColumns += ", " + columnNames.get(i) ;
      insertValues += "?";
    }

    String insertSql = "INSERT INTO MyDB.MyTable (" + insertColumns + ") values(" + insertValues + ")"; 

    try{
    PrepareStatement ps = conn.prepareStatement(insertSql);

    for(Object o : data){
     ps.setObject(o); //you must pass objects of correct type
    }
    ps.execute(); //this inserts your data
    }catch(SQLException sqle){
      //do something with it
    }

Tento kód předpokládá, že předáte objekty správných typů metodě PreparedStatement.setObject(Object o). Je také možné načíst typy sloupců pomocí informací z metadatabáze a poté tyto informace použít k vynucení kontroly typu, ale to by váš kód značně zkomplikovalo



  1. Deset tipů, jak dosáhnout zabezpečení MySQL a MariaDB

  2. SQL - Jak najít nejvyšší číslo ve sloupci?

  3. INNER JOIN stejný stůl

  4. Chyba při použití tabulky INSERT INTO ON DUPLICATE KEY pomocí pole smyčky for