先说一说的,我的系统还有MYSQL的JDBC都已经配置好了、、、
系统变量:
CLSSPATH=D:\progarm two\mysql-connector-java-5.0.5\mysql-connector-java-5.0.5-bin.jar;C:\Program Files\Java\jdk1.6.0_12\bin;用户变量为:
classpath=.;.;d:\PROGAR~2\JMF\lib\sound.jar;d:\PROGAR~2\JMF\lib\jmf.jar;d:\PROGAR~2\JMF\lib;%JAVA_HOME%\lib\tools.jar;%JAVA_HOME%\lib\dt.jar;.;%JAVA_HOME%\lib;%JAVA_HOME%\lib\tools.jar;D:\progarm two\mysql-connector-java-5.0.5\mysql-connector-java-5.0.5-bin.jar;驱动的位置:
D:\progarm two\mysql-connector-java-5.0.5\mysql-connector-java-5.0.5.jar;配置的ODBC:Date Source Name :Mysql_Test
Databese:test
代码为:public class Main {
    public static void main(String[] args) {
         //驱动程序名
          String driver = "com.mysql.jdbc.Driver";         //URL指向要访问的数据库名字:
          String url = "jdbc:mysql://localhost/Mysql_test";          //Mysql配置用户名:
          String user = "root";
             
         //Mysql配置密码:
          String password = "LJZKID";            try {
            //加载驱动程序
             Class.forName(driver);
            } catch (ClassNotFoundException ex) {
            Logger.getLogger(Main.class.getName()).log(Level.SEVERE, null, ex);
        }
            
        try {            //连接数据库
            Connection con = DriverManager.getConnection(url, user, password);            if(!con.isClosed())
                 System.out.println("Succeeded connecting to the Database!");            //statement用来执行SQL语言
            Statement st = con.createStatement();            //要执行的SQL语言
            String sql = "select * from tablename";            //结果集
            ResultSet rs =  (ResultSet)(Statement) st.executeQuery(sql);            while( rs.next() ) {
                //选择col这列数据
                String name = rs.getString("col1");
                System.out.println("name=" +name );
            }
            rs.close();
            con.close();
        } catch (SQLException ex) {
            Logger.getLogger(Main.class.getName()).log(Level.SEVERE, null, ex);
        }    }}

解决方案 »

  1.   

    不清楚你现在是报什么错误,你把异常贴出来看看
    从你代码import的东西也不太清楚,里面ResultSet rs =  (ResultSet)(Statement) st.executeQuery(sql)是完全没有必要强制类型转换
    直接ResultSet rs =  st.executeQuery(sql)就OK的你先把异常贴出来,然后import内容也贴出来再讨论吧
      

  2.   

    string url怎么没有端口号呢,看下你的异常的
      

  3.   

    贴出log来
    还有你的端口号怎么没有?例如String url="jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=gbk"; 
      

  4.   


    lz是把后面的一堆通过数据源引用配置了,
    jdbc:mysql://localhost/Mysql_test,Mysql_test是指LZ上面说的数据源.lz这里混淆了吧。。既然用odbc连接数据库了,为什么用的是jdbc的驱动,为什么url还是jdbc的方式?
    用odbc连接mysql,要用odbc驱动,以及url格式你那个也不对把。。你把两种方式混淆使用了
      

  5.   

    如以下odbc连接mysql的代码:1.public static void main(String[] args)   
    2.{   
    3.Connection connection = null;   
    4.Statement statement;    
    5.ResultSet resultSet;   
    6.// 加载驱动程序以连接数据库   
    7.try    
    8.{   
    9.Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");//这个驱动不能是其他的..   
    10.connection = DriverManager.getConnection("jdbc:odbc:user","root","123"); //user是data Source ,root是用   
    11.  
    12.//户名,123是进入mysql的密码   
    13.System.out.println("open easy");   
    14.String query = "Select * from userrole";   
    15.statement = connection.createStatement();    
    16.resultSet = statement.executeQuery( query );    
    17.connection.close();   
    18.System.out.println("close easy");   
    19.  
    20.}   
    21.// 捕获加载驱动程序异常   
    22.catch ( ClassNotFoundException cnfex )    
    23.{   
    24.System.err.println(   
    25."装载 JDBC/ODBC 驱动程序失败。" );   
    26.cnfex.printStackTrace();   
    27.System.exit( 1 ); // terminate program   
    28.}   
    29.// 捕获连接数据库异常   
    30.catch ( SQLException sqlex )    
    31.{   
    32.System.err.println( "无法连接数据库" );   
    33.sqlex.printStackTrace();   
    34.System.exit( 1 ); // terminate program   
    35.}    
    36.catch (Exception e)   
    37.{   
    38.System.out.println(e.toString());   
    39.}