java不能为空_java中的“表名模式不能为NULL或为空”

当我想从databaseMetaData获取表时,我收到此错误:

Exception in thread "main" java.sql.sqlException: Table name pattern can not be NULL or empty.

at com.MysqL.cj.jdbc.exceptions.sqlError.createsqlException(sqlError.java:545)

at com.MysqL.cj.jdbc.exceptions.sqlError.createsqlException(sqlError.java:513)

at com.MysqL.cj.jdbc.exceptions.sqlError.createsqlException(sqlError.java:505)

at com.MysqL.cj.jdbc.exceptions.sqlError.createsqlException(sqlError.java:479)

at com.MysqL.cj.jdbc.DatabaseMetaData.getTables(DatabaseMetaData.java:3836)

at FindUserTables.main(FindUserTables.java:14)

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)

at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)

at java.lang.reflect.Method.invoke(Method.java:498)

at com.intellij.rt.execution.application.AppMain.main(AppMain.java:147)

这是我的代码,我的jdbc驱动是MysqL-connector-java-6.0.5-bin.jar.发生了什么?

import java.sql.*;

public class FindUserTables {

public static void main(String[] args)

throws sqlException,ClassNotFoundException {

Class.forName("com.MysqL.cj.jdbc.Driver");

System.out.println("Driver loaded");

Connection connection = DriverManager.getConnection("jdbc:MysqL://localhost/javabook ?characterEncoding=utf8&useSSL=false&&serverTimezone=UTC","root","123456");

System.out.println("Database connected");

DatabaseMetaData dbMetaData = connection.getMetaData();

ResultSet rsTables = dbMetaData.getTables(null,null,new String[] {"TABLE"});

System.out.print("User tables: ");

while (rsTables.next())

System.out.print(rsTables.getString("TABLE_NAME") + " ");

connection.close();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值