JDBC代码没有关问题,但网页上显示不了数据库里的东西咋回事
JDBC代码没问题,但网页上显示不了数据库里的东西怎么回事?
密码是默认的,按理说这JDBC应该没问题啊
数据库也有数据,为什么显示不出来呢?
快没什么分了,分少大大们别介意啊
------解决思路----------------------
网页里显示不了,有可能是你后台的查询语句有问题,也有可能是你查到的数据向页面推送时有问题。
------解决思路----------------------
打断点跟踪一下。
------解决思路----------------------
debug一下了,看看查询到没有
------解决思路----------------------
sql打印出来,看是什么样的 放到数据库执行一下
------解决思路----------------------
有没有异常之类的 或者是你在查询完时就把连接关了
------解决思路----------------------
画断点调试一下 看看具体错误 如果不知道可以把错误信息贴出来
------解决思路----------------------
1.打断点一步一步调试,看是否查询到结果集
2.把sql先放到数据库测试,看能否通过,如果可以,再看看是否是代码里面sql书写错误
3.在页面上获取的时候,是否能获取到值,建议用console.debug打印一下
密码是默认的,按理说这JDBC应该没问题啊
数据库也有数据,为什么显示不出来呢?
快没什么分了,分少大大们别介意啊
package com.yxq.dao;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class DB {
private String className;
private String url;
private String username;
private String password;
private Connection con;
private PreparedStatement pstm;
public DB(){
className="com.mysql.jdbc.Driver";
url="jdbc:mysql://localhost:3306/db_bbs";
username="root";
password="root";
try{
Class.forName(className);
}catch(ClassNotFoundException e){
System.out.println("加载数据库驱动程序失败!");
e.printStackTrace();
}
}
public void getCon(){
try {
con=DriverManager.getConnection(url,username,password);
} catch (SQLException e) {
System.out.println("获取数据库连接失败!");
e.printStackTrace();
}
}
public void doPstm(String sql,Object[] params){
if(sql!=null&&!sql.equals("")){
System.out.println(sql);
getCon();
try {
pstm=con.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);
if(params==null){
params=new Object[0];
}
for(int i=0;i<params.length;i++){
pstm.setObject(i+1,params[i]);
}
pstm.execute();
} catch (SQLException e) {
System.out.println("调用DB类中doPstm方法时出错!");
e.printStackTrace();
}
}
}
public ResultSet getRs(){
try {
return pstm.getResultSet();
} catch (SQLException e) {
System.out.println("DB类中的getRs()方法出错!");
e.printStackTrace();
return null;
}
}
public int getUpdate(){
try {
return pstm.getUpdateCount();
} catch (SQLException e) {
e.printStackTrace();
return -1;
}
}
public void closed(){
try{
if(pstm!=null)
pstm.close();
}catch(Exception e){
System.out.println("关闭pstm对象失败!");
}
try{
if(con!=null)
con.close();
}catch(Exception e){
System.out.println("关闭con对象失败!");
}
}
}
------解决思路----------------------
网页里显示不了,有可能是你后台的查询语句有问题,也有可能是你查到的数据向页面推送时有问题。
------解决思路----------------------
打断点跟踪一下。
------解决思路----------------------
debug一下了,看看查询到没有
------解决思路----------------------
sql打印出来,看是什么样的 放到数据库执行一下
------解决思路----------------------
有没有异常之类的 或者是你在查询完时就把连接关了
------解决思路----------------------
画断点调试一下 看看具体错误 如果不知道可以把错误信息贴出来
------解决思路----------------------
1.打断点一步一步调试,看是否查询到结果集
2.把sql先放到数据库测试,看能否通过,如果可以,再看看是否是代码里面sql书写错误
3.在页面上获取的时候,是否能获取到值,建议用console.debug打印一下