mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-24 07:13:33 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			44 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| ################################################################################
 | |
| # inc/gcol_dependencies_on_gcol.inc                                            #
 | |
| #                                                                              #
 | |
| # Purpose:                                                                     #
 | |
| #  Testing scenarios when columns depend on generated columns, i.e. such as    #
 | |
| #   - a generated column is based on a generated column                            #
 | |
| #   - a "real" column on which a generated one is renamed/dropped              #
 | |
| #   - a generated column involved in partitioning is renamed/dropped           #
 | |
| #                                                                              #
 | |
| #------------------------------------------------------------------------------#
 | |
| # Original Author: Andrey Zhakov                                               #
 | |
| # Original Date: 2008-09-02                                                    #
 | |
| # Change Author:                                                               #
 | |
| # Change Date:                                                                 #
 | |
| # Change:                                                                      #
 | |
| ################################################################################
 | |
| 
 | |
| --echo # Can't define a generated column on another generated column
 | |
| --error ER_VCOL_BASED_ON_VCOL
 | |
| create table t1 (a int, b int generated always as (a+1) virtual, c int generated always as (b+1) virtual);
 | |
| create table t1 (a int, b int generated always as (a+1) virtual);
 | |
| --error ER_VCOL_BASED_ON_VCOL
 | |
| alter table t1 add column c int generated always as (b+1) virtual;
 | |
| drop table t1;
 | |
| 
 | |
| --echo # Can't rename or drop a column used in the function of a generated column
 | |
| create table t1 (a int, b int generated always as (a+1) virtual);
 | |
| --echo # On renaming/dropping a column on which a virtual field is
 | |
| --echo # defined the following error is displayed:
 | |
| --echo # "Unknown column 'a' in 'generated column function'"
 | |
| --error 1054
 | |
| alter table t1 drop column a;
 | |
| --error 1054
 | |
| alter table t1 change a c int;
 | |
| drop table t1;
 | |
| 
 | |
| --echo # Can't rename or drop a generated column used by the paritition function
 | |
| create table t1 (a int, b int generated always as (a+1) virtual) partition by hash(b);
 | |
| --error 1054
 | |
| alter table t1 drop b;
 | |
| --error 1054
 | |
| alter table t1 change b c int generated always as (a+1) virtual;
 | |
| 
 |