怎么拼这个sql语句

gryes 2006-01-17 10:12:18
向数据库中插入数据,从Hashtable中取道字段名及值后怎么拼sql语句呢,如果字段的个数也是不定的,怎么实现呢,谢谢!!!!
如 ID NAME
1 A


String key ;
String v = null;
Enumeration e = dbParam.keys();
while (e.hasMoreElements()) { //这样只能是一个字段操作
key = (String) e.nextElement();

k = k.toString();

v = dbParam.get(key).toString();

}

StringBuffer sql = new StringBuffer();
sql.append(" insert");
sql.append(" into ");
sql.append(tableName);
sql.append("(");
sql.append(ziduan);
sql.append(")");
sql.append("values");
sql.append("(");
sql.append("'");
sql.append(values);
sql.append("'");
sql.append(")");

stmt.executeUpdate(sql.toString());
...全文
91 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
pdvv 2006-01-18
  • 打赏
  • 举报
回复
key代表字段名,value代表对应的值。
while(…){
sql1 = insert into table1 (key1, key2,…)
sql2 = values (value1, value2,…)
}
sql = sql1 + sql2;
masse 2006-01-18
  • 打赏
  • 举报
回复
String columns = "";
String values="";

Enumeration e = dbParam.keys();
while (e.hasMoreElements()) { //这样只能是一个字段操作
key = (String) e.nextElement();
k = key.toString(); // 这里是字段名
v = dbParam.get(key).toString(); // 这里是值

if(columns.length()>0) columns+=",";
columns += k;

if(values.length()>0)values+=",";
values += ("'"+v+"'");
}

// 此时 columns就是: ID,Name
// 此时 values就是 : '1','A'

String sql = "Insert into mTable("+columns+")+" values(" + values + ")";

stmt.executeUpdate(sql.toString());

这种方法要注意单引号的转义


62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧