MYSQL已经装好了, 并建立了名为 storemanagement的database , 而且也添加 了 驱动 但是运行下面代码还是说database名出错,请问该如何解决,谢谢!
package becker;import java.sql.*;public class Database {
public static void main(String argv[]) { 
        Connection con = null; 
        try { 
            // here is the JDBC URL for this database 
         String url ="jdbc:mysql://localhost:3306/storemanagement ?"+"user=root&password=backer&useUnicode=true&characterEncoding=gbk";  
            // more on what the Statement and ResultSet classes do later 
            Statement stmt; 
            ResultSet rs;  
            // either pass this as a property, i.e. 
            // -Djdbc.drivers=org.gjt.mm.mysql.Driver 
            // or load it here as we are doing in this example 
            try {
             Class.forName("com.mysql.jdbc.Driver"); 
             
                
} catch (Exception e) {
// TODO: handle exception
System.out.println("e");
}
            
            // here is where the connection is made    
            con = DriverManager.getConnection(url);  
        } 
        catch( SQLException e ) { 
            e.printStackTrace(  ); 
        } 
        finally { 
            if( con != null ) { 
                try { 
                 System.out.println("Collection succeeded!");
                
                 con.close(  ); } 
                catch( Exception e ) { } 
            } 
        } 
    }
}
出错信息是:(确定database name 名没有错)
com.mysql.jdbc.exceptions.MySQLSyntaxErrorException: Incorrect database name 'storemanagement '
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:936)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:2985)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:885)
at com.mysql.jdbc.MysqlIO.secureAuth411(MysqlIO.java:3421)
at com.mysql.jdbc.MysqlIO.doHandshake(MysqlIO.java:1247)
at com.mysql.jdbc.Connection.createNewIO(Connection.java:2748)
at com.mysql.jdbc.Connection.<init>(Connection.java:1553)
at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:285)
at java.sql.DriverManager.getConnection(DriverManager.java:525)
at java.sql.DriverManager.getConnection(DriverManager.java:193)
at becker.Database.main(Database.java:27)

解决方案 »

  1.   

    : Incorrect database name 'storemanagement '整个错误还不明显吗?
      

  2.   

    参考一下如下写法:address=192.168.0.xx
    port=3306/dbname?jdbcCompliantTruncation=false&useUnicode=true&characterEncoding=GBKwww.MySQLpub.com 
    MySQLpub - 专业MySQL社区,MySQL,MySQL技术,MySQL中文,MySQL论坛
      

  3.   

    二楼的方法不是很清楚,address 和 port 该在程序哪里设置呢?。
    1.添加的那个database的驱动从工程属性里把 那个 jar文件导入就可以了是吧,其他还有
    哪里需要设置下
    2mysql的数据库server 和 client 服务需要手动打开吗 ,需要类似于windows那样官方火
    墙吗