The CData JDBC Driver for MySQL implements JDBC standards that enable third-party tools to interoperate, from wizards in IDEs to business intelligence tools. This article shows how to connect to MySQL data with wizards in DBeaver and browse data in the DBeaver GUI.
Create a JDBC Data Source for MySQL Data
Follow the steps below to load the driver JAR in DBeaver.
- Open the DBeaver application and, in the Databases menu, select the Driver Manager option. Click New to open the Create New Driver form.
- In the Driver Name box, enter a user-friendly name for the driver.
- To add the .jar, click Add File.
- In the create new driver dialog that appears, select the cdata.jdbc.mysql.jar file, located in the lib subfolder of the installation directory.
- Click the Find Class button and select the MySQLDriver class from the results. This will automatically fill the Class Name field at the top of the form. The class name for the driver is cdata.jdbc.mysql.MySQLDriver.
- Add jdbc:mysql: in the URL Template field.
DBeaver뿐만 아니라 다른 클라이언트 프로그램, 서비스에서 mysql db 접속을 시도할 때 CLIENTPLUGINAUTH is required 라는 에러가 뜨면서 안되는 경우는 사용중인 mysql-connector가 구버전일 때 발생할 수 있.
Create a Connection to MySQL Data
- Step-by-step guide on how to connect to SQL Server using DBeaver on a Mac. Screenshots included. DBeaver is a database management tool for managing DBs such as MySQL, PostgreSQL, MariaDB, SQLite, Oracle, DB2, SQL Server, Sybase, MS Access, Teradata, Firebird, Derby, etc.
- Pastebin.com is the number one paste tool since 2002. Pastebin is a website where you can store text online for a set period of time.
- DBeaver is a free, universal SQL client that can connect to numerous types of databases-one of which is MySQL. I want to show you how to install and use DBeaver to connect to your remote MySQL.
Follow the steps below to add credentials and other required connection properties.
- In the Databases menu, click New Connection.
- In the Create new connection wizard that results, select the driver.
- On the next page of the wizard, click the driver properties tab.
Enter values for authentication credentials and other properties required to connect to MySQL.
The Server and Port properties must be set to a MySQL server. If IntegratedSecurity is set to false, then User and Password must be set to valid user credentials. Optionally, Database can be set to connect to a specific database. If not set, tables from all databases will be returned.
Built-in Connection String Designer
For assistance in constructing the JDBC URL, use the connection string designer built into the MySQL JDBC Driver. Either double-click the JAR file or execute the jar file from the command-line.
java -jar cdata.jdbc.mysql.jar
Fill in the connection properties and copy the connection string to the clipboard.
Below is a typical connection string:
jdbc:mysql:User=myUser;Password=myPassword;Database=NorthWind;Server=myServer;Port=3306;
Query MySQL Data
You can now query information from the tables exposed by the connection: Right-click a Table and then click Edit Table. The data is available on the Data tab.
- java.sql.SQLNonTransientConnectionException: CLIENT_PLUGIN_AUTH is required
- at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:110)
- at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97)
- at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:89)
- at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:63)
- at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:73)
- at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:79)
- at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:835)
- at com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:455)
- at com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:240)
- at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:199)
- at com.zaxxer.hikari.util.DriverDataSource.getConnection(DriverDataSource.java:136)
- at com.zaxxer.hikari.pool.PoolBase.newConnection(PoolBase.java:369)
- at com.zaxxer.hikari.pool.PoolBase.newPoolEntry(PoolBase.java:198)
- at com.zaxxer.hikari.pool.HikariPool.createPoolEntry(HikariPool.java:467)
- at com.zaxxer.hikari.pool.HikariPool.checkFailFast(HikariPool.java:541)
- at com.zaxxer.hikari.pool.HikariPool.<init>(HikariPool.java:115)
- at com.zaxxer.hikari.HikariDataSource.getConnection(HikariDataSource.java:112)
- at org.hibernate.engine.jdbc.connections.internal.DatasourceConnectionProviderImpl.getConnection(DatasourceConnectionProviderImpl.java:122)
- at org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator$ConnectionProviderJdbcConnectionAccess.obtainConnection(JdbcEnvironmentInitiator.java:180)
- at org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator.initiateService(JdbcEnvironmentInitiator.java:68)
- at org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator.initiateService(JdbcEnvironmentInitiator.java:35)
- at org.hibernate.boot.registry.internal.StandardServiceRegistryImpl.initiateService(StandardServiceRegistryImpl.java:94)
- at org.hibernate.service.internal.AbstractServiceRegistryImpl.createService(AbstractServiceRegistryImpl.java:263)
- at org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:237)
- at org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:214)
- at org.hibernate.id.factory.internal.DefaultIdentifierGeneratorFactory.injectServices(DefaultIdentifierGeneratorFactory.java:152)
- at org.hibernate.service.internal.AbstractServiceRegistryImpl.injectDependencies(AbstractServiceRegistryImpl.java:286)
- at org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:243)
- at org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:214)
- at org.hibernate.boot.internal.InFlightMetadataCollectorImpl.<init>(InFlightMetadataCollectorImpl.java:179)
- at org.hibernate.boot.model.process.spi.MetadataBuildingProcess.complete(MetadataBuildingProcess.java:119)
- at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.metadata(EntityManagerFactoryBuilderImpl.java:904)
- at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:935)
- at org.springframework.orm.jpa.vendor.SpringHibernateJpaPersistenceProvider.createContainerEntityManagerFactory(SpringHibernateJpaPersistenceProvider.java:57)
- at org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean.createNativeEntityManagerFactory(LocalContainerEntityManagerFactoryBean.java:365)
- at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.buildNativeEntityManagerFactory(AbstractEntityManagerFactoryBean.java:390)
- at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.afterPropertiesSet(AbstractEntityManagerFactoryBean.java:377)
- at org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean.afterPropertiesSet(LocalContainerEntityManagerFactoryBean.java:341)
- at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1837)
- at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1774)
- at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:593)
- at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:515)
- at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:320)
- at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
- at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:318)
- at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:199)
- at org.springframework.context.support.AbstractApplicationContext.getBean(AbstractApplicationContext.java:1105)
- at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:867)
- at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:549)
- at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:140)
- at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:742)
- at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:389)
- at org.springframework.boot.SpringApplication.run(SpringApplication.java:311)
- at org.springframework.boot.SpringApplication.run(SpringApplication.java:1213)
- at org.springframework.boot.SpringApplication.run(SpringApplication.java:1202)
- at com.tst.flow.service.Application.main(Application.java:32)
- 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 org.springframework.boot.loader.MainMethodRunner.run(MainMethodRunner.java:47)
- at org.springframework.boot.loader.Launcher.launch(Launcher.java:86)
- at org.springframework.boot.loader.Launcher.launch(Launcher.java:50)
- at org.springframework.boot.loader.JarLauncher.main(JarLauncher.java:51)
- Caused by: com.mysql.cj.exceptions.UnableToConnectException: CLIENT_PLUGIN_AUTH is required
- at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
- at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
- at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
- at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
- at com.mysql.cj.exceptions.ExceptionFactory.createException(ExceptionFactory.java:61)
- at com.mysql.cj.exceptions.ExceptionFactory.createException(ExceptionFactory.java:85)
- at com.mysql.cj.protocol.a.NativeAuthenticationProvider.connect(NativeAuthenticationProvider.java:205)
- at com.mysql.cj.protocol.a.NativeProtocol.connect(NativeProtocol.java:1452)
- at com.mysql.cj.NativeSession.connect(NativeSession.java:165)
- at com.mysql.cj.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:955)
- at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:825)
- 2019-07-26 11:01:31,137 6703 [ WARN][o.h.e.j.e.i.JdbcEnvironmentInitiator ] - HHH000342: Could not obtain connection to query metadata : CLIENT_PLUGIN_AUTH is required
- 2019-07-26 11:01:31,151 6717 [ INFO][org.hibernate.dialect.Dialect ] - HHH000400: Using dialect: org.hibernate.dialect.MySQL5Dialect
- 2019-07-26 11:01:31,168 6734 [ INFO][o.h.e.j.env.internal.LobCreatorBuilderImpl ] - HHH000422: Disabling contextual LOB creation as connection was null
- 2019-07-26 11:01:33,006 8572 [ INFO][com.zaxxer.hikari.HikariDataSource ] - HikariPool-1 - Starting...
- 2019-07-26 11:01:34,008 9574 [ERROR][com.zaxxer.hikari.pool.HikariPool ] - HikariPool-1 - Exception during pool initialization.
- java.sql.SQLNonTransientConnectionException: CLIENT_PLUGIN_AUTH is required
- at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:110)
- at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97)
- at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:89)
- at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:63)
- at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:73)
- at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:79)
- at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:835)
- at com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:455)
- at com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:240)
- at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:199)
- at com.zaxxer.hikari.util.DriverDataSource.getConnection(DriverDataSource.java:136)
- at com.zaxxer.hikari.pool.PoolBase.newConnection(PoolBase.java:369)
- at com.zaxxer.hikari.pool.PoolBase.newPoolEntry(PoolBase.java:198)
- at com.zaxxer.hikari.pool.HikariPool.createPoolEntry(HikariPool.java:467)
- at com.zaxxer.hikari.pool.HikariPool.checkFailFast(HikariPool.java:541)
- at com.zaxxer.hikari.pool.HikariPool.<init>(HikariPool.java:115)
- at com.zaxxer.hikari.HikariDataSource.getConnection(HikariDataSource.java:112)
- at org.hibernate.engine.jdbc.connections.internal.DatasourceConnectionProviderImpl.getConnection(DatasourceConnectionProviderImpl.java:122)
- at org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator$ConnectionProviderJdbcConnectionAccess.obtainConnection(JdbcEnvironmentInitiator.java:180)
- at org.hibernate.resource.transaction.backend.jdbc.internal.DdlTransactionIsolatorNonJtaImpl.getIsolatedConnection(DdlTransactionIsolatorNonJtaImpl.java:43)
- at org.hibernate.tool.schema.internal.exec.ImprovedExtractionContextImpl.getJdbcConnection(ImprovedExtractionContextImpl.java:60)
- at org.hibernate.tool.schema.internal.exec.ImprovedExtractionContextImpl.getJdbcDatabaseMetaData(ImprovedExtractionContextImpl.java:67)
- at org.hibernate.tool.schema.extract.internal.InformationExtractorJdbcDatabaseMetaDataImpl.getTables(InformationExtractorJdbcDatabaseMetaDataImpl.java:329)
- at org.hibernate.tool.schema.extract.internal.DatabaseInformationImpl.getTablesInformation(DatabaseInformationImpl.java:120)
- at org.hibernate.tool.schema.internal.GroupedSchemaMigratorImpl.performTablesMigration(GroupedSchemaMigratorImpl.java:65)
- at org.hibernate.tool.schema.internal.AbstractSchemaMigrator.performMigration(AbstractSchemaMigrator.java:207)
- at org.hibernate.tool.schema.internal.AbstractSchemaMigrator.doMigration(AbstractSchemaMigrator.java:114)
- at org.hibernate.tool.schema.spi.SchemaManagementToolCoordinator.performDatabaseAction(SchemaManagementToolCoordinator.java:183)
- at org.hibernate.tool.schema.spi.SchemaManagementToolCoordinator.process(SchemaManagementToolCoordinator.java:72)
- at org.hibernate.internal.SessionFactoryImpl.<init>(SessionFactoryImpl.java:310)
- at org.hibernate.boot.internal.SessionFactoryBuilderImpl.build(SessionFactoryBuilderImpl.java:467)
- at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:939)
- at org.springframework.orm.jpa.vendor.SpringHibernateJpaPersistenceProvider.createContainerEntityManagerFactory(SpringHibernateJpaPersistenceProvider.java:57)
- at org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean.createNativeEntityManagerFactory(LocalContainerEntityManagerFactoryBean.java:365)
- at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.buildNativeEntityManagerFactory(AbstractEntityManagerFactoryBean.java:390)
- at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.afterPropertiesSet(AbstractEntityManagerFactoryBean.java:377)
- at org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean.afterPropertiesSet(LocalContainerEntityManagerFactoryBean.java:341)
- at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1837)
- at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1774)
- at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:593)
- at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:515)
- at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:320)
- at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)
- at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:318)
- at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:199)
- at org.springframework.context.support.AbstractApplicationContext.getBean(AbstractApplicationContext.java:1105)
- at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:867)
- at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:549)
- at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:140)
- at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:742)
- at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:389)
- at org.springframework.boot.SpringApplication.run(SpringApplication.java:311)
- at org.springframework.boot.SpringApplication.run(SpringApplication.java:1213)
- at org.springframework.boot.SpringApplication.run(SpringApplication.java:1202)
- at com.tst.flow.service.Application.main(Application.java:32)
- 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 org.springframework.boot.loader.MainMethodRunner.run(MainMethodRunner.java:47)
- at org.springframework.boot.loader.Launcher.launch(Launcher.java:86)
- at org.springframework.boot.loader.Launcher.launch(Launcher.java:50)
- at org.springframework.boot.loader.JarLauncher.main(JarLauncher.java:51)
- Caused by: com.mysql.cj.exceptions.UnableToConnectException: CLIENT_PLUGIN_AUTH is required
- at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
- at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
- at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
- at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
- at com.mysql.cj.exceptions.ExceptionFactory.createException(ExceptionFactory.java:61)
- at com.mysql.cj.exceptions.ExceptionFactory.createException(ExceptionFactory.java:85)
- at com.mysql.cj.protocol.a.NativeAuthenticationProvider.connect(NativeAuthenticationProvider.java:205)
- at com.mysql.cj.protocol.a.NativeProtocol.connect(NativeProtocol.java:1452)
- at com.mysql.cj.NativeSession.connect(NativeSession.java:165)
- at com.mysql.cj.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:955)
- at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:825)
- 2019-07-26 11:01:34,010 9576 [ WARN][o.h.engine.jdbc.spi.SqlExceptionHelper ] - SQL Error: 0, SQLState: 08001
- 2019-07-26 11:01:34,010 9576 [ERROR][o.h.engine.jdbc.spi.SqlExceptionHelper ] - CLIENT_PLUGIN_AUTH is required
- 2019-07-26 11:01:34,013 9579 [ WARN][notationConfigServletWebServerApplicationContext] - Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowEntityManager' defined in class path resource [com/tst/flow/persistence/config/DatabaseConfig.class]: Invocation of init method failed; nested exception is javax.persistence.PersistenceException: [PersistenceUnit: default] Unable to build Hibernate SessionFactory; nested exception is org.hibernate.exception.JDBCConnectionException: Unable to open JDBC Connection for DDL execution
- 2019-07-26 11:01:34,017 9583 [ INFO][org.apache.catalina.core.StandardService ] - Stopping service [Tomcat]
- 2019-07-26 11:01:34,029 9595 [ INFO][s.b.a.l.ConditionEvaluationReportLoggingListener] -
- Error starting ApplicationContext. To display the conditions report re-run your application with 'debug' enabled.
- 2019-07-26 11:01:34,031 9597 [ERROR][org.springframework.boot.SpringApplication ] - Application run failed
- org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flowEntityManager' defined in class path resource [com/tst/flow/persistence/config/DatabaseConfig.class]: Invocation of init method failed; nested exception is javax.persistence.PersistenceException: [PersistenceUnit: default] Unable to build Hibernate SessionFactory; nested exception is org.hibernate.exception.JDBCConnectionException: Unable to open JDBC Connection for DDL execution
- at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1778)
- at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:593)
- at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:515)