mirror of
				https://github.com/MariaDB/server.git
				synced 2025-11-03 14:33:32 +03:00 
			
		
		
		
	BitKeeper/etc/ignore: Added mysql-test/suite/funcs_1/r/innodb_views.warnings mysql-test/suite/funcs_1/r/memory_trig_03e.warnings mysql-test/suite/funcs_1/r/memory_views.warnings mysql-test/suite/funcs_1/r/myisam_trig_03e.warnings mysql-test/suite/funcs_1/r/myisam_views.warnings mysql-test/suite/funcs_1/r/ndb_trig_03e.warnings mysql-test/suite/funcs_1/r/ndb_views.warnings mysql-test/suite/partitions/r/diff mysql-test/suite/partitions/r/partition_bit_ndb.warnings mysql-test/suite/partitions/r/partition_special_innodb.warnings mysql-test/suite/partitions/r/partition_special_myisam.warnings storage/archive/archive_reader mysql-test/suite/funcs_1/r/innodb_trig_03e.warnings to the ignore list mysql-test/suite/funcs_2/include/check_charset.inc: inserted newline at the end of file. mysql-test/suite/objects/include/drop_all.inc: inserted newline at the end of file. mysql-test/suite/partitions/include/partition_key_32col.inc: inserted newline at the end of file. mysql-test/suite/rpl/data/rpl_mixed.dat: inserted newline at the end of file. mysql-test/suite/rpl/include/rpl_mixed_check_event.inc: inserted newline at the end of file. mysql-test/suite/rpl/include/rpl_mixed_check_select.inc: inserted newline at the end of file. mysql-test/suite/rpl/include/rpl_mixed_check_user.inc: inserted newline at the end of file. mysql-test/suite/rpl/include/rpl_mixed_check_view.inc: inserted newline at the end of file.
		
			
				
	
	
		
			348 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			348 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
################################################################################
 | 
						|
# include/partition_alter2.inc                                                 #
 | 
						|
#                                                                              #
 | 
						|
# Purpose:                                                                     #
 | 
						|
#   Tests where the columns used within the partitioning function are altered. #
 | 
						|
#   This routine is only useful for the partition_<feature>_<engine> tests.   .#
 | 
						|
#                                                                              #
 | 
						|
#------------------------------------------------------------------------------#
 | 
						|
# Original Author: ML                                                          #
 | 
						|
# Original Date: 2006-03-05                                                    #
 | 
						|
# Change Author:                                                               #
 | 
						|
# Change Date:                                                                 #
 | 
						|
# Change:                                                                      #
 | 
						|
################################################################################
 | 
						|
 | 
						|
--echo
 | 
						|
--echo #========================================================================
 | 
						|
--echo #  1     Increase the size of the column used in the partitioning
 | 
						|
--echo #        function and/or PRIMARY KEY and/or UNIQUE INDEX
 | 
						|
--echo #========================================================================
 | 
						|
--echo #------------------------------------------------------------------------
 | 
						|
--echo #  1.1   ALTER column f_int2 not used in partitioning function
 | 
						|
--echo #------------------------------------------------------------------------
 | 
						|
#         Rule: Only f_int1 is used within the partitioning function
 | 
						|
#         ---> include/partition_alter_11.inc
 | 
						|
let $alter= ALTER TABLE t1 MODIFY f_int2 BIGINT;
 | 
						|
--echo #  1.1.1 no PRIMARY KEY or UNIQUE INDEX exists
 | 
						|
let $unique= ;
 | 
						|
--source suite/partitions/include/partition_alter_11.inc
 | 
						|
# --source include/partition_alter_11.inc
 | 
						|
#
 | 
						|
if ($do_pk_tests)
 | 
						|
{
 | 
						|
   --echo #  1.1.2 PRIMARY KEY exists
 | 
						|
   # The value of the direct following test is maybe covered by the test with
 | 
						|
   # the PRIMARY KEY containing two columns.
 | 
						|
   if ($more_pk_ui_tests)
 | 
						|
   {
 | 
						|
      let $unique= , PRIMARY KEY (f_int1);
 | 
						|
      --source suite/partitions/include/partition_alter_11.inc
 | 
						|
      # --source include/partition_alter_11.inc
 | 
						|
   }
 | 
						|
   let $unique= , PRIMARY KEY (f_int1,f_int2);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
   let $unique= , PRIMARY KEY (f_int2,f_int1);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
}
 | 
						|
#
 | 
						|
--echo #  1.1.3 UNIQUE INDEX exists
 | 
						|
# The value of the direct following test is maybe covered by the test with
 | 
						|
# the UNIQUE INDEX containing two columns
 | 
						|
if ($more_pk_ui_tests)
 | 
						|
{
 | 
						|
   let $unique= , UNIQUE INDEX uidx1 (f_int1);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
}
 | 
						|
let $unique= , UNIQUE INDEX uidx1 (f_int1,f_int2);
 | 
						|
--source suite/partitions/include/partition_alter_11.inc
 | 
						|
# --source include/partition_alter_11.inc
 | 
						|
let $unique= , UNIQUE INDEX uidx1 (f_int2,f_int1);
 | 
						|
--source suite/partitions/include/partition_alter_11.inc
 | 
						|
# --source include/partition_alter_11.inc
 | 
						|
#
 | 
						|
if ($more_pk_ui_tests)
 | 
						|
{
 | 
						|
   # The value of the tests 1.2 is maybe covered by the tests 1.3
 | 
						|
   --echo #------------------------------------------------------------------------
 | 
						|
   --echo #  1.2   ALTER column f_int1 used in partitioning function
 | 
						|
   --echo #------------------------------------------------------------------------
 | 
						|
   #         Rule: Only f_int1 is used within the partitioning function
 | 
						|
   #         ---> include/partition_alter_11.inc
 | 
						|
   let $alter= ALTER TABLE t1 MODIFY f_int1 BIGINT;
 | 
						|
   --echo #  1.2.1 no PRIMARY KEY or UNIQUE INDEX exists
 | 
						|
   let $unique= ;
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
   --source suite/partitions/include/partition_alter_13.inc
 | 
						|
   # --source include/partition_alter_13.inc
 | 
						|
   #
 | 
						|
   if ($do_pk_tests)
 | 
						|
   {
 | 
						|
      --echo #  1.2.2 PRIMARY KEY exists
 | 
						|
      let $unique= , PRIMARY KEY (f_int1);
 | 
						|
      --source suite/partitions/include/partition_alter_11.inc
 | 
						|
      # --source include/partition_alter_11.inc
 | 
						|
      let $unique= , PRIMARY KEY (f_int1,f_int2);
 | 
						|
      --source suite/partitions/include/partition_alter_11.inc
 | 
						|
      # --source include/partition_alter_11.inc
 | 
						|
      --source suite/partitions/include/partition_alter_13.inc
 | 
						|
      # --source include/partition_alter_13.inc
 | 
						|
      let $unique= , PRIMARY KEY (f_int2,f_int1);
 | 
						|
      --source suite/partitions/include/partition_alter_11.inc
 | 
						|
      # --source include/partition_alter_11.inc
 | 
						|
      --source suite/partitions/include/partition_alter_13.inc
 | 
						|
      # --source include/partition_alter_13.inc
 | 
						|
   }
 | 
						|
   #
 | 
						|
   --echo #  1.2.3 UNIQUE INDEX exists
 | 
						|
   let $unique= , UNIQUE INDEX uidx (f_int1);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
   let $unique= , UNIQUE INDEX uidx (f_int1,f_int2);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
   --source suite/partitions/include/partition_alter_13.inc
 | 
						|
   # --source include/partition_alter_13.inc
 | 
						|
   let $unique= , UNIQUE INDEX uidx (f_int2,f_int1);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
   --source suite/partitions/include/partition_alter_13.inc
 | 
						|
   # --source include/partition_alter_13.inc
 | 
						|
}
 | 
						|
#
 | 
						|
--echo #------------------------------------------------------------------------
 | 
						|
--echo #  1.3   ALTER column f_int1 and f_int2
 | 
						|
--echo #        f_int1 or (f_int1 and f_int2) used in partitioning function
 | 
						|
--echo #------------------------------------------------------------------------
 | 
						|
#         Rule: f_int1 and f_int2 is used within the partitioning function
 | 
						|
#         ---> include/partition_alter_13.inc
 | 
						|
let $alter= ALTER TABLE t1 MODIFY f_int1 BIGINT, MODIFY f_int2 BIGINT;
 | 
						|
--echo #  1.3.1 no PRIMARY KEY or UNIQUE INDEX exists
 | 
						|
let $unique= ;
 | 
						|
--source suite/partitions/include/partition_alter_11.inc
 | 
						|
# --source include/partition_alter_11.inc
 | 
						|
--source suite/partitions/include/partition_alter_13.inc
 | 
						|
# --source include/partition_alter_13.inc
 | 
						|
#
 | 
						|
if ($do_pk_tests)
 | 
						|
{
 | 
						|
   --echo #  1.3.2 PRIMARY KEY exists
 | 
						|
   # The value of the direct following test is maybe covered by the test with
 | 
						|
   # the PRIMARY KEY containing two columns.
 | 
						|
   if ($more_pk_ui_tests)
 | 
						|
   {
 | 
						|
      let $unique= , PRIMARY KEY (f_int1);
 | 
						|
      --source suite/partitions/include/partition_alter_11.inc
 | 
						|
      # --source include/partition_alter_11.inc
 | 
						|
   }
 | 
						|
   let $unique= , PRIMARY KEY (f_int1,f_int2);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
   --source suite/partitions/include/partition_alter_13.inc
 | 
						|
   # --source include/partition_alter_13.inc
 | 
						|
   let $unique= , PRIMARY KEY (f_int2,f_int1);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
   --source suite/partitions/include/partition_alter_13.inc
 | 
						|
   # --source include/partition_alter_13.inc
 | 
						|
}
 | 
						|
#
 | 
						|
--echo #  1.3.3 UNIQUE INDEX exists
 | 
						|
# The value of the direct following test is maybe covered by the test with
 | 
						|
# the UNIQUE INDEX containing two columns.
 | 
						|
if ($more_pk_ui_tests)
 | 
						|
{
 | 
						|
   let $unique= , UNIQUE INDEX uidx (f_int1);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
}
 | 
						|
let $unique= , UNIQUE INDEX uidx (f_int1,f_int2);
 | 
						|
--source suite/partitions/include/partition_alter_11.inc
 | 
						|
# --source include/partition_alter_11.inc
 | 
						|
--source suite/partitions/include/partition_alter_13.inc
 | 
						|
# --source include/partition_alter_13.inc
 | 
						|
let $unique= , UNIQUE INDEX uidx (f_int2,f_int1);
 | 
						|
--source suite/partitions/include/partition_alter_11.inc
 | 
						|
# --source include/partition_alter_11.inc
 | 
						|
--source suite/partitions/include/partition_alter_13.inc
 | 
						|
# --source include/partition_alter_13.inc
 | 
						|
 | 
						|
--echo
 | 
						|
--echo #========================================================================
 | 
						|
--echo #  2     Decrease the size of the column used in the partitioning
 | 
						|
--echo #        function and/or PRIMARY KEY and/or UNIQUE INDEX
 | 
						|
--echo #========================================================================
 | 
						|
--echo #------------------------------------------------------------------------
 | 
						|
--echo #  2.1   ALTER column f_int2 not used in partitioning function
 | 
						|
--echo #------------------------------------------------------------------------
 | 
						|
#         Rule: Only f_int1 is used within the partitioning function
 | 
						|
#         ---> include/partition_alter_11.inc
 | 
						|
let $alter= ALTER TABLE t1 MODIFY f_int2 MEDIUMINT;
 | 
						|
--echo #  2.1.1 no PRIMARY KEY or UNIQUE INDEX exists
 | 
						|
let $unique= ;
 | 
						|
--source suite/partitions/include/partition_alter_11.inc
 | 
						|
# --source include/partition_alter_11.inc
 | 
						|
#
 | 
						|
if ($do_pk_tests)
 | 
						|
{
 | 
						|
   # The value of the direct following test is maybe covered by the test with
 | 
						|
   # the PRIMARY KEY containing two columns.
 | 
						|
   if ($more_pk_ui_tests)
 | 
						|
   {
 | 
						|
      --echo #  2.1.2 PRIMARY KEY exists
 | 
						|
      let $unique= , PRIMARY KEY (f_int1);
 | 
						|
      --source suite/partitions/include/partition_alter_11.inc
 | 
						|
      # --source include/partition_alter_11.inc
 | 
						|
   }
 | 
						|
   let $unique= , PRIMARY KEY (f_int1,f_int2);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
   let $unique= , PRIMARY KEY (f_int2,f_int1);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
}
 | 
						|
#
 | 
						|
--echo #  2.1.3 UNIQUE INDEX exists
 | 
						|
# The value of the direct following test is maybe covered by the test with
 | 
						|
# the UNIQUE INDEX containing two columns.
 | 
						|
if ($more_pk_ui_tests)
 | 
						|
{
 | 
						|
   let $unique= , UNIQUE INDEX uidx1 (f_int1);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
}
 | 
						|
let $unique= , UNIQUE INDEX uidx1 (f_int1,f_int2);
 | 
						|
--source suite/partitions/include/partition_alter_11.inc
 | 
						|
# --source include/partition_alter_11.inc
 | 
						|
let $unique= , UNIQUE INDEX uidx1 (f_int2,f_int1);
 | 
						|
--source suite/partitions/include/partition_alter_11.inc
 | 
						|
# --source include/partition_alter_11.inc
 | 
						|
#
 | 
						|
if ($more_pk_ui_tests)
 | 
						|
{
 | 
						|
   # The value of the tests 2.2 is maybe covered by the tests 2.3
 | 
						|
   --echo #------------------------------------------------------------------------
 | 
						|
   --echo #  2.2   ALTER column f_int1 used in partitioning function
 | 
						|
   --echo #------------------------------------------------------------------------
 | 
						|
   #         Rule: Only f_int1 is used within the partitioning function
 | 
						|
   #         ---> include/partition_alter_11.inc
 | 
						|
   let $alter= ALTER TABLE t1 MODIFY f_int1 MEDIUMINT;
 | 
						|
   --echo #  2.2.1 no PRIMARY KEY or UNIQUE INDEX exists
 | 
						|
   let $unique= ;
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
   --source suite/partitions/include/partition_alter_13.inc
 | 
						|
   # --source include/partition_alter_13.inc
 | 
						|
   #
 | 
						|
   if ($do_pk_tests)
 | 
						|
   {
 | 
						|
      --echo #  2.2.2 PRIMARY KEY exists
 | 
						|
      let $unique= , PRIMARY KEY (f_int1);
 | 
						|
      --source suite/partitions/include/partition_alter_11.inc
 | 
						|
      # --source include/partition_alter_11.inc
 | 
						|
      let $unique= , PRIMARY KEY (f_int1,f_int2);
 | 
						|
      --source suite/partitions/include/partition_alter_11.inc
 | 
						|
      # --source include/partition_alter_11.inc
 | 
						|
      --source suite/partitions/include/partition_alter_13.inc
 | 
						|
      # --source include/partition_alter_13.inc
 | 
						|
      let $unique= , PRIMARY KEY (f_int2,f_int1);
 | 
						|
      --source suite/partitions/include/partition_alter_11.inc
 | 
						|
      # --source include/partition_alter_11.inc
 | 
						|
      --source suite/partitions/include/partition_alter_13.inc
 | 
						|
      # --source include/partition_alter_13.inc
 | 
						|
   }
 | 
						|
   #
 | 
						|
   --echo #  2.2.3 UNIQUE INDEX exists
 | 
						|
   let $unique= , UNIQUE INDEX uidx (f_int1);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
   let $unique= , UNIQUE INDEX uidx (f_int1,f_int2);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
   --source suite/partitions/include/partition_alter_13.inc
 | 
						|
   # --source include/partition_alter_13.inc
 | 
						|
   let $unique= , UNIQUE INDEX uidx (f_int2,f_int1);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
   --source suite/partitions/include/partition_alter_13.inc
 | 
						|
         # --source include/partition_alter_13.inc
 | 
						|
}
 | 
						|
#
 | 
						|
--echo #------------------------------------------------------------------------
 | 
						|
--echo #  2.3   ALTER column f_int1 and f_int2 used in partitioning function
 | 
						|
--echo #------------------------------------------------------------------------
 | 
						|
#         Rule: f_int1 and f_int2 is used within the partitioning function
 | 
						|
#         ---> include/partition_alter_13.inc
 | 
						|
let $alter= ALTER TABLE t1 MODIFY f_int1 MEDIUMINT, MODIFY f_int2 MEDIUMINT;
 | 
						|
--echo #  2.3.1 no PRIMARY KEY or UNIQUE INDEX exists
 | 
						|
let $unique= ;
 | 
						|
--source suite/partitions/include/partition_alter_11.inc
 | 
						|
# --source include/partition_alter_11.inc
 | 
						|
--source suite/partitions/include/partition_alter_13.inc
 | 
						|
# --source include/partition_alter_13.inc
 | 
						|
#
 | 
						|
if ($do_pk_tests)
 | 
						|
{
 | 
						|
   --echo #  2.3.2 PRIMARY KEY exists
 | 
						|
   # The value of the direct following test is maybe covered by the test with
 | 
						|
   # the PRIMARY KEY containing two columns.
 | 
						|
   if ($more_pk_ui_tests)
 | 
						|
   {
 | 
						|
      let $unique= , PRIMARY KEY (f_int1);
 | 
						|
      --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   }
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
   let $unique= , PRIMARY KEY (f_int1,f_int2);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
   --source suite/partitions/include/partition_alter_13.inc
 | 
						|
   # --source include/partition_alter_13.inc
 | 
						|
   let $unique= , PRIMARY KEY (f_int2,f_int1);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
   --source suite/partitions/include/partition_alter_13.inc
 | 
						|
   # --source include/partition_alter_13.inc
 | 
						|
}
 | 
						|
#
 | 
						|
--echo #  2.3.3 UNIQUE INDEX exists
 | 
						|
# The value of the direct following test is maybe covered by the test with
 | 
						|
# the UNIQUE INDEX containing two columns.
 | 
						|
if ($more_pk_ui_tests)
 | 
						|
{
 | 
						|
   let $unique= , UNIQUE INDEX uidx (f_int1);
 | 
						|
   --source suite/partitions/include/partition_alter_11.inc
 | 
						|
   # --source include/partition_alter_11.inc
 | 
						|
}
 | 
						|
let $unique= , UNIQUE INDEX uidx (f_int1,f_int2);
 | 
						|
--source suite/partitions/include/partition_alter_11.inc
 | 
						|
# --source include/partition_alter_11.inc
 | 
						|
--source suite/partitions/include/partition_alter_13.inc
 | 
						|
# --source include/partition_alter_13.inc
 | 
						|
let $unique= , UNIQUE INDEX uidx (f_int2,f_int1);
 | 
						|
--source suite/partitions/include/partition_alter_11.inc
 | 
						|
# --source include/partition_alter_11.inc
 | 
						|
--source suite/partitions/include/partition_alter_13.inc
 | 
						|
# --source include/partition_alter_13.inc
 | 
						|
#
 | 
						|
 | 
						|
if (0)
 | 
						|
{
 | 
						|
--echo
 | 
						|
--echo #========================================================================
 | 
						|
--echo #  3     ALTER the type of the column used in the partitioning
 | 
						|
--echo #        function and/or PRIMARY KEY and/or UNIQUE INDEX
 | 
						|
--echo #                   INTEGER --> FLOAT
 | 
						|
--echo #                   INTEGER --> DECIMAL
 | 
						|
--echo #                   INTEGER --> VARCHAR
 | 
						|
--echo #        ML: I assume that at least the first two variants are of some
 | 
						|
--echo #            interest. But I am unsure if the server allows such
 | 
						|
--echo #            conversions. I also think that such operations have a
 | 
						|
--echo #            conversions very small likelihood.
 | 
						|
--echo #            To be implemented.
 | 
						|
--echo #========================================================================
 | 
						|
}
 |