JAVA报return为不兼容类型
我的一个JSP网站,要连接数据库,这是书上的一个Bean文件,编译时最后的return语句报为不兼容类型错误,各位大侠帮看是怎么回事,谢谢了packagelg;impor...
我的一个JSP网站,要连接数据库,这是书上的一个Bean文件,编译时最后的return语句报为不兼容类型错误,各位大侠帮看是怎么回事,谢谢了
package lg;
import java.sql.*;
public class Querybean{
String tableName="";
StringBuffer queryResult;
public Querybean(){
queryResult=new StringBuffer();
try{Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");}
catch(ClassNotFoundException e){
queryResult=new StringBuffer();
queryResult.append(""+e);
}
}
public void setTableName(String s){
tableName=s.trim();
}
public String getTableName(){
return tableName;
}
public String getQueryResult(){
Connection con;
Statement sql;
ResultSet rs;
try{ queryResult.append("<table border=1>");
con=DriverManager.getConnection("jdbc:adbc:a","sa","sa");
DatabaseMetaData metadata=con.getMetaData();
ResultSet rs1=metadata.getColumns(null,null,tableName,null);
int n=0;
queryResult.append("<tr>");
while(rs1.next()){
n++;
String clumnName=rs1.getString(4);
queryResult.append("<tr>"+clumnName+"<tr>");
}
queryResult.append("<tr>");
sql=con.createStatement();
rs=sql.executeQuery("Select * FROM msg");
while(rs.next()){
queryResult.append("<tr>");
for(int k=0;k<=n;k++){
queryResult.append("<tr>"+rs.getString(k)+"<tr>");
}
queryResult.append("<tr>");
}
queryResult.append("</table>");
con.close();
}
catch(SQLException e){
queryResult.append(e);
}
return queryResult;
}
} 展开
package lg;
import java.sql.*;
public class Querybean{
String tableName="";
StringBuffer queryResult;
public Querybean(){
queryResult=new StringBuffer();
try{Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");}
catch(ClassNotFoundException e){
queryResult=new StringBuffer();
queryResult.append(""+e);
}
}
public void setTableName(String s){
tableName=s.trim();
}
public String getTableName(){
return tableName;
}
public String getQueryResult(){
Connection con;
Statement sql;
ResultSet rs;
try{ queryResult.append("<table border=1>");
con=DriverManager.getConnection("jdbc:adbc:a","sa","sa");
DatabaseMetaData metadata=con.getMetaData();
ResultSet rs1=metadata.getColumns(null,null,tableName,null);
int n=0;
queryResult.append("<tr>");
while(rs1.next()){
n++;
String clumnName=rs1.getString(4);
queryResult.append("<tr>"+clumnName+"<tr>");
}
queryResult.append("<tr>");
sql=con.createStatement();
rs=sql.executeQuery("Select * FROM msg");
while(rs.next()){
queryResult.append("<tr>");
for(int k=0;k<=n;k++){
queryResult.append("<tr>"+rs.getString(k)+"<tr>");
}
queryResult.append("<tr>");
}
queryResult.append("</table>");
con.close();
}
catch(SQLException e){
queryResult.append(e);
}
return queryResult;
}
} 展开
展开全部
这个问题其实您自己仔细的看看应该就能发现。
首先看方法定义:肆销
public String getQueryResult();
返裂宽游回值为String类型。
再看这个queryResult的定义:
StringBuffer queryResult;
queryResult域的定义为StringBuffer类。
这样问题就很明显了——返回值类型不对。
解决这个问题,只需要把返回巧晌语句改为:
return queryResult.toString();
这样返回类型就和方法定义一致了(都是String)。
首先看方法定义:肆销
public String getQueryResult();
返裂宽游回值为String类型。
再看这个queryResult的定义:
StringBuffer queryResult;
queryResult域的定义为StringBuffer类。
这样问题就很明显了——返回值类型不对。
解决这个问题,只需要把返回巧晌语句改为:
return queryResult.toString();
这样返回类型就和方法定义一致了(都是String)。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询