2008-04-23 11:36:17 +02:00
|
|
|
############## mysql-test\t\group_concat_max_len_func.test ####################
|
|
|
|
# #
|
|
|
|
# Variable Name: group_concat_max_len #
|
|
|
|
# Scope: GLOBAL | SESSION #
|
|
|
|
# Access Type: Dynamic #
|
|
|
|
# Data Type: numeric #
|
|
|
|
# Default Value: 1024 #
|
|
|
|
# Minimum value: 4 #
|
|
|
|
# #
|
|
|
|
# #
|
|
|
|
# Creation Date: 2008-03-07 #
|
|
|
|
# Author: Salman Rawala #
|
|
|
|
# #
|
2008-11-14 19:20:16 +01:00
|
|
|
# Last modification: #
|
|
|
|
# 2008-11-14 mleich Fix Bug#40644 main.group_concat_max_len_func random #
|
|
|
|
# failures #
|
|
|
|
# + minor improvements #
|
|
|
|
# #
|
2008-04-23 11:36:17 +02:00
|
|
|
# Description: Test Cases of Dynamic System Variable group_concat_max_len #
|
|
|
|
# that checks the functionality of this variable #
|
|
|
|
# #
|
2008-11-14 19:20:16 +01:00
|
|
|
# Reference: #
|
|
|
|
# http://dev.mysql.com/doc/refman/5.1/en/server-system-variables.html #
|
2008-04-23 11:36:17 +02:00
|
|
|
# #
|
|
|
|
###############################################################################
|
|
|
|
|
|
|
|
SET @save = @@global.group_concat_max_len;
|
|
|
|
|
|
|
|
--disable_warnings
|
2008-11-14 19:20:16 +01:00
|
|
|
DROP TABLE IF EXISTS t1;
|
2008-04-23 11:36:17 +02:00
|
|
|
--enable_warnings
|
|
|
|
|
|
|
|
#########################
|
|
|
|
# Creating new table #
|
|
|
|
#########################
|
|
|
|
|
|
|
|
--echo ## Creating new table t1 ##
|
|
|
|
CREATE TABLE t1
|
|
|
|
(
|
2008-11-14 19:20:16 +01:00
|
|
|
id INT NOT NULL AUTO_INCREMENT,
|
2008-04-23 11:36:17 +02:00
|
|
|
PRIMARY KEY (id),
|
2008-11-14 19:20:16 +01:00
|
|
|
rollno INT NOT NULL,
|
2008-04-23 11:36:17 +02:00
|
|
|
name VARCHAR(30)
|
|
|
|
);
|
|
|
|
|
|
|
|
--echo '#--------------------FN_DYNVARS_034_01-------------------------#'
|
|
|
|
########################################################################
|
|
|
|
# Setting initial value of group_concat_max_len, inserting some rows
|
2008-11-14 19:20:16 +01:00
|
|
|
# & creating 2 new connections
|
2008-04-23 11:36:17 +02:00
|
|
|
########################################################################
|
|
|
|
|
2008-11-14 19:20:16 +01:00
|
|
|
--echo ## Setting initial value of variable to 4 ##
|
2008-04-23 11:36:17 +02:00
|
|
|
SET @@global.group_concat_max_len = 4;
|
|
|
|
|
2008-11-14 19:20:16 +01:00
|
|
|
--echo ## Inserting some rows in table ##
|
|
|
|
INSERT INTO t1(rollno, name) VALUES(1, 'Record_1');
|
|
|
|
INSERT INTO t1(rollno, name) VALUES(2, 'Record_2');
|
|
|
|
INSERT INTO t1(rollno, name) VALUES(1, 'Record_3');
|
|
|
|
INSERT INTO t1(rollno, name) VALUES(3, 'Record_4');
|
|
|
|
INSERT INTO t1(rollno, name) VALUES(1, 'Record_5');
|
|
|
|
INSERT INTO t1(rollno, name) VALUES(3, 'Record_6');
|
|
|
|
INSERT INTO t1(rollno, name) VALUES(4, 'Record_7');
|
|
|
|
INSERT INTO t1(rollno, name) VALUES(4, 'Record_8');
|
|
|
|
# The following "auxiliary" select ensures that all records are on disk
|
|
|
|
# = result sets got by parallel sessions cannot suffer from effects
|
|
|
|
# caused by the MyISAM feature "concurrent_inserts".
|
|
|
|
SELECT * FROM t1 ORDER BY id;
|
|
|
|
|
|
|
|
--echo ## Creating two new connections ##
|
|
|
|
connect (test_con1,localhost,root,,);
|
|
|
|
connect (test_con2,localhost,root,,);
|
2008-04-23 11:36:17 +02:00
|
|
|
|
|
|
|
|
|
|
|
--echo '#--------------------FN_DYNVARS_034_02-------------------------#'
|
|
|
|
###############################################################################
|
|
|
|
# Verifying initial behavior of variable by concatinating values greater than 4
|
|
|
|
###############################################################################
|
|
|
|
|
|
|
|
--echo ## Connecting with test_con1 ##
|
2008-11-14 19:20:16 +01:00
|
|
|
connection test_con1;
|
2008-04-23 11:36:17 +02:00
|
|
|
|
2008-11-14 19:20:16 +01:00
|
|
|
--echo ## Accessing data and using group_concat on column whose value is greater than 4 ##
|
|
|
|
SELECT id, rollno, GROUP_CONCAT(name) FROM t1 GROUP BY rollno;
|
2008-04-23 11:36:17 +02:00
|
|
|
|
|
|
|
--echo ## Changing session value of variable and verifying its behavior, ##
|
2008-11-14 19:20:16 +01:00
|
|
|
--echo ## warning should come here ##
|
2008-04-23 11:36:17 +02:00
|
|
|
|
|
|
|
SET @@session.group_concat_max_len = 10;
|
2008-11-14 19:20:16 +01:00
|
|
|
SELECT id, rollno, GROUP_CONCAT(name) FROM t1 GROUP BY rollno;
|
2008-04-23 11:36:17 +02:00
|
|
|
|
|
|
|
|
|
|
|
--echo '#--------------------FN_DYNVARS_034_03-------------------------#'
|
|
|
|
##############################################################################
|
|
|
|
# Verifying behavior of variable by increasing session value of variable #
|
|
|
|
##############################################################################
|
|
|
|
|
2008-11-14 19:20:16 +01:00
|
|
|
--echo ## Connecting with new connection test_con2 ##
|
2008-04-23 11:36:17 +02:00
|
|
|
connection test_con2;
|
|
|
|
|
2008-11-14 19:20:16 +01:00
|
|
|
--echo ## Verifying initial value of variable. It should be 4 ##
|
2008-04-23 11:36:17 +02:00
|
|
|
SELECT @@session.group_concat_max_len = 4;
|
|
|
|
|
2008-11-14 19:20:16 +01:00
|
|
|
--echo ## Setting session value of variable to 20 and verifying variable is concating ##
|
|
|
|
--echo ## column's value to 20 or not ##
|
2008-04-23 11:36:17 +02:00
|
|
|
SET @@session.group_concat_max_len = 20;
|
|
|
|
|
|
|
|
--echo ## Verifying value of name column, it should not me more than 20 characters ##
|
|
|
|
--echo ## Warning should come here ##
|
2008-11-14 19:20:16 +01:00
|
|
|
SELECT id, rollno, GROUP_CONCAT(name) FROM t1 GROUP BY rollno;
|
2008-04-23 11:36:17 +02:00
|
|
|
|
|
|
|
|
|
|
|
--echo '#--------------------FN_DYNVARS_034_04-------------------------#'
|
|
|
|
###############################################################################
|
|
|
|
# Verifying behavior of variable by increasing session value of variable #
|
|
|
|
# greater than the maximum concat length of name column #
|
|
|
|
###############################################################################
|
|
|
|
|
2008-11-14 19:20:16 +01:00
|
|
|
--echo ## Setting session value of variable to 26. No warning should appear here ##
|
|
|
|
--echo ## because the value after concatination is less than 30 ##
|
2008-04-23 11:36:17 +02:00
|
|
|
SET @@session.group_concat_max_len = 26;
|
|
|
|
|
2008-11-14 19:20:16 +01:00
|
|
|
--echo ## Verifying value of name column, it should not give warning now ##
|
|
|
|
SELECT id, rollno, GROUP_CONCAT(name) FROM t1 GROUP BY rollno;
|
2008-04-23 11:36:17 +02:00
|
|
|
|
|
|
|
|
|
|
|
############################################################
|
|
|
|
# Disconnecting all connection & dropping table #
|
|
|
|
############################################################
|
|
|
|
|
|
|
|
--echo ## Dropping table t1 ##
|
2008-11-14 19:20:16 +01:00
|
|
|
DROP TABLE t1;
|
2008-04-23 11:36:17 +02:00
|
|
|
|
|
|
|
--echo ## Disconnecting both the connection ##
|
2008-11-14 19:20:16 +01:00
|
|
|
disconnect test_con2;
|
|
|
|
disconnect test_con1;
|
2008-04-23 11:36:17 +02:00
|
|
|
|
|
|
|
connection default;
|
|
|
|
|
2008-05-01 01:39:51 +02:00
|
|
|
SET @@global.group_concat_max_len = @save;
|
2008-04-23 11:36:17 +02:00
|
|
|
|