我是使用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
没有问题
答案 0 :(得分:39)
首先升级MySql
服务器以通过运行此命令解决问题:
mysql_upgrade -u root -p --force
然后重启服务器:
答案 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。
在此目录中打开CMD,然后运行“ mysql_upgrade -u root -p”命令。
如果您的模式受密码保护,则应在请求密码时输入密码。
这将检查所有模式的所有表,因此您应该等待检查完成。
最后应显示以下消息:
r (column1 text, column2 text,column3 int, column4 text, icon text)) ); ERROR: subquery must return only one column LINE 9: (select column1, column3 ^
Upgrade process completed successfully. Checking if update is needed.