如何在循环内相应地在数据库列中存储数据

时间:2015-10-31 11:38:58

标签: java jsp vector db2

我在向量表中有一个项目列表,但项目大小可能有不同的大小,我如何根据项目编号相应地将这些项目存储在数据库列中。示例:我有[apple,red,24]的列表项我希望通过使用循环将此项目相应地存储在数据库列value1= applevalue2=redvalue3=24中?下面是当前的示例代码和数据库列。

数据库设计的例子

VALUE1 | VALUE2 | VALUE3 | VALUE4 |值5

jsp文件

    for(int i =0; i <2; i++)
        {

            Vector vTables = (Vector)session.getAttribute("SES_VALUE"+i); 
            //first vector list [[apple,red,5],[orange,orange,3]]
            //second vector list [[apple,red,5,big],[orange,orange,4,small]]

                for(int k = 0; k < vTables.size(); k++) 
                { 

                    Vector vTemp2           = (Vector) vTables.elementAt(i); 
                   //first loop vTemp2 list [[apple,red,5],[orange,orange,3]] 

                        DB_BS.makeConnection();
                        iRowAffected = DB_BS.insert_table_value(vTemp2);
                        DB_BS.takeDown();   
                }

        }

java文件 - 暂时停留在此部分

public int insert_table_value(Vector vtTable)throws Exception 
{
    //vtTable item will be  [[apple,red,5],[orange,orange,3]] 

    for(int k = 1; k <= vtTable.size(); k++) 
    { 
        //in this sValue will get each items from the vtTable
        String sValue           = (String) vtTable.elementAt(k); 

       //how to write an sql query at here??  
       //what i plan to do is, if sValue have 3 item, it will store the value in database per columns accodingly
        String myQuery = "INSERT INTO TB_BS_VALUE ( ) VALUES ( )"; 

        pstmt2 = new PreparedStatementLogable(myConn, myQuery);
        pstmt2.setString(k, sValue);

        myQuery = pstmt2.toString();
        pstmt = myConn.prepareStatement(myQuery);
        RowsAffected = pstmt.executeUpdate();

        if (RowsAffected > 0) 
            insertSQLLog("SQL", myQuery, "", "", "", "");
    }
    return RowsAffected;
}

1 个答案:

答案 0 :(得分:0)

字符串sValue是一个字符串,所以首先应该将其拆分(根据你的评论“,”)

String[] result = sValue.split(",");

然后你可以做

String columns = "";
String values = "";

for (int i = 0; i <= result.size(); i++) {
   columns += "VALUE" + (i+1) +",";
   values+="?,";
}

// get rid of trailing ,
columns = b.replace(columns.lastIndexOf(","), columns.lastIndexOf(",") + 1,""); 
values = b.replace(values.lastIndexOf(","), values.lastIndexOf(",") + 1,"");

String myQuery = "INSERT INTO TB_BS_VALUE ("+columns+") VALUES ("+values+")"; 

pstmt = new PreparedStatementLogable(myConn, myQuery);

for (int i = 0; i <= result.size(); i++) {
    pstmt.setString(i, result[i]);
}

这两个for循环可能会折叠成一个,不确定这个想法,并且不能尝试atm。

请注意

RowsAffected = pstmt.executeUpdate(); 

不应该编译,应该是

int rowsAffected = pstmt.executeUpdate();