24小时热门版块排行榜    

查看: 1655  |  回复: 9

楚明娟

新虫 (小有名气)

[求助] 大家好,我现在遇到了一个问题,请大家帮帮忙! 已有1人参与

package Water;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
//import java.util.Scanner;


public class QueryDesc {



        public static List<UserVo> showUser() throws ClassNotFoundException {


                Connection conn = null;
                Statement stmt = null;
                ResultSet rs = null;
                List<UserVo> list = new ArrayList<UserVo>();//声明一个List集合,用于存放查询出的数据

                try {


           // String Str=" SELECT '%s' FROM MONTHAVERAGE ";
                   // String.format(Str,M);          // 格式化字符串


                        conn = JDBC_Connection.getConnection();// 连接数据库
                        stmt = conn.createStatement();// 建立Statement对象;
            rs = stmt.executeQuery("SELECT 一 FROM MONTHAVERAGE " );

                                while(rs.next())// 结果集存在,则进行循环遍历
                                {

                                        UserVo userVo = new UserVo();
                                        userVo.setDD(rs.getInt("一");
                                        list.add(userVo);

                                }

                     }catch (SQLException e) {
                                 // TODO Auto-generated catch block
                                 e.printStackTrace();
                     }finally{
                               JDBC_Connection.free(rs, conn, stmt);// 关闭连接
                       }
                return list;
        }

大家好,我想知道怎样将 rs = stmt.executeQuery("SELECT 一 FROM MONTHAVERAGE " );这一句中所选的那个列名“一”变成变量,在以上的程序中我要加入一段什么样的代码来实现呢?谢谢大家!
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

me_yu

木虫 (正式写手)

为什么要这么做呢?

[ 发自小木虫客户端 ]
听,寂静的夜里,田野里蛙声和虫鸣,好不欢快!
2楼2014-05-12 19:20:36
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

libralibra

至尊木虫 (著名写手)

骠骑将军

【答案】应助回帖

★ ★ ★ ★ ★
感谢参与,应助指数 +1
楚明娟: 金币+5, 有帮助, 谢谢您! 2014-07-14 10:00:26
CODE:
String name = "--";
String sql_str = "SELECT "+name+" FROM MONTHAVERAGE";
rs = stmt.executeQuery(sql_str);

matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
3楼2014-05-12 19:23:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

楚明娟

新虫 (小有名气)

引用回帖:
2楼: Originally posted by me_yu at 2014-05-12 19:20:36
为什么要这么做呢?

因为我想计算12个月中的任何一个月都是由我可以掌控的。。
4楼2014-05-13 08:28:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

楚明娟

新虫 (小有名气)

引用回帖:
3楼: Originally posted by libralibra at 2014-05-12 19:23:05
String name = "--";
String sql_str = "SELECT "+name+" FROM MONTHAVERAGE";
rs = stmt.executeQuery(sql_str);

您好,麻烦您了,我把程序按您的提示改了之后如下:
public class QueryDesc {



        public static List<UserVo> showUser(String M) throws ClassNotFoundException {


                Connection conn = null;
                Statement stmt = null;
                ResultSet rs = null;
                List<UserVo> list = new ArrayList<UserVo>();//声明一个List集合,用于存放查询出的数据

                try {


           // String Str=" SELECT '%s' FROM MONTHAVERAGE ";
                   // String.format(Str,M);          // 格式化字符串


                        conn = JDBC_Connection.getConnection();// 连接数据库
                        stmt = conn.createStatement();// 建立Statement对象;
                        String name="M";
                        String sql_str = "SELECT "+name+" FROM MONTHAVERAGE";
                        rs = stmt.executeQuery(sql_str);
            //rs = stmt.executeQuery("SELECT 一 FROM MONTHAVERAGE ";

                                while(rs.next())// 结果集存在,则进行循环遍历
                                {

                                        UserVo userVo = new UserVo();
                                        userVo.setDD(rs.getInt("一");
                                        list.add(userVo);

                                }

                     }catch (SQLException e) {
                                 // TODO Auto-generated catch block
                                 e.printStackTrace();
                     }finally{
                               JDBC_Connection.free(rs, conn, stmt);// 关闭连接
                       }
                return list;
        }

                public static void main(String[] args) throws ClassNotFoundException {
                        System.out.print("请输入要计算的月份:";
                        Scanner scanner=new Scanner(System.in);
                        String str=scanner.next();


                        List<UserVo> list=QueryDesc.showUser(str);//调用查询方法
                        //如果list集合不为空,则循环遍历打印出所有的信息
                        if(list!=null){
                                System.out.print("十二";
                                System.out.println();
                                for (int j = 0; j < list.size(); j++) {

                                        System.out.print(list.get(j).getDD()+"\t";
                                        System.out.println();
                                }
                        }



        }

}

其中public static List<UserVo> showUser(String M)这一句加了一个String M;
然后就是String name="M";
                        String sql_str = "SELECT "+name+" FROM MONTHAVERAGE";
                        rs = stmt.executeQuery(sql_str);按您说的修改了,
最后加了一段:public static void main(String[] args) throws ClassNotFoundException {
                        System.out.print("请输入要计算的月份:";
                        Scanner scanner=new Scanner(System.in);
                        String str=scanner.next();


                        List<UserVo> list=QueryDesc.showUser(str);//调用查询方法
                        //如果list集合不为空,则循环遍历打印出所有的信息
                        if(list!=null){
                                System.out.print("十二";
                                System.out.println();
                                for (int j = 0; j < list.size(); j++) {

                                        System.out.print(list.get(j).getDD()+"\t";
                                        System.out.println();
                                }
                        }



        }

}
这个,可是结果显示  : ORA-00904: "M": 标识符无效
请问是我修改的哪里有问题吗?谢谢您!
5楼2014-05-13 08:41:14
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

me_yu

木虫 (正式写手)

引用回帖:
5楼: Originally posted by 楚明娟 at 2014-05-13 08:41:14
您好,麻烦您了,我把程序按您的提示改了之后如下:
public class QueryDesc {



        public static List<UserVo> showUser(String M) throws ClassNotFoundException {


                Connection conn = null;
...

暈死,怎麼字符串的拼接都還那麼生疏啊,把基礎知識再過一遍吧
showUser(String M)  方法參數 M 就是個變量了
方法內部可以直接用
String sql_str = "SELECT "+M+" FROM MONTHAVERAGE";
你再定義個 String name = "M";
-----------------------------------------------------------------------------------------------------------------------------------------------------
String name="M";
String sql_str = "SELECT "+name+" FROM MONTHAVERAGE";
你這麼寫 最後不就的字符串不就成了  "SELECT M FROM MONTHAVERAGE"; 你表裡沒有 M 列 肯定報錯啊
可以用 System.out.println(sql_str);  查看字符串拼接的結果
听,寂静的夜里,田野里蛙声和虫鸣,好不欢快!
6楼2014-05-13 12:59:52
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

楚明娟

新虫 (小有名气)

引用回帖:
6楼: Originally posted by me_yu at 2014-05-13 12:59:52
暈死,怎麼字符串的拼接都還那麼生疏啊,把基礎知識再過一遍吧
showUser(String M)  方法參數 M 就是個變量了
方法內部可以直接用
String sql_str = "SELECT "+M+" FROM MONTHAVERAGE";
...

那我想请问:
while(rs.next())// 结果集存在,则进行循环遍历
                                {

                                        UserVo userVo = new UserVo();
                                        userVo.setDD(rs.getInt("+M+");
                                        list.add(userVo);

                                }
刚刚上边的这段程序其中一句userVo.setDD(rs.getInt("+M+")里边的+M+必须与select的那个列名保持一致,那这样又怎样变成变量呢?
刚开始接触,不好意思,麻烦您了!
7楼2014-05-13 15:17:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

me_yu

木虫 (正式写手)

???????:
7?: Originally posted by ?????? at 2014-05-13 15:17:05
???????????
while(rs.next())// ??????????????????????
                                {

                                        UserVo userVo = new UserVo();
                                        userVo.setDD(rs.getInt("+M+");
                                        list.add(userVo);

                                }
????????? ...

public class QueryDesc {
        public static List<UserVo> showUser(String M) throws ClassNotFoundException {
                Connection conn = null;
                Statement stmt = null;
                ResultSet rs = null;
                List<UserVo> list = new ArrayList<UserVo>();
                try {
                        conn = JDBC_Connection.getConnection();
                        stmt = conn.createStatement();
                        //String name="M"; ????@???
                        String sql_str = "SELECT "+M+" FROM MONTHAVERAGE";//?????? name ??? M
                        System.out.println(sql_str);//???????????????????Z????????_
                        rs = stmt.executeQuery(sql_str);
                                while(rs.next())
                                {
                                    UserVo userVo = new UserVo();
                                    userVo.setDD(rs.getInt(M));//????? M
                                    list.add(userVo);
                                }
                     }catch (SQLException e) {
                                 e.printStackTrace();
                     }finally{
                               JDBC_Connection.free(rs, conn, stmt);
                       }
                return list;
        }

    public static void main(String[] args) throws ClassNotFoundException {
            System.out.print("enter month :";
            Scanner scanner=new Scanner(System.in);
            String str=scanner.next();
            List<UserVo> list=QueryDesc.showUser(str);
            if(list!=null){
                    System.out.print("???";
                    System.out.println();
                    for (int j = 0; j < list.size(); j++) {
                            System.out.println(list.get(j).getDD()+"\t";
                    }
            }
        }
}

??????????????????????@????????

» 本帖已获得的红花(最新10朵)

听,寂静的夜里,田野里蛙声和虫鸣,好不欢快!
8楼2014-05-13 16:28:06
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

楚明娟

新虫 (小有名气)

送红花一朵
引用回帖:
8楼: Originally posted by me_yu at 2014-05-13 16:28:06
public class QueryDesc {
        public static List<UserVo> showUser(String M) throws ClassNotFoundException {
                Connection conn = null;
                Statement stmt = null; ...

谢谢您!谢谢您!真的达到目的了耶!
9楼2014-05-13 17:34:31
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

楚明娟

新虫 (小有名气)

送红花一朵
引用回帖:
8楼: Originally posted by me_yu at 2014-05-13 16:28:06
public class QueryDesc {
        public static List<UserVo> showUser(String M) throws ClassNotFoundException {
                Connection conn = null;
                Statement stmt = null; ...

非常感谢!
10楼2014-07-14 09:59:35
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 楚明娟 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 302求调剂 +3 小贾同学123 2026-03-15 5/250 2026-03-16 20:39 by zhq0425
[考研] 环境工程调剂 +6 大可digkids 2026-03-16 6/300 2026-03-16 17:16 by barlinike
[考研] 274求调剂 +4 时间点 2026-03-13 4/200 2026-03-15 15:29 by Rambo13
[考研] 材料与化工(0856)304求B区调剂 +7 邱gl 2026-03-10 11/550 2026-03-14 12:18 by 邱gl
[考研] 材料080500调剂求收留 +3 一颗meteor 2026-03-13 3/150 2026-03-14 10:54 by peike
[考研] 学硕285求调剂 +13 Wisjxn 2026-03-12 46/2300 2026-03-14 10:33 by JourneyLucky
[考研] 271求调剂 +10 生如夏花… 2026-03-11 10/500 2026-03-14 00:35 by 卖报员小雨
[考研] 一志愿华中农业大学071010,总分三百二,求调剂 +3 困困困困坤坤 2026-03-10 3/150 2026-03-14 00:35 by JourneyLucky
[考研] 26考研调剂 +3 ying123. 2026-03-10 3/150 2026-03-14 00:18 by JourneyLucky
[考研] 材料工程,326分,求调剂 +6 KRSLSR 2026-03-10 6/300 2026-03-13 23:47 by JourneyLucky
[考研] 279求调剂 +3 Dizzy123@ 2026-03-10 3/150 2026-03-13 23:02 by JourneyLucky
[考研] 308求调剂 +5 是Lupa啊 2026-03-11 5/250 2026-03-13 22:13 by JourneyLucky
[考研] (081700)化学工程与技术-298分求调剂 +12 11啦啦啦 2026-03-11 35/1750 2026-03-13 21:25 by JourneyLucky
[考研] 332求调剂 +3 Zz版 2026-03-13 3/150 2026-03-13 20:36 by 18595523086
[考研] 材料工程调剂 +4 咪咪空空 2026-03-11 4/200 2026-03-13 19:57 by JourneyLucky
[考研] 求调剂 +7 18880831720 2026-03-11 7/350 2026-03-13 16:10 by JourneyLucky
[考博] 26读博 +4 Rui135246 2026-03-12 10/500 2026-03-13 07:15 by gaobiao
[考研] 081200-11408-276学硕求调剂 +3 崔wj 2026-03-12 4/200 2026-03-12 19:33 by 求调剂zz
[考博] 读博申请 +5 感dd 2026-03-10 7/350 2026-03-11 17:02 by QGZDSYS
[考研] 大连大学化学专业研究生调剂 +3 琪久. 2026-03-10 8/400 2026-03-11 10:02 by 琪久.
信息提示
请填处理意见