@@ -823,4 +823,193 @@ create view v3 as select t2.id, t3.b from t2 join t3 using(id);
823
823
update t1 join v3 using (id) set t1.a=0;
824
824
drop view v1, v2, v3;
825
825
drop table t2, t3, t1;
826
+ #
827
+ # MDEV-7613: MariaDB 5.5.40 server crash on update table left join
828
+ # with a view
829
+ #
830
+ CREATE TABLE `t1` (
831
+ `f1` varchar(6) COLLATE latin1_general_ci DEFAULT NULL,
832
+ `f2` varchar(6) COLLATE latin1_general_ci DEFAULT NULL,
833
+ `f3` varchar(7) COLLATE latin1_general_ci DEFAULT NULL,
834
+ `f4` varchar(15) COLLATE latin1_general_ci DEFAULT NULL,
835
+ `f5` datetime DEFAULT NULL,
836
+ `f6` varchar(2) COLLATE latin1_general_ci DEFAULT NULL,
837
+ `f7` varchar(2) COLLATE latin1_general_ci DEFAULT NULL,
838
+ `ff1` int(1) DEFAULT NULL,
839
+ `ff2` int(1) DEFAULT NULL,
840
+ `ff3` int(1) DEFAULT NULL,
841
+ `ff4` int(1) DEFAULT NULL,
842
+ `ff5` int(1) DEFAULT NULL,
843
+ `ff6` int(1) DEFAULT NULL,
844
+ `ff7` int(1) DEFAULT NULL,
845
+ `ff8` int(2) DEFAULT NULL,
846
+ `ff9` int(1) DEFAULT NULL,
847
+ `ff10` int(1) DEFAULT NULL,
848
+ `ff11` int(1) DEFAULT NULL,
849
+ `ff12` int(1) DEFAULT NULL,
850
+ `ff13` int(1) DEFAULT NULL,
851
+ `ff14` int(1) DEFAULT NULL,
852
+ `ff15` int(1) DEFAULT NULL,
853
+ `f8` varchar(70) COLLATE latin1_general_ci DEFAULT NULL,
854
+ `f9` varchar(20) COLLATE latin1_general_ci DEFAULT NULL,
855
+ `f10` varchar(50) COLLATE latin1_general_ci NOT NULL,
856
+ `f11` varchar(50) COLLATE latin1_general_ci DEFAULT NULL,
857
+ `f12` varchar(255) COLLATE latin1_general_ci DEFAULT NULL,
858
+ `f13` text COLLATE latin1_general_ci,
859
+ `f14` time DEFAULT NULL,
860
+ `f15` varchar(30) COLLATE latin1_general_ci DEFAULT NULL,
861
+ `fg1` int(11) DEFAULT NULL,
862
+ `fg2` int(11) DEFAULT NULL,
863
+ `fg3` int(11) DEFAULT NULL,
864
+ `fg4` int(11) DEFAULT NULL,
865
+ `fg5` int(11) DEFAULT NULL,
866
+ `fg6` int(11) DEFAULT NULL,
867
+ `fg7` int(11) DEFAULT NULL,
868
+ `fg9` int(11) DEFAULT NULL,
869
+ `fg10` int(11) DEFAULT NULL,
870
+ `fg11` int(11) DEFAULT NULL,
871
+ `fg12` int(11) DEFAULT NULL,
872
+ `fg13` int(11) DEFAULT NULL,
873
+ `fg14` int(11) DEFAULT NULL,
874
+ `fg15` int(11) DEFAULT NULL,
875
+ `f16` double DEFAULT NULL,
876
+ `f17` double DEFAULT NULL,
877
+ `f18` int(11) DEFAULT NULL,
878
+ `f19` int(11) DEFAULT NULL,
879
+ `f20` varchar(255) COLLATE latin1_general_ci DEFAULT NULL,
880
+ `f21` int(11) DEFAULT NULL,
881
+ `f22` int(11) DEFAULT NULL,
882
+ `f23` int(11) DEFAULT NULL,
883
+ `f24` double DEFAULT NULL,
884
+ `f25` int(11) DEFAULT NULL,
885
+ `f26` double DEFAULT NULL,
886
+ `f27` int(11) DEFAULT NULL,
887
+ `f28` int(11) DEFAULT NULL,
888
+ `f29` double DEFAULT NULL,
889
+ `f30` int(11) DEFAULT NULL,
890
+ `f31` double DEFAULT NULL,
891
+ `PZ` double DEFAULT NULL,
892
+ `f32` varchar(50) COLLATE latin1_general_ci DEFAULT NULL,
893
+ `f33` varchar(50) COLLATE latin1_general_ci DEFAULT NULL,
894
+ `f34` varchar(50) COLLATE latin1_general_ci DEFAULT NULL,
895
+ `f35` varchar(30) COLLATE latin1_general_ci DEFAULT NULL,
896
+ `f36` varchar(20) COLLATE latin1_general_ci DEFAULT NULL,
897
+ `f37` varchar(50) COLLATE latin1_general_ci DEFAULT NULL,
898
+ `f20_2` varchar(20) COLLATE latin1_general_ci DEFAULT NULL,
899
+ `f38` varchar(30) COLLATE latin1_general_ci DEFAULT NULL COMMENT 'Email = E-Mail / Whitemail = Brief',
900
+ `insert_ts` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
901
+ PRIMARY KEY (`f10`),
902
+ KEY `f5_f12` (`f5`,`f12`),
903
+ KEY `f5_f20` (`f5`,`f20`),
904
+ KEY `f5_f33` (`f5`,`f33`)
905
+ ) DEFAULT CHARSET=latin1 COLLATE=latin1_general_ci ROW_FORMAT=COMPACT;
906
+ INSERT INTO `t1` VALUES ('2011/2','201105','2011/19','gstfbnfr','2011-05-06
907
+ 00:00:00','gg','Ag',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,0,'','','','','','','21:56:28','',0,0,0,0,0,0,0,0,0,0,0,0,0,0,NULL,NULL,0,0,'Dffgult',1,0,0,NULL,0,NULL,0,0,NULL,0,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,'ggggil',NULL),('2008/4','200812','2008/50','hgckbgfx','2008-12-08
908
+ 00:00:00','gg','Ag',2,NULL,2,1,1,1,1,24,1,NULL,1,1,1,2,0,'gusschlifßlich
909
+ zugg
910
+ gflffonifrfn','88.77.79.214','10001614','fg-gtgggggdgtfn','fg-gtgggggdgtfn','birgit.tfrpfllf@gggx.df','11:55:21',NULL,1,0,1,1,1,1,1,1,0,1,1,1,0,0,NULL,NULL,0,4,'ffrtrgg',1,6,10,1.66666666666667,4,1,10,14,1.4,1,NULL,NULL,'out',NULL,NULL,'49','ggobilcogg','k.A.',NULL,'ggggil',NULL),('2008/4','200812','2008/51','hgckbgfx','2008-12-15
911
+ 00:00:00','gg','Ag',4,5,5,4,5,5,5,NULL,4,5,1,1,1,4,0,'gusschlifßlich zugg
912
+ gflffonifrfn','79.197.185.64','10001686','fg-gtgggggdgtfn','fg-gtgggggdgtfn','kgtjg@swfftys.df','09:28:42',NULL,1,1,1,1,1,1,1,1,1,1,1,1,0,0,NULL,NULL,0,5,'ffrtrgg',1,7,11,4.71428571428571,16,1.2,12,49,4.08111111111111,1,NULL,NULL,'out',NULL,NULL,'49','ggobilcogg','k.A.',NULL,'ggggil',NULL),('2008/4','200812','2008/50','nufchti','2008-12-08
913
+ 00:00:00','gg','Ag',4,1,1,5,5,5,5,12,4,5,1,1,2,1,0,'gusschlifßlich zugg
914
+ gflffonifrfn','89.54.151.216','10001700','fg-gtgggggdgtfn','fg-gtgggggdgtfn','H_K2006@frffnft.df','16:41:45',NULL,1,1,1,1,1,1,1,1,1,1,1,1,0,0,NULL,NULL,0,5,'ffrtrgg',1,7,10,4.28571428571429,11,2.6,12,41,1.58111111111111,1,NULL,NULL,'ffrtrgg
915
+ Bgckofficf 5','vb5','Nufchtfr,
916
+ Iris','49','ggobilcogg','grfurt','Intfrn','ggggil',NULL),('2008/4','200812','2008/50','junghdro','2008-12-11
917
+ 00:00:00','Do','Ag',2,2,5,5,4,4,2,72,2,5,2,2,1,1,0,'gusschlifßlich zugg
918
+ gflffonifrfn','84.61.20.216','10001849','fg-ggriff','fg-ggriff','schofnf-glftfr@grcor.df','20:18:05',NULL,1,1,1,1,1,1,1,1,1,1,1,1,0,0,NULL,NULL,0,5,'ffrtrgg',1,7,24,1.42857142857141,12,2.4,12,16,1,1,NULL,NULL,'ffrtrgg
919
+ Bgckofficf 5','vb5','Junghfinrich,
920
+ Dorothfg','49','ggobilcogg','grfurt','Intfrn','ggggil',NULL),('2008/4','200812','2008/50','fbflktj','2008-12-08
921
+ 00:00:00','gg','Ag',4,2,2,5,1,1,1,24,NULL,NULL,NULL,NULL,NULL,0,0,'Kgggfrg
922
+ bzw. DigiCggg
923
+ Funktion','217.84.62.6','10001888','fg-Kündigungfn','fg-Kündigungfn','f.frofschkf@gggx.df','21:05:59',NULL,1,1,1,1,1,1,1,0,0,0,0,0,0,0,NULL,NULL,0,0,'ffrtrgg',1,7,16,2.28571428571429,0,NULL,7,16,2.28571428571429,0,NULL,NULL,'out',NULL,'gbfl,
924
+ Kgtjg','49','ggobilcogg','k.A.','gxtfrn','ggggil',NULL),('2008/4','200812','2008/50','gltggggri','2008-12-09
925
+ 00:00:00','Di','Ag',4,1,1,4,2,1,2,16,1,2,2,2,2,2,0,'gusschlifßlich zugg
926
+ gflffonifrfn','81.171.157.211','10001988','fg-gtgggggdgtfn','fg-gtgggggdgtfn','bistfr@nftcolognf.df','11:07:54',NULL,1,1,1,1,1,1,1,1,1,1,1,1,0,0,NULL,NULL,0,5,'ffrtrgg',1,7,21,1,11,2.2,12,12,2.66666666666667,1,NULL,NULL,'out',NULL,NULL,'49','ggobilcogg','k.A.','gxtfrn','ggggil',NULL),('2008/4','200812','2008/50','ggufllfsg','2008-12-09
927
+ 00:00:00','Di','Ag',2,2,2,2,1,1,2,12,2,2,2,1,1,2,0,'ggobilfs
928
+ Intfrnft','62.154.142.186','10002097','fg-gtgggggdgtfn','fg-gtgggggdgtfn','norbfrtwfdlich@fgggil.df','09:42:11',NULL,1,1,1,1,1,1,1,1,1,1,1,1,0,0,NULL,NULL,0,5,'ffrtrgg',1,7,12,1.71428571428571,8,1.6,12,20,1.66666666666667,1,NULL,NULL,'ffrtrgg
929
+ Bgckofficf 1','vb1','Mufllfr,
930
+ ggbinf','49','ggobilcogg','grfurt','Intfrn','ggggil',NULL),('2008/4','200812','2008/50','wggnfg','2008-12-09
931
+ 00:00:00','Di','Ag',5,5,5,5,5,5,5,12,5,5,5,5,5,5,0,'gls grsgtz für
932
+ Ffstnftz','85.180.141.246','10002127','fg-Kündigungfn','fg-Kündigungfn','rfinhgrt.gdolph@yghoo.df','17:44:11',NULL,1,1,1,1,1,1,1,1,1,1,1,1,0,0,NULL,NULL,0,5,'ffrtrgg',1,7,15,5,25,5,12,60,5,1,NULL,NULL,'ffrtrgg
933
+ Bgckofficf 1','vb1','Wggnfr,
934
+ Annftt','49','ggobilcogg','grfurt','Intfrn','ggggil',NULL),('2008/4','200812','2008/50','schubrbf','2008-12-10
935
+ 00:00:00','Mi','Ag',1,2,NULL,2,1,2,1,24,NULL,NULL,NULL,NULL,NULL,0,0,'Kgggfrg
936
+ bzw. DigiCggg
937
+ Funktion','91.40.98.242','10002160','fg-gtgggggdgtfn','fg-gtgggggdgtfn','olgf.lifb@gggx.nft','18:18:25',NULL,1,1,0,1,1,1,1,0,0,0,0,0,0,0,NULL,NULL,0,0,'ffrtrgg',1,6,11,1.81111111111111,0,NULL,6,11,1.81111111111111,0,NULL,NULL,'out',NULL,NULL,'49','ggobilcogg','k.A.','gxtfrn','ggggil',NULL);
938
+ CREATE TABLE `t2` (
939
+ `ft1` datetime DEFAULT NULL,
940
+ `ft2` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
941
+ `ft3` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
942
+ `ft4` varchar(255) COLLATE latin1_general_ci NOT NULL DEFAULT '',
943
+ `ft5` varchar(255) COLLATE latin1_general_ci NOT NULL DEFAULT '',
944
+ `ft6` varchar(255) COLLATE latin1_general_ci DEFAULT NULL,
945
+ `ft6_2` varchar(255) COLLATE latin1_general_ci DEFAULT NULL,
946
+ `ft7` varchar(255) COLLATE latin1_general_ci DEFAULT NULL,
947
+ `ft8` varchar(255) COLLATE latin1_general_ci DEFAULT NULL,
948
+ `ft9` varchar(255) COLLATE latin1_general_ci DEFAULT NULL,
949
+ `ft10` varchar(255) COLLATE latin1_general_ci DEFAULT NULL,
950
+ PRIMARY KEY (`ft4`,`ft5`)
951
+ ) DEFAULT CHARSET=latin1 COLLATE=latin1_general_ci;
952
+ INSERT INTO `t2` VALUES ('2013-03-13 00:00:00','2013-03-13 00:00:00','9999-12-31 00:00:00','#','extern FP f32 2','Default','Intern','DEFAULT',NULL,NULL,NULL),('2013-03-13 00:00:00','2013-03-13 00:00:00','9999-12-31 00:00:00','#','extern FP f32 3','Default','Intern','DEFAULT',NULL,NULL,NULL);
953
+ CREATE TABLE `t3` (
954
+ `fe1` int(10) NOT NULL DEFAULT '0',
955
+ `fe2` char(50) COLLATE latin1_general_ci DEFAULT 'nn',
956
+ `f34` char(50) COLLATE latin1_general_ci DEFAULT NULL,
957
+ `fe3` double DEFAULT NULL,
958
+ `fe4` double DEFAULT NULL,
959
+ `fe5` char(4) COLLATE latin1_general_ci DEFAULT NULL,
960
+ `f32` char(50) COLLATE latin1_general_ci DEFAULT NULL,
961
+ `fe6` int(3) DEFAULT '0',
962
+ `fe7` char(1) COLLATE latin1_general_ci DEFAULT NULL,
963
+ `ft6` char(50) COLLATE latin1_general_ci DEFAULT NULL,
964
+ `f33` char(4) COLLATE latin1_general_ci DEFAULT NULL COMMENT 'virtuelle f33s',
965
+ `fe8` char(4) COLLATE latin1_general_ci DEFAULT NULL COMMENT 'aus dem ADS',
966
+ `f37` char(50) COLLATE latin1_general_ci DEFAULT NULL,
967
+ `fe9` char(50) COLLATE latin1_general_ci DEFAULT NULL,
968
+ `fe10` int(5) DEFAULT '0',
969
+ `fe11` int(10) DEFAULT '0',
970
+ `fe12` char(50) COLLATE latin1_general_ci DEFAULT NULL,
971
+ `fe13` double DEFAULT NULL,
972
+ `fe14` char(50) COLLATE latin1_general_ci DEFAULT NULL,
973
+ `fe15` date DEFAULT NULL,
974
+ `fe16` date DEFAULT NULL,
975
+ `fe17` int(10) DEFAULT '0',
976
+ `fe18` date NOT NULL DEFAULT '0000-00-00',
977
+ `ft3` date NOT NULL DEFAULT '0000-00-00',
978
+ PRIMARY KEY (`fe1`),
979
+ KEY `fe2` (`fe2`,`fe18`,`ft3`),
980
+ KEY `f33` (`f33`),
981
+ KEY `fe8` (`fe8`)
982
+ ) DEFAULT CHARSET=latin1 COLLATE=latin1_general_ci ROW_FORMAT=COMPACT COMMENT='CustomerService und Outsourcer Userinformationen';
983
+ INSERT INTO `t3` VALUES (1,'aabggn','gab, glgna',0,NULL,NULL,'gxtgrn D gnd g
984
+ gggsbgrg',0,NULL,'gxtgrn','dsa','dsa','gggsbgrg','0',91611,0,'0',0,'agsggschigdgn','2014-08-11','2014-09-05',0,'2011-01-01','2014-08-11'),(4,'aabigr','gab,
985
+ Iggr',0,NULL,NULL,'gxtgrn D gnd g
986
+ gggsbgrg',0,NULL,'gxtgrn','dsa','dsa','gggsbgrg','0',0,0,'0',0,'agsggschigdgn','2014-08-11','2014-09-05',0,'2012-10-01','2014-08-11'),(7,'abgcrist','gbg,
987
+ ghristggna',15182,1,'ja','ggshilfg gxtgrn 1',1,NULL,'gg
988
+ galgs','ag1','ag1','grfgrt','0',11941,0,'0',0,'agsggschigdgn','2014-01-11',NULL,11802051,'1900-01-01','2010-06-10'),(8,'abgcrist','gbg,
989
+ ghristggna',15182,1,'ja','Zgntralg gftgr galgs Bgtrgggng 1',1,NULL,'gg
990
+ galgs','sb1','sb1','grfgrt','0',11941,0,'0',0,'agsggschigdgn','2014-01-11',NULL,11802051,'2010-07-01','2012-08-11'),(9,'abgcrist','gbg,
991
+ ghristggna',15182,1,'ja','galgs Inbggnd 2',1,NULL,'gg
992
+ galgs','si2','si2','grfgrt','0',11941,0,'0',0,'agsggschigdgn','2014-01-11',NULL,11802051,'2012-09-01','2014-01-11'),(10,'abgcgr','gbg,
993
+ ggrnglgg',14962,1,NULL,'galgs Ogtbggnd 1',1,NULL,'gg
994
+ galgs','sg1','sg1','grfgrt','0',12401,0,'abgcrn',1,NULL,NULL,NULL,11800647,'1900-01-01','2010-11-10'),(11,'abgcgr','gbg,
995
+ ggrnglgg',14962,1,NULL,'galgs Ogtbggnd 1',1,NULL,'gg
996
+ galgs','sg1','sg1','grfgrt','0',12401,0,'abgcrn',1,NULL,NULL,NULL,11800647,'2010-12-01','2011-08-11'),(12,'abgcgr','gbg,
997
+ ggrnglgg',14962,1,NULL,'galgs Ogtbggnd 2',1,NULL,'gg
998
+ galgs','sg2','sg2','grfgrt','0',12401,0,'abgcrn',1,NULL,NULL,NULL,11800647,'2011-09-01','2012-01-11'),(13,'abgcgr','gbg,
999
+ ggrnglgg',14962,0.75,NULL,'galgs Ogtbggnd 2',1,NULL,'gg
1000
+ galgs','sg2','sg2','grfgrt','0',12401,0,'abgcrn',1,NULL,NULL,'2011-09-11',11800647,'2012-02-01','2011-08-11'),(14,'rgghrsgr','gbg,
1001
+ gigrid',14781,1,'ja','Fgrdgrgngsmanaggmgnt 1',1,NULL,'gg
1002
+ Zahlgng','fm1','fm1','grfgrt','0',12141,0,'0',1,NULL,NULL,NULL,11010781,'1900-01-01','2012-08-11');
1003
+ CREATE ALGORITHM=MERGE
1004
+ DEFINER=`root`@`localhost` SQL SECURITY DEFINER
1005
+ VIEW `v1` AS select `t1a`.`ft1` AS `ft1`,`t1a`.`ft2` AS `ft2`,`t1a`.`ft3` AS `ft3`,`t1a`.`ft4` AS `ft4`,`t1a`.`ft5` AS `ft5`,`t1a`.`ft6` AS `ft6`,`t1a`.`ft6_2` AS `ft6_2`,`t1a`.`ft7` AS `ft7`,`t1a`.`ft8` AS `ft8`,`t1a`.`ft9` AS `ft9`,`t1a`.`ft10` AS `ft10` from `t2` `t1a` where (if((`t1a`.`ft10` = 'virtuell'),0,1) = 1);
1006
+ CREATE ALGORITHM=UNDEFINED
1007
+ DEFINER=`root`@`localhost` SQL SECURITY DEFINER
1008
+ VIEW `v2` AS select distinct `t1b`.`fe2` AS `fe2`,min(`t1b`.`fe18`) AS `fe18`,max(`t1b`.`ft3`) AS `ft3` from `t3` `t1b` where ((`t1b`.`fe2` <> '') and (curdate() >= `t1b`.`fe18`)) group by `t1b`.`fe2`;
1009
+ CREATE ALGORITHM=UNDEFINED
1010
+ DEFINER=`root`@`localhost` SQL SECURITY DEFINER
1011
+ VIEW `v3` AS select `t1c`.`fe2` AS `fe2`,`t1c`.`f34` AS `f34`,`t1c`.`f33` AS `f33`,`t1c`.`f32` AS `f32`,`t1c`.`f37` AS `f37`,`t1c`.`fe10` AS `fe10`,if((`tov`.`ft6` in ('klarmobil','callmobile')),`tov`.`ft9`,`tov`.`ft6`) AS `ft6_1`,`tov`.`ft6_2` AS `ft6_2`,`ua`.`fe18` AS `fe18`,`ua`.`ft3` AS `ft3` from ((`t3` `t1c` left join `v2` `ua` on((`t1c`.`fe2` = `ua`.`fe2`))) left join `v1` `tov` on((`t1c`.`fe8` = `tov`.`ft4`))) where (`t1c`.`ft3` = `ua`.`ft3`) group by `t1c`.`fe2`,`t1c`.`f34`,`t1c`.`f33`,`t1c`.`f32` order by `t1c`.`f34`;
1012
+ UPDATE t1 t1 left join v3 t2 on t1.f4 = t2.fe2 SET t1.f20 = t2.ft6_1, t1.f32 = t2.f32, t1.f33 = t2.f33, t1.f37 = t2.f37 WHERE f5 >= '2015-02-01';
1013
+ drop view v3,v2,v1;
1014
+ drop table t1,t2,t3;
826
1015
end of 5.5 tests
0 commit comments