sql >> Databasteknik >  >> RDS >> Mysql

En primär måste inkludera alla kolumner i tabellens partitioneringsplatsfel?

Du partitionerar data med fldconfirmdate, som är en del av din PK, men inte en del av din UNIKA KEY fld_id.

Detta är extraherat från MySQL-manual :

Vilket betyder att om du gör fldconfirmdate att vara en del av din UNIKA KEY 'fld_id' kommer problemet att lösas.

CREATE TABLE `tbl_emp_confirmation` (
  `fld_id` int(11) NOT NULL AUTO_INCREMENT,
  `fldemp_id` varchar(100) DEFAULT NULL,
  `fldempname` varchar(100) DEFAULT NULL,
  `fldjoindate` varchar(100) DEFAULT NULL,
  `fldconfirmdate` Date NOT NULL,
  `fldresigndate` varchar(100) DEFAULT NULL,
  `fldstatus` varchar(50) DEFAULT NULL,
  `fldcon_status` varchar(100) DEFAULT NULL,
  UNIQUE KEY `fld_id` (`fld_id`, `fldconfirmdate`),
  KEY `in_empconfirmation` (`fldemp_id`,`fldempname`,`fldjoindate`,`fldconfirmdate`)
  ) PARTITION BY RANGE ( Month(fldconfirmdate))
  (PARTITION p_JAN VALUES LESS THAN (TO_DAYS('2011-01-01')),
 PARTITION p_FEB VALUES LESS THAN (TO_DAYS('2011-02-01')),
 PARTITION p_MAR VALUES LESS THAN (TO_DAYS('2011-03-01')),
 PARTITION p_APR VALUES LESS THAN (TO_DAYS('2011-04-01')),
 PARTITION p_MAY VALUES LESS THAN (TO_DAYS('2011-05-01')),
 PARTITION p_MAX VALUES LESS THAN MAXVALUE );



  1. Vad är schema i SQL Server och hur man skapar/släpper schema i SQL Server-databas - SQL Server / TSQL Tutorial Del 27

  2. Skillnaden mellan int och int(2) datatyper i min sql

  3. Felmeddelande:Undantag i trådens huvud org.hibernate.HibernateException:Fel vid åtkomst till staxström

  4. php mysqli_connect:autentiseringsmetod okänd för klienten [caching_sha2_password]