当前位置:编程学习 > JAVA >>

求助!!使用Commons DbUtils 向SQLserver2008中的表插入数据出错。

小弟刚开始学Java,各位大哥大姐指点一二,不胜感谢!!!
注:已在SQLSERVER2008中创建相应的表。
代码如下:
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

import org.apache.commons.dbutils.DbUtils;
import org.apache.commons.dbutils.QueryRunner;

public class QueryRunnerTest{
private static String URL="jdbc:sqlserver://localhost:1433;databaseName=mr";
private static String DRIVER="com.microsoft.sqlserver.jdbc.SQLServerDriver";
private static String USERNAME="sa";
private static String PASSWORD="07013638";
private static Connection conn;

public static Connection getConnection(){
try {
DbUtils.loadDriver(DRIVER);
conn=DriverManager.getConnection(URL, USERNAME, PASSWORD);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return conn;
}

public static int operate(String sql, Object...params){
int result=0;
QueryRunner runner=new QueryRunner();
try {
result=runner.update(getConnection(), sql, params);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
DbUtils.closeQuietly(conn);
}
return result;
}

public static void main(String[] args){
String sql="insert users(username, password) values(?,?)";
Object[] params={"HJ", "07013638"};
operate(sql, params);
}
}

错误异常如下:
java.sql.SQLException: com.microsoft.sqlserver.jdbc.SQLServerException: 无法识别元数据的表 insert users(username, password) values(?,?)。 Query: insert users(username, password) values(?,?) Parameters: [HuJian, 07013638]
at org.apache.commons.dbutils.AbstractQueryRunner.rethrow(AbstractQueryRunner.java:363)
at org.apache.commons.dbutils.QueryRunner.update(QueryRunner.java:490)
at org.apache.commons.dbutils.QueryRunner.update(QueryRunner.java:403)
at no10.QueryRunnerTest.operate(QueryRunnerTest.java:32)
at no10.QueryRunnerTest.main(QueryRunnerTest.java:45)
--------------------编程问答-------------------- --------------------编程问答-------------------- 除 --------------------编程问答-------------------- java.sql.SQLException: com.microsoft.sqlserver.jdbc.SQLServerException: 无法识别元数据的表
我也遇到了同样的问题。 --------------------编程问答--------------------
引用 1 楼 AWUSOFT 的回复:

            insert users(username, password) values(?,?)




==>insert into users(username, password) values(?,?)


+1用标准的sql试试! --------------------编程问答-------------------- 检查sql语句,然后你看看表列名是否正确 ! --------------------编程问答-------------------- 对于sqlserver的办法是,在sqlserver的面板里面去拼接你的sql语句。
补充:Java ,  Java SE
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,