表' performance_schema.session_variables'不存在

时间:2016-04-20 14:17:40

标签: mysql spring mysql-error-1064

我是使用MySql数据库的新手,我已经下载了EasyPHP-Devserver-16.1,当我运行服务器来更新我的数据库架构时,会显示此错误消息。

  

com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException:Table   ' performance_schema.session_variables'不存在

我知道问题不在我的spring配置文件中,而是在mysql服务器中。

public class Configurations {

    protected static final String PROPERTY_NAME_DATABASE_DRIVER = "com.mysql.jdbc.Driver";
    protected static final String PROPERTY_NAME_DATABASE_PASSWORD = "";
    protected static final String PROPERTY_NAME_DATABASE_URL = "jdbc:mysql://127.0.0.1:3306/quraa";
    protected static final String PROPERTY_NAME_DATABASE_USERNAME = "root";

    private static final String PROPERTY_PACKAGES_TO_SCAN = "com.med.quraa.models";
    @Bean
    public LocalContainerEntityManagerFactoryBean entityManagerFactoryBean(DataSource dataSource, JpaVendorAdapter jpaVendorAdapter){
        LocalContainerEntityManagerFactoryBean entityManagerFactoryBean = new LocalContainerEntityManagerFactoryBean();
        entityManagerFactoryBean.setDataSource(dataSource);
        entityManagerFactoryBean.setJpaVendorAdapter(jpaVendorAdapter);
        entityManagerFactoryBean.setPackagesToScan(PROPERTY_PACKAGES_TO_SCAN);
        return entityManagerFactoryBean;
    }

    @Bean
    public DriverManagerDataSource dataSource(){
        DriverManagerDataSource ds = new DriverManagerDataSource();
        ds.setDriverClassName(PROPERTY_NAME_DATABASE_DRIVER);
        ds.setUrl(PROPERTY_NAME_DATABASE_URL);
        ds.setUsername(PROPERTY_NAME_DATABASE_USERNAME);
        ds.setPassword(PROPERTY_NAME_DATABASE_PASSWORD);
        return ds;
    }

    @Bean
    public JdbcTemplate jdbcTemplate(){
        JdbcTemplate jdbcTemplate=new JdbcTemplate();
        jdbcTemplate.setDataSource(dataSource());
        return jdbcTemplate;
    }

    @Bean
    public JpaVendorAdapter jpaVendorAdapter(){
        HibernateJpaVendorAdapter adapter = new HibernateJpaVendorAdapter();
        adapter.setDatabase(Database.MYSQL);
        adapter.setShowSql(true);
        adapter.setGenerateDdl(true);
        adapter.setDatabasePlatform("org.hibernate.dialect.MySQL5InnoDBDialect");
        return adapter;
    }

    @Bean
    public PlatformTransactionManager transactionManager(EntityManagerFactory entityManagerFactory) {
        return new JpaTransactionManager(entityManagerFactory);
    }

}

请注意,我也测试了org.apache.tomcat.dbcp.dbcp.BasicDataSource,但我遇到了同样的错误,这意味着org.springframework.jdbc.datasource.DriverManagerDataSource没有问题

5 个答案:

答案 0 :(得分:39)

  1. 首先升级MySql服务器以通过运行此命令解决问题:

    mysql_upgrade -u root -p --force

  2. 然后重启服务器:

答案 1 :(得分:11)

...解决 我打开了cmd然后:

cd [installation_path]\eds-binaries\dbserver\mysql5711x86x160420141510\bin

然后执行此命令行:

mysql_upgrade -u root -p --force

需要重启服务器!

答案 2 :(得分:4)

默认情况下未安装性能架构 要进行检查,您可以运行命令

SHOW VARIABLES LIKE 'performance_schema';

假设现在你会看到OFF

要启用它,请启用performance_schema变量启动服务器。例如,在my.cnf文件中使用以下行:

[mysqld]
performance_schema=ON

您可以在官方文档中找到更多详细信息:

https://dev.mysql.com/doc/refman/en/performance-schema-quick-start.html

答案 3 :(得分:4)

以下是如何修复它(从命令行):

mysql -u {user} -p
mysql> set @@global.show_compatibility_56=ON;

在/etc/my.cnf:

show_compatibility_56 = 1

这个在没有升级mysql的情况下对我有用。在此之后,您需要重新启动mysql。

答案 4 :(得分:1)

当有人问到服务器重启的那一部分时,我将考虑那部分内容发布我的答案:

1。在我的情况下,转到MySQL安装文件夹的目录:     C:\ Program Files \ MySQL \ MySQL Server 5.7 \ bin。

  1. 在此目录中打开CMD,然后运行“ mysql_upgrade -u root -p”命令。

  2. 如果您的模式受密码保护,则应在请求密码时输入密码。

  3. 这将检查所有模式的所有表,因此您应该等待检查完成。

  4. 最后应显示以下消息:

r (column1 text, column2 text,column3 int, column4 text, icon text)) );
ERROR:  subquery must return only one column
LINE 9:   (select column1, column3
      ^
  1. 重新启动MySQL服务器和路由器服务:
Upgrade process completed successfully.

Checking if update is needed.
  1. 使用工作台连接到服务器,它应该连接。