Sqlserver
 sql >> Base de données >  >> RDS >> Sqlserver

Appeler une procédure stockée avec un paramètre table à partir de Java

Ceci est documenté ici dans le manuel du pilote JDBC. Dans votre cas, vous devriez faire ceci :

try (SQLServerCallableStatement stmt =
    (SQLServerCallableStatement) con.prepareCall("{call test(?)}")) {

    SQLServerDataTable table = new SQLServerDataTable();   
    sourceDataTable.addColumnMetadata("n", java.sql.Types.INTEGER);   

    sourceDataTable.addRow(9);
    sourceDataTable.addRow(12);
    sourceDataTable.addRow(27);
    sourceDataTable.addRow(37);

    stmt.setStructured(1, "dbo.integer_list_tbltype", table);  
}

J'ai également récemment documenté cela dans un article.