python-SQLAlchemy-doc-1.2.7-lp150.2.3.1<>,#p]_ָ/=„6_l p 7r> ē0-eu%޴jO1Zҥ_&bx큄8N\-8F]Upej&dgpZ\j G!- Fz0k=zCM7% m,8.2eϷ'+33  }Ԩ|Je{dop[AW!G~>;?d * N 39@MtM  M  M M XiM YM^MemMklMqPqqr(r;8rD9r:tjFGMHMIHMXY\M]M^5b Rc d e f l u MvzM`djCpython-SQLAlchemy-doc1.2.7lp150.2.3.1Documentation for python-SQLAlchemyThis package contains HTML documentation, including tutorials and API reference for python-SQLAlchemy.]_cloud129'%openSUSE Leap 15.0openSUSEMIThttp://bugs.opensuse.orgDocumentation/Otherhttp://www.sqlalchemy.orglinuxnoarchnLI<<K;IJ75IlW/-15`IYC~P*J\J<>5_c__01ECr^?PX+i_]bTjB] )a=*# VRZZ+ciY`/lc 8G_6JXU]݁.$4 FQU,>ovε|SQ(KrV PV-IhH6PƁ Wj5M- c :qaDW+1lp b.M4G_gAv*n(4G@@6P6x9Tz7(X25bQb}!Zb9F c^)1L'[qd)aK0e(66*=:C,Wr@h jK D !X V ,  2I xW   v 7=#+%;!TV# AAA큤AAA큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤A큤]_]_6ZMZMFZMFZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMYZZZZM^ZMZMZMZZZZM^ZZZZZMZMZM[ZZZZZZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMZMFZMZMFZMFZMZMFZMFZMFZMFZMZMFZMFZMFZMFZMZMFZMFZMFZMFZMFZMFZMFZMFZMF]_6ZMF]_6ZMZMFZMFZMFZMFZMFZMFZMFZMZMFZMFZMFZMFZMFZMZMFZMFZMZMFZMFZMFZMFZMZMFZMFZMFZMZMFZMFZMZMFZMFZMZMFZMFZMZMFZMFZMFZMFZMFZMFZMFZMZMFZMFZMZMFZMFZMZMFZMFZMFZMZMFZMFZMFZMZMFZMFZMF88f12eb31ce6e8660d169eefa827207bbebf11270917708ac6066d7f4986a5071f6ec419a8188e4e9d105ac1ba99f521dae01e3f33bd4d7c94a11f588abfd1013f3241d6486b81aa6c0352ba344e4b1876d8cfc34e17caaf35ad7760288edc8900270b0b985b8df00d487e5305ff5837a7393e8e13dfd36e6f9b198da5ac4a94edfc389c9cab2f7dad0e956cb7a2938fc695e8fdc44d4254f98eda392917ee6199a128d5982fc2c4bd41ac3feae102a62cb0fb5779f6617cd3bd5d3a0c90bd12483d11ff9307cb11a3241f3696f920919ca0f1f12501c899ee669b7b545c5acb749d2964ab82f1a157c860e7452d2cb94955550b01ab1daa433e62cf2d6b02a003a9b4f227271ac27c4473cc71addc958ef20d7eb683f8ff82e0b0e040cf9736fd00e8acbdc275f555d94fb849781cae36cf32e90a245e35596625a077fde2663a03891c990a5be5fe868e440bf9af2fd417bf6c759cb450519dfb1f0e9df2a360ca0181503a9f14d96dae7fd617d3e9e75eaa998e2f41a8a7f281cb971d2f5881a9b776b2b6d6d60668a9a215d7458bfa2d01f8a0977546f4e4a45fa2b51fbf3071546c52dbe6b2ceb0ddc31e3e7c089473cd93995142f1d4365c4ca25582d551ef753b24c28fece092ffc67985592a7f232c9dc3dff87b773740ec11ff7be743c7b67d33d1245d3f481d02a24ea0f180fc78a1b1a0627f3a22ad23752316712e91f5b73ff5b12f490fc1c2d0832be7d6fce4a241467a8bfd41edc33089528e2fb063e08c826bf1820fbe192c7fedc51f93c2739425195c92e25c32606c8e821dfdd1900447ee58c8e64b9174f7ed1a22e0dcc06b7802677203f39754d9345a8515800ba2850a6ddd9994325407618e29566c7b1ea57dcaa3eede9d6b8f73157b00d781105be6416d3d3b8dc912cc7538e55ad92155c6054f8e0bdcaaed737f4cfc25c3acaedb61a5d6e02bf5748adf19f0f451a8dec394098ffaf99dc9605846f9b834af2052d3157d99c19c75a7a771d4144520fabdb834db884bc320bfd7281feabd56b48b9691e5d8ca480fcb16d31115ff7c0ea2306b228a3b7a8f2f592af7adc66d994eb1999259dafa5ccc1e43efb7a08ee0338358d65c1edc97f1788fada50edabbdc1d21d953559bc151ef80da16a941d15c6f4f6307404557f730a0f52b4dea9d4c694b5902dea148e519c22263d3dc4ba8cf2a7b494704604f09dfa09cd6d65ece683e42eabada450ed6c7866ffa73319a8dbe8e67ec1cc1dd79cf983cec2f70dbb4f7e73f404eb1357ccde71e92a1965e4ca6ce36a027e7053a4fd5fc8d2a34340a10502821a5d37bcd728b21d82f8ad4ee3f2b277ea514334e015c2e9650bd652aa1f8e6a3ded1657c17b5f6e09e352cad9e7ecc85d9dba267a6a8cc77d060b4a99738de5f99e4c9dda54d3086370cd8b45eff470974c1deba959f828f9b0ef75292bf511b5fd91fbd7f22063bc9b27482aa7d12c859e38faadc96e02213164dea52db32341c5ae4a6fcb7604edf91f40b1d1d6772e524ea80a8b29b35c9cdf64e5cd901c1eba7f99ad14c7b368e31752cf52139ebd9309deb39cf47764acab8e6c98f388cb695abf8fb6df0487658f8776bf718eae04722c91894cb75bd8edda369569c21ec8631684a96e74c1f3555fb15ff251d6f54879b52ed52bb6b03ed0b400f00f8f5b407686d4fe1de2794a47cbf3c0f02f2e12789bb358fadc60be1b8c231f666640b4073245df88bd79608e9aad46047658d4f572e914bd4e003d4d5011f50b58eb13076255a59161c3c12089b5aab99074ddd8efa79abbae4c9dfd92606126cfbe10260ac0eee588523d76d751192339bb44d295534ee76f15751c2c52dd1ac57ee0bb2a68db2d4cd0330fe5732360f6ee4937b3df3e9f169c95183f6f193817901bad823118207d51e100e34ec399fed1c7bb3a10427bcc812821a0554b7c1b5669f6daf117ba8e648431f0218ca52438e7bb1d66ce2dec8cc9d69f31a1e98716efb98f43b258fb1849de69759c78bc0589646ee73b416865e7f6eae21ba043322d58f00f3c2d1f395baaba2139fdf202b745f71c591ebf5c36dc22cb3c22951565b8d2c986f7857983b4752dfc96b0669f9a034dcaf6d96b66a9fdd7d631bde2ff1b812e3856fdfea995e686f44d5498b680f92cd8cc361372a503f655bb090abccf3ac3e93a8ea61a60398db407543af5d47b61fc4383784ca3ff8589a1bb48d19d06fddc78d6120cbc9ad31f275f62f4cce8aeb4cecc7ccb78fc4266465bb97f7e8cfa623ce7682a30fcc207446e8d59e100737b92f8825f5ed0740482819f3fba7826297908bbd44ff00b64ee95d262d60866319c7cf09c3d5b2926ea9d9f068801c8ee0724dac66604b03ac50b18295775fb8b0b215a51fc05bc152a12ab32d44cda758721c5df53f2aeab1b1e3490aa56117279b413625162e3d6bafad52f379cb84155046b8d75db6304e06134391472aa96a09b54646573a89290712bf8737d6d80904607315d86a4c46aa26b22bfc49431d9138cc502813e938e55f705a978066a6b3277c26d749d118f250e187921f32c80bdcc8bbfd0d7322839c51874ecc27181e6e17af047a0404a05e3e9e64c89ca40639d0bb71502306afdbc8646f6ef362b79c54a8f9211aa290ad8b363575fc30ab04aa494f8ab239fba636663b950ccff763bd3b95a3c214ee2344ec895c4bc9a16aebf38c4b950f59b8e501ca36495328cb9eb622218bce9064a35e3ec4e78178884a783e53abea2af71081ceed3df691aed41de197d1daa4037699ca0d9027289ffa5d9f6c8b4e0782bb31bbff2cef5ee3708ccbcb7a22df9128bb2187083882cc6015984eb0411a99d3981817f5dc5c90ba24f0940420c5548d82de47e7fc50db3699f1ca41ce9a2ffa202c00c5d1d5180c55f62ba859b1bd6cc00854115199b96a130cba02147c47c0deb43dcc9b9f08b5162bba8642b34980ac63c67b5260b50a0f434e9b26585479ce67ab2184adc7b31c26d665642d3512835fe8d039d87d8f443d02abb76df25715de53a329a7a35cb58d4767c08a574fbe000b0c104634209312a6e71cafca8d8701f43e28fbaa37686ee565ae4378530882f808f0aa32fbe90fb9c9c846917faff3fdd4e236c284b76c02dd33753dc9017742d8fad13bc28fc726775196ec9ab953febf9bde175c5845128361c953fa17f4cfe678a4446900f4081ab8d74ef3d1f8b1002edbf8cae3db292fcca0637310ed108f280badfe5ec5168738c4f70a59bc6ea9d1e9243ff2b951386fb668e935023e61ad44de4625bdd7aa3b1ac8ddad355c919de8a23bd16fb36053901ff23cb9d7e24628f1299349ab7dfc99d8378a8a39134709719e6ddc21e6d5b4c3aa06b39947df5853c42ec21e6863dc41e4e4ecc1490edb17732f03dcff8108895d99f5de3c3db997a55adf8326b8dcbb75a89f479ef0833e68baeaddccff774484ea123b4f152b9e97e9e690bd7f310e102fa7f87dbd8db6ace40843ee3672328b32a5da450b78eb55fca4a42f0dc8111b672b6dd8cadc89cf075540afed8f464fb2f33d26fdf5e24622d3d5d0a9cbe67fe730c92a9fe3b227121c2bfc2c54426c73b2cce632907ef6e8724e5329246d35e8df6eb60e28186234467adae7afb1604a154573e16b0adb262b387d5735c8078d9cdcd59841689ad6bbda3b748ffee01da6a6e10129f0866993a5a991132659c71666c4705c5ecebba08e01e6340b7b42fa3a0ce4a3178bd52bd582ae7765abd41ef722994535eb88e9212e4110f450e905ccd9f2e22cb413ee69550875ba131ac8a23a07ff57c2825202ba77e45dcd4f8fde8db3fec4d7b1511b385ce77aa51f70a24ddff43ceb3b90a62638a5c48821e7222864069bde620b03abf66c7b2a9885a97f1c695efc0a65ec184cc1bec421fc9923db14cbe09a58e583d0541d04e20376355c1a012c6bf5ddc0b18a106788eacb7c1d4516ee81c2b57ff0b89ec7c219d79ad0dd7d8b0fe677aa4778d0694ef6cde1328779a582257c5599389fbd9a28e4e6cbcb0bd7cf367410d9056c9c096c13b39561f303728cb038e922cd636c40f656f2350c033179304566f0ba1b97e41298b7524ce5cf4cccf8cf38ab90d03927e03f52753b722e7d00f01ae686e0eea8a0bca85e6db0d153fcaaf71f5e21d99549f334e7cf2e4cd702d491ef8c6fb849e86880c0acfde4f69b82673dd278193d721d184a48bac7b3568a1ecafc35c451a8cddb3e468b59c7bc5a3cb6f5c9dc489d4b32670de7da6f03729e411cf0d0927058c4b27b7dd2222b4b029db48282d79a5553aa881c94673996bb7df676ab4e9fb67ab2036c93b5361786533e32ebb1a3d675144a25f1e706d0c856b54ed98fc66e50cd54347f576e3aec346e3b045f3eb56adf04c24fff65bf713f88571ed86347a1e4c573cad99cd3a006eb24d212e05ae33ca2e331ec6b351342c8e4e75d195d8a42a45c652fb0f5ea0431099a3ada1f1e2ff5e429ad66416ca9b503bed2863ffe9eb1287d748e08085b6b51142cc6af9baf8afe3abd9481a31ffe0567c044d37e33929e925dddbfd213319bd6e9d4e2b70d8800c09969befdcbe7f735cc6b8eba9cd20070f8995ac8b4db7c6e83ce16487631f4ff692297191cf194fab6fc67f087ef1c85bf31ea6fbc21f8eac156cf5f026c63f65a7ca2a0ab1c31ffae0faa4dd0be8d08eb9d0689cef4531f4026d4f59d433e6dff2a92d874b46967b296b7c8b9af1b9e8a39b40d2a5475d36114284f9ff469f5c883b734be8b317679d51727c20a96335550c38e2334d154606b6358cd0e8db890edc353e3fe8974076383847eb928caa9b52f4484bb91f731ad346a961a983b80304a51a03752b378ce92e1085c93db200e12ce65d6ea6d15238246341e7779aefbb8d67668e2843bb14f9614707e0e739637add54a6e95edcc4228a86e33158b7d23e8c63a81c12529aab52d1e72983eeddb4a5f76d8dd554b01879be63a5a777ce685445b25e7363e6e0a9cb0c8255df74f7f1d4778e1bc13e9a15f87f53ce0d00b63c6ef730ada10929ed2fc2e0c6162e227f206ccf4bc4926de9c39666776e31fe04c90a28a7811dbacbcd2d8a8bd4e0d5ca3f5942bfb6715096c70ee76e93a5997286df6d19aab60bef572b976e670ca8ad3cf72b491237341f9667ce74053f26843777ddce900d4b2ff328d4319cdbda676df23cc61ff4039f1e5d3bee82a1610a8154a398e763a41ebf25679dcb60ca610ce37f158e005708643d118e213e96a86130a6c7428835aebfb880e1b7fda79327f63333829e7aa33264da87b194dab7290b9097e295a23f6b3c07b6825f75c1a6644c8a12e3a6b52ad86a4360a21a123a2a5f283018e66cb7601b09cde8cac0da54833e0570b808a6dec42bf33d04acc4fe9bfd13022305f9f3811b3581ade063bb368e2ec99990c45d385e14dddb2833fc1d8ca3a85c59fe7b83687b3cdf5fbdf5707c725fa3c3c094f635e108e8798594374775543d05dc3436c7330cde57ae5e3e8d43177dba3beaef9f6fc3c08bf19f99f695a6e6c724b5cfc24679be64e3a2efc14c3961baa4e8770f0e504188c4fd57c2f90332d754395bf9e0277c625f2aaf0c74230f32221a73357030f295d1ee4afaa1d16da2e82df740e8fb522278e8336a08a7eecbc3becfdba99cbe9cd64aec21014e46728e7e53e42562ab1d6fa9c800e0d65cd50b4f1daf889e5c70eeb4f7a3ebf4a28fec3b881c90ffda535c0e970e6f4d21ee5a1cdd8b34127495e750e9d56f8b192bc34f9880df00b73c816717f76736cfd1733699590686b5058ebf1c86f836f5f92bd62bbd8645aaf501538d90d19e3809020994a5e671f8fcad5c453f05a019e9469af50253281913a3bb8882d224cf3b65c0b9fc12a395db1e22d83e187562b2460dc4c7419c5a0cd613d19047da1a808d9feb999c36dbea692f62d99a7ba97410d4d0755951ed796c5df7c915d18e2496e205bc6e9777c64bda83012e3f8e55a16e2a8118b0674115b660ddacb9eed307c900c3e8e522cfe272a03d81062b2c1cebb31d9e0a3c9fc1d826364766abb6f0f1b1efa8fb435f7d033448f501ef39ac2174380ba0249849cfd4339ea2aa16b37deae002e325a7dc61f3f6af57dd1b04c3a15245ab58a60347e24ff6ae3422f176187e39c96f617351f85f0849ef3b2b88d4e5b74b1bffbecc6f96ebb4954dc5fcb7ab9e60f9224ce11218c86abea90eb313568236f66396ed62e4dddc3d60d167eda592c6543727e6db70faefb85ffd8bf8214a955b8e675ccb2ad7ecc93a0eade41a4c3ee644cd47a0bcc36b5c95249ec5e5a4e9af7079bf4561823d7e072221ac3f4da36be6df9f8037d8a9000ed19aaf43745444ec3ee20fbd078f02a0c6940faeff9327fa3911e56424254d710acf0cc460075a7643c78debf8f9e672a94c176d33f105622ea3f5d78b5ad7da71e86e19f607f6239982c8dc918804a909a21802ed71210a424116286d12aba0f07e1777964759bccd472a2982a7e0095170c3d8d393da5e711ce0503e7a984008580a718ace1d9fa3262129c47216c253a504a238903600833272314c0182a706d47db77ac4c2ecd8bdf12f42ae8bbf457a3d69da2bb461fb00a6bbac3df28826f439345189e2aa7609497c180c0761f86d0e481946e3cedabb1f13bf4a396441dd900ff86689cac9e73ba076995e9865cd1db3ecc3db6a89b8b78443e24ee4415ea98724e92a21aefe0f1094dd6827a00bd9c8333882ab814c5c86c405179c6a5881bc50242cb8c78bf1ba54c9670daf7c3d13490434300dc8666ad42f42dc710392c8ad88ebcdc8f5586479a19ec5580fdeb28bf5094683ad76448ad02ef04b0409b410a160a708da0a89d257835b355571a2531baea6d2a3eefed3529d961e9967a99985955606be02aa4c3fc68c126e4cc7f039d935a2c58732baa3a622c718dde99fc1614606868f19bdb6d6198a14431f7cc0c4ee3e34c53b2a37dd61e938f1979a6f354cd4c998aff2f2cbe7eb5c7593a92f2d4d2756a8a9395932fa6d343f7c03f7c7228d8a30c1cbcd714779b24c7cdc85ccc661901f90fe90fa15d6e8b0ad8d5c1661bb58ceefe78cd4f1bba240b9eb9a8cecd99710827f8849894eea2b897c2515534efea51b5440d5cd644d398cc10f4debb1f267ab8b6a89e1276b12c90a0a01026b48a6cd294c90e964afa4c54e775ff81142f8ffc7a65d5f158e0e27c33414e226d474a87075d481c0882dda97e771ca9f40dae7061dc3707a4e4266c5749f5569a36920b686c1bc8cf9ab619b8b44ef8342174234ee76b71ee636cac26e39d2b0d98a5b11be589646e50db085214d14c630637a8abd73b27185ccd3e33756ed2b0a1d87b89065d88af713d1725290b115d195d9d55c633d6532ba0e7ff6eabc634dc45063111d6ae9d79c1df4f6fd63dfb1b16262167f51520f3d354d927648806d67e5576b2cab6086f50755aa9b39cebeaee4dabd3ebad53205e7bd3fc0bf7579e8c29d6b955eb8f3c3ea4b5dce87e772e033bf451e47890363f0203581b0f7023b704e3f9c0c67cb17e11ac8b398ca5bab296df7340f022e45614f51fb98220c02f36c9b32da8b29c99d0e2e0e1016e542086dcffef30a64e0d93d8c67f5948d712fc9cd1cdc250b154174579c7d390e784b9d5271aa58c1705c072e1f11f454bc4b25c3760e93034b6f201e8d73c1312e4392e7cf7a0a4ef8fece66d1b15624688f95e8f0217951fe7ed41ea797dbb857faefa098579c2d10c5140f726a11259006827cb48e3d6e579d63250a51f286f8d7ea3817650566f001a905756a0e20305448ee1b9d86dc7e49cd7dc88fd2e0c9305b7e62abf2ae52d4101b89c7cfae523720874a3007e396ac67e7ba9f234b09cf2ce83fbaaaf51151c1dc060ce72c6f9f83972a542fece6c9e11af4c01e7641bc2a6565278827f2efea25619b5edee799c4cba83e629d79811de8b8b594d598ea14133bd312c3108dd360169790c191479de934fd7a5218f7d98185ce8038adc0c8db0bf7746d90279327083e64b2e413ea5714447390c87c2c317875e580ec0eba2f777d18898cc2286e58fbfacc5ac0e9336942ba9333f82617311ade6bc8e7eb0e0d2a64ffb5411ea11994ec03424fd7ce971d52b9a1b34bb8106ebdbc17bd94c5133d9f0d7a8db9e263a0b076f314b5654b74ae4fd03c0e9ab969920b310136fccd5aaee65977620f6a2dca4e8e4d2fa90af95122feeb438a354da0cd9b2df8d425abc9ebc599d56ebcec258404396b600017b6f705f8193f77841cb82e51e398da78893851f6d5322d0b28c9efa3dffa42ab9d468761d30b61f0371890d6e3dec0877652ed889cb398a2c21ea65a8ea37ead52917df4c04adcef9482b25b3f16c230bb2534f30dcb58bb061c8baed358e4168ac4627956129547be0895356d49bd127494fd76662ec8e7f6dd92a7a6fac1edbaf5140803c02c086c84fa9ad4ece9131bc12d693ad3ea054ec8bfd804d2bd720c06d3ed0ae4a02d8a622b0d0242908ffe3c9f4750904a917e4d1fcf1f61aeef358b0dee249dbaf46c66e6bdbf79cc4039b28ebec9d54c2be67abcf3a12b0a6159bf28b4424ad67320e58b1c44e96b365f633235abd5f1db99668bb8f877bd14d80bd26f12c85fa67d048368369772f3935897174a05e72aea47626dca9691a3cb40b1ca403158ff3a3deeae2099a7aa118d9b8a64641562679a242baf23f2b6ce5308dd5237746b6a0a84558d65db3bec07068b4e3a6dd6b5f244d0e9bbf939cd5bfc600f3e8d46eabb559b997743b59781e77fa8dab222b5ce21dcc9664e5f210ad4c43866679945b9764f6b2de5566cbdb9510b6916eee1488395b7aae332030943960afbf553382dc1bf9ce90ef5a90d0ef66a424fd4a58731c91cae81c8cd5d15dcb72b577e732fab8daa087dd4b308f4b32a0199c2b39c9e640ab4fbf51828f5085622084aa35df5f3ea9cbab07d256adbbf267d1e89aaab7f1933e377861bc01ccf438522218984f867f8a9ee5db3447a55759a2b15ca782a484eeca2f991b06bdd8751341104e5ec747c8026f00f1de9eff822e303f8e01c56415f4cadf8636514cf73fa498dcab1bbf91be57d79da26481a43d529cfa2533a742ef5d36ffcc3ade3aec43e02862b685f3c149e6d235c7c56064444c2d0d0eb6d503b0d5ec80f5421a0295d7e6c0c93fc49397e8c0c8f6ddcf97aaa44e80c041b28fc8e283eec22723e6d29cf2197fec4c3256cb3260e194599336ceec98a5ece2cf6dc8cf4fbcb0385be7e77c10f30a4d4a544c8e4f5b13bc65eb9379dfa45c628cfb231d8cd0cbc2c67fb3bdc2067f839c7b368d70ccb7cde39ec6bb7b33fbf90638d4a178f63c54cf938ac405a2668e7e08941bf363524988b92464835bde0c8fed5eff22b2080248543f7e529d02ea67a80c7d7641418716ebbec1c00bc8aba0d2afb474e4a33f60f54daa41473cbe004901d0629b8b038b14e4e443b1c83fc402dfaf77b9e925ed2e21aa2bf1b2d00f1f5efdb2f507f61eb9f62ddd69f9f13d28f1450d56058eba6758b5ffe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855863449782e06aa392c80a821573f4afc7090430d3ab88754c560f9388218c7ba7ce9202cf1d547a5717c4f66886842e87c833571ebaeb71e7a9e850fff32843a12e45aaaa229dc25b932409fa11074f3db4739beec1bf02aae9cd77382e0ad13c74184772c75d1fd5ca6f5d06192eabba22caef1210430ef7c822246c25db1de6c488c3595a6801a2082f0c53fccc5d57193f0851f08e2c265565a9bc367fd5b691e0640abb616927cc097486153da5ca5ae01325dbcbda2b6b129b7d6171e6ec456c6068757f6587d37b65a76cc117b306798dfeb7deb1b07fd34907cd066ad8503088e52662dd92e2bd1bd5dfc6d64fe7bd0613b07ad32aa18ad360e2c219e8672ecd20c0facccbda7cedfa71b0acc05d75e185c373f86f60dc4d6fc5f9c6d2080f3c4185ee15fb2b79d02127068eec5637ac7729f4fcc59fe66f234b63cddf13712e519b00d21cd546e618e04495b939fc8d73ef5ad578dd1c17b194d31dbdf717e6ea54a078a861952c0ccb7a9b36d4b6791ecb14b1ca3d59044630f317ca6b570fba8cf9f56c5c2bdf18d974db28ac62e59a30a03c44becdc95f668ffb612cd4ae3edf94e22065c7a95513f03e55ce3b328ce942dfa68fc02d300e214af04127f60b0ff7213340934bd5f0500673b63071f36bb6533a12606d5acf5bc30b0590c40f33b77eb9885ec76db13479ca1a26de4181b04b6fa218b162d6e7ac7136d943c81b6df1478c3d091baf4e8a4252b70fdfb0c07a3a13027f35c86af77d8c61294ade9ec71de53390b98da54169b0b8fb89c87996917fa1f82e139421449c9cdc0a9b97deb47c71e51cf1953e0636b5e4b10eb47a918eb2c75ff51a92c3354d1763b26ca824b781d90822f7a2b8b2a56c839871b90ed8a7faaf8f5cdf8793ef486b824af1345c76a859f80d9d35bb4949c67dcac664211a2a1b4ef5b453ada636d178b6ad3ba668cf41b5829e8c22c38f9b004bb6c4eaa7567ec0ef7931f0edc816b378155ef69f7d03c0067928c077cbe302c4db82d59d7f1bccea13ff3d4a5b8985dddc0d85b261bbfcb3108f2e40c308e1a72ae6b3d27b82402e91f7ba7e5b0adf1abf67c97b0e2bc246c687c8319468335b54d42206a0e4c052a7dcaa53f6eed6c9d5f9fd5044d9779e82b1c37ccee6fc881af8f1d22d4ba0cbdd4b9b459fd2ee229480c8ae65864dbc480e905b62aed0046ac9303609e3249c5850ba54358bd6a7b3fb9454eea4666d09c3ef3740610271dbac2d0b1fbc147908b75241ca134a0e95b0e38491c9b2b78006c8a5ea46b465596ddc6d638d41d100934a4debb9b034ead38473405dae9bc05bc94f2fbcb1841e0e683f04712293d534caaf5cfba4846faf1f41a129c90626ab86c58f9094d037c444271cc46630ef9c62721a5a23e923ffad4da520fa2c7cccff46f2543dd2012acda9e9726ae29a0d4d54320f66cbad885e2e08443c113fefc8205c7218c1aa87e699a3361b67d96bec804db4bceca4fdf01a25c9deef05ad7958bd3f99c8d84b967255fcb90f782f44278d45660e1dd2af87b05919a09931ed7c6ffaf86465262a2da601c6444a02750ac111572e53cebe781a3c69575f22eeb579d57a8cce084f768564608d9c11aaabc53b464815aaa6537efc3eb066f96214c824dd203a37f3e1c59cc306a1f1824e61f3fa743f143c6ef42f3838a8bab388c00d771e1d254dc368409030b17129114ff4e496dea43d8506ff13515c912011d608b6ecce9cb726fdca438ccff06460826722ce8e27ac8c9dc81a845aab67958f3f6343a95aa5388ac245afcd6cbc1b95bbf2489f82e74416a3a63fb4cf547f17f53b91ac6555b36e13f69ad8bdfb5aa2a6885ada7588a8e8e70b328a22581a0abfd2b7d6187b9c9d49e28a76bc67b1c4db7f24ae3b174c6f52c49a7eac7506ffea61d163e3f640fb26b429543bf5e3f5fe3b3950f0864a0dc98b6e254caceb75c640ba8633f699c7521eb14d76ff0c84115c96bdc79e591fba91018148783d0bc1956f1ab01ba364f2476cea796757fb7b1d8cad1678ab4f08de219d4f1ccac9160c5637bbdd22a1c074f8a05b9f9c4d7535b23eea62c30caeb313c457a2c8716e81df852b783e76ad6d68f0b524381632729b6ea3dfff64a74b5bb8b7fae8788799d301dbf5180c30b9a09eb690a5a4600e8c14a145cf4e0b155d3bfba23f18366c3794593f21c70dec7815d9abf3e3acfebb4598ed0b9565fefbd93b67ad7d011c3c49ec947b2699b1ffd1e0afeaead9e9c3477b4fbcf4b9f7a8b13834286af25dff2d8055992c883341d2375b372d5dd6937b41b54dd447cd8f09f5003033fe04d40f3dd9a649154aa6fa9522870a059c116dd085ef054520fd76fe4a8f837ff258bb6ca01e951472cd890ba4ea9d7bc2d75bb7524dd5221d5b55922ee893cff9d97b2e5f7718d45a319fe8b519c8fd66b683e60f90ced05fe8ecc4ef2465cd25a3ec8d1234184350f41f5e60e35757976449bce2062884e28bfe2cb9e6c66be72006c1c6513c31eea53cbe969f72aaeb845e4c12cda8a7fe09d606ccc63d7c3a60797f1f0d6f7ef14da00848ecec0ff564a7fa395700d129b4c58c43d2655244c3c2f4ce61bde4e9bb1fb98b7152c8d523cc4b58fb5fa020c02f139601db3fb784f7287bd7817eac7612846bfaa3b65907afc90796742cbb43b401fba88c93192484c695dedfae11fea4a411e7bc6773fb36037ea1b1d258632c357fa0c0ec9bec83870fec72dc5db4d5303c572c0eec8171d5831f923f72c9dac54ee317b0253ce700aab4d9c215bde0d40d9edc3b53bc352813bc2d8b81349fbad0521f47dace17834440ac4e1f243c6ed760ba35be8bd9190e250045d29452e43343a300401fae84fe34aaf79925bea14df66d4a0b212996b7b7c6caa6bdf35aa0d6f3342ba632eb56b787ee80db05633af64f363ec8130263fdebcb0d4c226561087e868ed2c6070d512ef2d7fa766cb04f561fbf5a51b1929d9f145fbeb14d76f6ed36b78236b1f9eb6602ddacb926595431e326d893ad17e01d3114899a3a974556cc34f36ef0fda5ebd0f9da89arootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootpython-SQLAlchemy-1.2.7-lp150.2.3.1.src.rpmpython-SQLAlchemy-docpython-SQLAlchemy-docpython2-SQLAlchemy-docpython3-SQLAlchemy-doc    rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)3.0.4-14.6.0-14.0-15.2-14.14.1][Z'ZZ%Z@ZjZm@Z_:ZLZH@YYY_wY Y#@XWڍ@WUeWQq@VwV@VU~@Ua@U7@Tq@Ralf Haferkamp arun@gmx.dearun@gmx.dearun@gmx.dearun@gmx.dearun@gmx.dearun@gmx.dearun@gmx.dearun@gmx.dearun@gmx.dearun@gmx.detbechtold@suse.comtbechtold@suse.comtoddrme2178@gmail.comtoddrme2178@gmail.comtoddrme2178@gmail.comtoddrme2178@gmail.comdmueller@suse.comtbechtold@suse.comaplanas@suse.combwiedemann@suse.comtbechtold@suse.combruno@ioda-net.chbruno@ioda-net.chtbechtold@suse.comtbechtold@suse.com- Add 0001-Illustrate-fix-for-4481-in-terms-of-a-1.2-patch.patch (bsc#1124593, CVE-2019-7164, CVE-2019-7548) - Add 0002-fix-TypeReflectionTest-for-sqlite-3.24.patch to fix test suite for latest sqlite version update in SLE-15.- update to version 1.2.7: * orm + [orm] [bug] Fixed regression in 1.2 within sharded query feature where the new “identity_token” element was not being correctly considered within the scope of a lazy load operation, when searching the identity map for a related many-to-one element. The new behavior will allow for making use of the “id_chooser” in order to determine the best identity key to retrieve from the identity map. In order to achieve this, some refactoring of 1.2’s “identity_token” approach has made some slight changes to the implementation of ShardedQuery which should be noted for other derivations of this class. References: #4228 + [orm] [bug] Fixed issue in single-inheritance loading where the use of an aliased entity against a single-inheritance subclass in conjunction with the Query.select_from() method would cause the SQL to be rendered with the unaliased table mixed in to the query, causing a cartesian product. In particular this was affecting the new “selectin” loader when used against a single-inheritance subclass. References: #4241 * sql + [sql] [bug] Fixed issue where the compilation of an INSERT statement with the “literal_binds” option that also uses an explicit sequence and “inline” generation, as on Postgresql and Oracle, would fail to accommodate the extra keyword argument within the sequence processing routine. References: #4231 * postgresql + [postgresql] [feature] Added new PG type postgresql.REGCLASS which assists in casting table names to OID values. Pull request courtesy Sebastian Bank. References: #4160 + [postgresql] [bug] Fixed bug where the special “not equals” operator for the Postgresql “range” datatypes such as DATERANGE would fail to render “IS NOT NULL” when compared to the Python None value. References: #4229 * mssql + [mssql] [bug] Fixed 1.2 regression caused by #4060 where the query used to reflect SQL Server cross-schema foreign keys was limiting the criteria incorrectly. References: #4234 * oracle + [oracle] [bug] The Oracle NUMBER datatype is reflected as INTEGER if the precision is NULL and the scale is zero, as this is how INTEGER values come back when reflected from Oracle’s tables. Pull request courtesy Kent Bower.- specfile: * run spec-cleaner - update to version 1.2.6: * orm + [orm] [bug] Fixed bug where using Mutable.associate_with() or Mutable.as_mutable() in conjunction with a class that has non- primary mappers set up with alternatively-named attributes would produce an attribute error. Since non-primary mappers are not used for persistence, the mutable extension now excludes non-primary mappers from its instrumentation steps. References: [#4215] * engine + [engine] [bug] Fixed bug in connection pool where a connection could be present in the pool without all of its “connect” event handlers called, if a previous “connect” handler threw an exception; note that the dialects themselves have connect handlers that emit SQL, such as those which set transaction isolation, which can fail if the database is in a non-available state, but still allows a connection. The connection is now invalidated first if any of the connect handlers fail. References: #4225 * sql + [sql] [bug] Fixed a regression that occurred from the previous fix to #4204 in version 1.2.5, where a CTE that refers to itself after the CTE.alias() method has been called would not refer to iself correctly. References: #4204 * postgresql + [postgresql] [feature] Added support for “PARTITION BY” in Postgresql table definitions, using “postgresql_partition_by”. Pull request courtesy Vsevolod Solovyov. * mssql + [mssql] [bug] Adjusted the SQL Server version detection for pyodbc to only allow for numeric tokens, filtering out non-integers, since the dialect does tuple- numeric comparisons with this value. This is normally true for all known SQL Server / pyodbc drivers in any case. References: #4227 * oracle + [oracle] [bug] The minimum cx_Oracle version supported is 5.2 (June 2015). Previously, the dialect asserted against version 5.0 but as of 1.2.2 we are using some symbols that did not appear until 5.2. References: #4211 * misc + [bug] [declarative] Removed a warning that would be emitted when calling upon __table_args__, __mapper_args__ as named with a @declared_attr method, when called from a non-mapped declarative mixin. Calling these directly is documented as the approach to use when one is overidding one of these methods on a mapped class. The warning still emits for regular attribute names. References: #4221- update to version 1.2.5: * orm + [orm] [feature] Added new feature Query.only_return_tuples(). Causes the Query object to return keyed tuple objects unconditionally even if the query is against a single entity. Pull request courtesy Eric Atkin. + [orm] [bug] Fixed bug in new “polymorphic selectin” loading when a selection of polymorphic objects were to be partially loaded from a relationship lazy loader, leading to an “empty IN” condition within the load that raises an error for the “inline” form of “IN”. References: #4199 + [orm] [bug] Fixed 1.2 regression where a mapper option that contains an AliasedClass object, as is typical when using the QueryableAttribute.of_type() method, could not be pickled. 1.1’s behavior was to omit the aliased class objects from the path, so this behavior is restored. References: #4209 * sql + [sql] [bug] Fixed bug in :class:.`CTE` construct along the same lines as that of #4204 where a CTE that was aliased would not copy itself correctly during a “clone” operation as is frequent within the ORM as well as when using the ClauseElement.params() method. References: #4210 + [sql] [bug] Fixed bug in CTE rendering where a CTE that was also turned into an Alias would not render its “ctename AS aliasname” clause appropriately if there were more than one reference to the CTE in a FROM clause. References: #4204 + [sql] [bug] Fixed bug in new “expanding IN parameter” feature where the bind parameter processors for values wasn’t working at all, tests failed to cover this pretty basic case which includes that ENUM values weren’t working. References: #4198 * postgresql + [postgresql] [bug] [py3k] Fixed bug in Postgresql COLLATE / ARRAY adjustment first introduced in #4006 where new behaviors in Python 3.7 regular expressions caused the fix to fail. This change is also backported to: 1.1.18 References: #4208 * mysql + [mysql] [bug] MySQL dialects now query the server version using SELECT @@version explicitly to the server to ensure we are getting the correct version information back. Proxy servers like MaxScale interfere with the value that is passed to the DBAPI’s connection.server_version value so this is no longer reliable. This change is also backported to: 1.1.18 References: #4205- update to version 1.2.4: * orm + [orm] [bug] Fixed 1.2 regression in ORM versioning feature where a mapping against a select() or alias() that also used a versioning column against the underlying table would fail due to the check added as part of #3673. References: #4193 * engine + [engine] [bug] Fixed regression caused in 1.2.3 due to fix from [#4181] where the changes to the event system involving Engine and OptionEngine did not accommodate for event removals, which would raise an AttributeError when invoked at the class level. References: #4190 * sql + [sql] [bug] Fixed bug where CTE expressions would not have their name or alias name quoted when the given name is case sensitive or otherwise requires quoting. Pull request courtesy Eric Atkin. References: #4197- update to version 1.2.3: * orm + [orm] [feature] Added new argument attributes.set_attribute.inititator to the attributes.set_attribute() function, allowing an event token received from a listener function to be propagated to subsequent set events. + [orm] [bug] Fixed issue in post_update feature where an UPDATE is emitted when the parent object has been deleted but the dependent object is not. This issue has existed for a long time however since 1.2 now asserts rows matched for post_update, this was raising an error. This change is also backported to: 1.1.16 References: #4187 + [orm] [bug] Fixed regression caused by fix for issue #4116 affecting versions 1.2.2 as well as 1.1.15, which had the effect of mis-calculation of the “owning class” of an AssociationProxy as the NoneType class in some declarative mixin/inheritance situations as well as if the association proxy were accessed off of an un-mapped class. The “figure out the owner” logic has been replaced by an in-depth routine that searches through the complete mapper hierarchy assigned to the class or subclass to determine the correct (we hope) match; will not assign the owner if no match is found. An exception is now raised if the proxy is used against an un-mapped instance. This change is also backported to: 1.1.16 References: #4185 + [orm] [bug] Fixed bug where the Bundle object did not correctly report upon the primary Mapper object represened by the bundle, if any. An immediate side effect of this issue was that the new selectinload loader strategy wouldn’t work with the horizontal sharding extension. References: #4175 + [orm] [bug] Fixed bug in concrete inheritance mapping where user-defined attributes such as hybrid properties that mirror the names of mapped attributes from sibling classes would be overwritten by the mapper as non-accessible at the instance level. Additionally ensured that user-bound descriptors are not implicitly invoked at the class level during the mapper configuration stage. References: #4188 + [orm] [bug] Fixed bug where the orm.reconstructor() event helper would not be recognized if it were applied to the __init__() method of the mapped class. References: #4178 * engine + [engine] [bug] Fixed bug where events associated with an Engine at the class level would be doubled when the Engine.execution_options() method were used. To achieve this, the semi-private class OptionEngine no longer accepts events directly at the class level and will raise an error; the class only propagates class-level events from its parent Engine. Instance-level events continue to work as before. References: #4181 + [engine] [bug] The URL object now allows query keys to be specified multiple times where their values will be joined into a list. This is to support the plugins feature documented at CreateEnginePlugin which documents that “plugin” can be passed multiple times. Additionally, the plugin names can be passed to create_engine() outside of the URL using the new create_engine.plugins parameter. References: #4170 * sql + [sql] [feature] Added support for Enum to persist the values of the enumeration, rather than the keys, when using a Python pep-435 style enumerated object. The user supplies a callable function that will return the string values to be persisted. This allows enumerations against non-string values to be value-persistable as well. Pull request courtesy Jon Snyder. References: #3906 + [sql] [bug] Fixed bug where the Enum type wouldn’t handle enum “aliases” correctly, when more than one key refers to the same value. Pull request courtesy Daniel Knell. References: #4180 * postgresql + [postgresql] [bug] Added “SSL SYSCALL error: Operation timed out” to the list of messages that trigger a “disconnect” scenario for the psycopg2 driver. Pull request courtesy André Cruz. This change is also backported to: 1.1.16 + [postgresql] [bug] Added “TRUNCATE” to the list of keywords accepted by the Postgresql dialect as an “autocommit”-triggering keyword. Pull request courtesy Jacob Hayes. This change is also backported to: 1.1.16 * sqlite + [sqlite] [bug] Fixed the import error raised when a platform has neither pysqlite2 nor sqlite3 installed, such that the sqlite3-related import error is raised, not the pysqlite2 one which is not the actual failure mode. Pull request courtesy Robin. * oracle + [oracle] [feature] The ON DELETE options for foreign keys are now part of Oracle reflection. Oracle does not support ON UPDATE cascades. Pull request courtesy Miroslav Shubernetskiy. + [oracle] [bug] Fixed bug in cx_Oracle disconnect detection, used by pre_ping and other features, where an error could be raised as DatabaseError which includes a numeric error code; previously we weren’t checking in this case for a disconnect code. References: #4182 * misc + [bug] [pool] Fixed a fairly serious connection pool bug where a connection that is acquired after being refreshed as a result of a user-defined DisconnectionError or due to the 1.2-released “pre_ping” feature would not be correctly reset if the connection were returned to the pool by weakref cleanup (e.g. the front-facing object is garbage collected); the weakref would still refer to the previously invalidated DBAPI connection which would have the reset operation erroneously called upon it instead. This would lead to stack traces in the logs and a connection being checked into the pool without being reset, which can cause locking issues. This change is also backported to: 1.1.16 References: #4184 + [bug] [tests] A test added in 1.2 thought to confirm a Python 2.7 behavior turns out to be confirming the behavior only as of Python 2.7.8. Python bug #8743 still impacts set comparison in Python 2.7.7 and earlier, so the test in question involving AssociationSet no longer runs for these older Python 2.7 versions. References: #3265- update to version 1.2.2: * orm + [orm] [bug] Fixed 1.2 regression regarding new bulk_replace event where a backref would fail to remove an object from the previous owner when a bulk-assignment assigned the object to a new owner. References: #4171 * mysql + [mysql] [bug] Added more MySQL 8.0 reserved words to the MySQL dialect for quoting purposes. Pull request courtesy Riccardo Magliocchetti. * mssql + [mssql] [bug] Added ODBC error code 10054 to the list of error codes that count as a disconnect for ODBC / MSSQL server. References: #4164 * oracle + [oracle] [bug] The cx_Oracle dialect now calls setinputsizes() with cx_Oracle.NCHAR unconditionally when the NVARCHAR2 datatype, in SQLAlchemy corresponding to sqltypes.Unicode(), is in use. Per cx_Oracle’s author this allows the correct conversions to occur within the Oracle client regardless of the setting for NLS_NCHAR_CHARACTERSET. References: #4163- update to version 1.2.1: * orm + [orm] [bug] Fixed bug where an object that is expunged during a rollback of a nested or subtransaction which also had its primary key mutated would not be correctly removed from the session, causing subsequent issues in using the session. + [orm] [bug] Fixed regression where pickle format of a Load / _UnboundLoad object (e.g. loader options) changed and __setstate__() was raising an UnboundLocalError for an object received from the legacy format, even though an attempt was made to do so. tests are now added to ensure this works. + [orm] [bug] Fixed regression caused by new lazyload caching scheme in #3954 where a query that makes use of loader options with of_type would cause lazy loads of unrelated paths to fail with a TypeError. + [orm] [bug] Fixed bug in new “selectin” relationship loader where the loader could try to load a non-existent relationship when loading a collection of polymorphic objects, where only some of the mappers include that relationship, typically when PropComparator.of_type() is being used. * sql + [sql] [bug] Fixed bug in Insert.values() where using the “multi-values” format in combination with Column objects as keys rather than strings would fail. Pull request courtesy Aubrey Stark-Toller. * mssql + [mssql] [bug] Fixed regression in 1.2 where newly repaired quoting of collation names in #3785 breaks SQL Server, which explicitly does not understand a quoted collation name. Whether or not mixed-case collation names are quoted or not is now deferred down to a dialect-level decision so that each dialect can prepare these identifiers directly. * oracle + [oracle] [bug] Fixed regression where the removal of most setinputsizes rules from cx_Oracle dialect impacted the TIMESTAMP datatype’s ability to retrieve fractional seconds. + [oracle] [bug] Fixed regression in Oracle imports where a missing comma caused an undefined symbol to be present. Pull request courtesy Miroslav Shubernetskiy. * misc + [bug] [ext] Fixed regression in association proxy due to #3769 (allow for chained any() / has()) where contains() against an association proxy chained in the form (o2m relationship, associationproxy(m2o relationship, m2o relationship)) would raise an error regarding the re-application of contains() on the final link of the chain. + [bug] [tests] Removed an oracle-specific requirements rule from the public test suite that was interfering with third party dialect suites. + [bug] [tests] Added a new exclusion rule group_by_complex_expression which disables tests that use “GROUP BY ”, which seems to be not viable for at least two third party dialects.- specfile: * updated test requirements- update to version 1.2.0: * See https://docs.sqlalchemy.org/en/latest/changelog/changelog_12.html- update to version 1.1.14: * orm + [orm] [bug] Fixed bug in Session.merge() following along similar lines as that of #4030, where an internal check for a target object in the identity map could lead to an error if it were to be garbage collected immediately before the merge routine actually retrieves the object. References: #4069 + [orm] [bug] Fixed bug where an undefer_group() option would not be recognized if it extended from a relationship that was loading using joined eager loading. Additionally, as the bug led to excess work being performed, Python function call counts are also improved by 20% within the initial calculation of result set columns, complementing the joined eager load improvements of [#3915]. References: #4048 + [orm] [bug] Fixed race condition in ORM identity map which would cause objects to be inappropriately removed during a load operation, causing duplicate object identities to occur, particularly under joined eager loading which involves deduplication of objects. The issue is specific to garbage collection of weak references and is observed only under the Pypy interpreter. References: #4068 + [orm] [bug] Fixed bug in Session.merge() where objects in a collection that had the primary key attribute set to None for a key that is typically autoincrementing would be considered to be a database-persisted key for part of the internal deduplication process, causing only one object to actually be inserted in the database. References: #4056 + [orm] [bug] An InvalidRequestError is raised when a synonym() is used against an attribute that is not against a MapperProperty, such as an association proxy. Previously, a recursion overflow would occur trying to locate non-existent attributes. References: #4067 * sql + [sql] [bug] Altered the range specification for window functions to allow for two of the same PRECEDING or FOLLOWING keywords in a range by allowing for the left side of the range to be positive and for the right to be negative, e.g. (1, 3) is “1 FOLLOWING AND 3 FOLLOWING”. References: #4053 - changes from version 1.1.13: * oracle + [oracle] [bug] [py2k] [performance] Fixed performance regression caused by the fix for #3937 where cx_Oracle as of version 5.3 dropped the .UNICODE symbol from its namespace, which was interpreted as cx_Oracle’s “WITH_UNICODE” mode being turned on unconditionally, which invokes functions on the SQLAlchemy side which convert all strings to unicode unconditionally and causing a performance impact. In fact, per cx_Oracle’s author the “WITH_UNICODE” mode has been removed entirely as of 5.1, so the expensive unicode conversion functions are no longer necessary and are disabled if cx_Oracle 5.1 or greater is detected under Python 2. The warning against “WITH_UNICODE” mode that was removed under #3937 is also restored. This change is also backported to: 1.0.19 References: #4035- update to 1.1.12: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_11.html#change-1.1.12- Update to 1.1.11: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_11.html#change-1.1.11 - Update to 1.1.10: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_11.html#change-1.1.10- Don't provide python2-sqlalchemy, singlespec packages should use correct name.- Add literal python-sqlalchemy provides.- Update to 1.1.9: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_11.html#change-1.1.9 - Update to 1.1.8: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_11.html#change-1.1.8 - Update to 1.1.7: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_11.html#change-1.1.7 - Update to 1.1.6: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_11.html#change-1.1.6 - Update to 1.1.5: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_11.html#change-1.1.5 - Update to 1.1.4: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_11.html#change-1.1.4 - Update to 1.1.3: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_11.html#change-1.1.3 - Update to 1.1.2: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_11.html#change-1.1.2 - Update to 1.1.1: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_11.html#change-1.1.1 - Update to 1.1.0: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_11.html#change-1.1.0 - Update to 1.0.18: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_10.html#change-1.0.18 - Update to 1.0.17: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_10.html#change-1.0.17 - Update to 1.0.16: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_10.html#change-1.0.16 - Implement single-spec version.- Update to 1.0.15: * See http://docs.sqlalchemy.org/en/latest/changelog/changelog_10.html#change-1.0.15 http://docs.sqlalchemy.org/en/latest/changelog/changelog_10.html#change-1.0.14- fix source url- update to 1.0.13: * see http://docs.sqlalchemy.org/en/latest/changelog/changelog_10.html#change-1.0.12 and http://docs.sqlalchemy.org/en/latest/changelog/changelog_10.html#change-1.0.13 Remove 0001-fix-sqlite3.10.0-test.patch. Applied upstream.- Add 0001-fix-sqlite3.10.0-test.patch Backport fix after SQLite3.10 upgrade- update to 1.0.11: * see http://docs.sqlalchemy.org/en/latest/changelog/changelog_10.html#change-1.0.11- update to 1.0.8: * see http://docs.sqlalchemy.org/en/latest/changelog/changelog_10.html#change-1.0.8- update to version 1.0.5: * see http://docs.sqlalchemy.org/en/latest/changelog/changelog_10.html#change-1.0.5- update to 1.0.4: + see http://docs.sqlalchemy.org/en/latest/changelog/changelog_10.html#change-1.0.4 + see http://docs.sqlalchemy.org/en/latest/changelog/migration_10.html- update to 0.9.9: + See http://docs.sqlalchemy.org/en/latest/changelog/changelog_09.html#change-0.9.9- Update to version 0.9.8: + See http://docs.sqlalchemy.org/en/latest/changelog/changelog_09.html#change-0.9.8cloud129 1566570198  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLM1.2.71.2.7-lp150.2.3.11.2.71.2.7      !!""!####!$$$$!%%%%%%%%%!&&!'''''''!(((((!))!****!+++!,,!--!..!///////!00!11!222!333!444python-SQLAlchemy-docdoc_imagessqla_arch_small.pngsqla_engine_arch.png_modulesexamplesadjacency_listadjacency_list.htmlassociationbasic_association.htmldict_of_sets_with_default.htmlproxied_association.htmlcustom_attributesactive_column_defaults.htmlcustom_management.htmllisten_for_events.htmldogpile_cachingadvanced.htmlcaching_query.htmlenvironment.htmlfixture_data.htmlhelloworld.htmllocal_session_caching.htmlmodel.htmlrelationship_caching.htmldynamic_dictdynamic_dict.htmlelementtreeadjacency_list.htmloptimized_al.htmlpickle.htmlgeneric_associationsdiscriminator_on_association.htmlgeneric_fk.htmltable_per_association.htmltable_per_related.htmlgraphsdirected_graph.htmlinheritanceconcrete.htmljoined.htmlsingle.htmljoin_conditionscast.htmlthreeway.htmllarge_collectionlarge_collection.htmlmaterialized_pathsmaterialized_paths.htmlnested_setsnested_sets.htmlperformance__main__.htmlbulk_inserts.htmlbulk_updates.htmllarge_resultsets.htmlshort_selects.htmlsingle_inserts.htmlpostgispostgis.htmlshardingattribute_shard.htmlversioned_historyhistory_meta.htmltest_versioning.htmlversioned_rowsversioned_map.htmlversioned_rows.htmlverticaldictlike-polymorphic.htmldictlike.htmlindex.html_staticbasic.csschangelog.csscomment-bright.pngcomment-close.pngcomment.pngdetectmobile.jsdocs.cssdoctools.jsdocumentation_options.jsdown-pressed.pngdown.pngfile.pnginit.jsjquery-3.2.1.jsjquery.jsminus.pngplus.pngpygments.csssearchtools.jssphinx_paramlinks.cssunderscore-1.3.1.jsunderscore.jsup-pressed.pngup.pngwebsupport.jschangelogchangelog_01.htmlchangelog_02.htmlchangelog_03.htmlchangelog_04.htmlchangelog_05.htmlchangelog_06.htmlchangelog_07.htmlchangelog_08.htmlchangelog_09.htmlchangelog_10.htmlchangelog_11.htmlchangelog_12.htmlindex.htmlmigration_04.htmlmigration_05.htmlmigration_06.htmlmigration_07.htmlmigration_08.htmlmigration_09.htmlmigration_10.htmlmigration_11.htmlmigration_12.htmlcontents.htmlcopyright.htmlcoreapi_basics.htmlcompiler.htmlconnections.htmlconstraints.htmlcustom_types.htmlddl.htmldefaults.htmldml.htmlengines.htmlengines_connections.htmlevent.htmlevents.htmlexceptions.htmlexpression_api.htmlfunctions.htmlindex.htmlinspection.htmlinterfaces.htmlinternals.htmlmetadata.htmlpooling.htmlreflection.htmlschema.htmlselectable.htmlserializer.htmlsqlelement.htmltutorial.htmltype_api.htmltype_basics.htmltypes.htmldialectsfirebird.htmlindex.htmlmssql.htmlmysql.htmloracle.htmlpostgresql.htmlsqlite.htmlsybase.htmlerrors.htmlfaqconnections.htmlindex.htmlmetadata_schema.htmlormconfiguration.htmlperformance.htmlsessions.htmlsqlexpressions.htmlgenindex.htmlglossary.htmlindex.htmlintro.htmlnotfound.htmlormbackref.htmlbasic_relationships.htmlcascades.htmlclassical.htmlcollections.htmlcomposites.htmlconstructors.htmlcontextual.htmldeprecated.htmlevents.htmlexamples.htmlexceptions.htmlextending.htmlextensionsassociationproxy.htmlautomap.htmlbaked.htmldeclarativeapi.htmlbasic_use.htmlindex.htmlinheritance.htmlmixins.htmlrelationships.htmltable_config.htmlhorizontal_shard.htmlhybrid.htmlindex.htmlindexable.htmlinstrumentation.htmlmutable.htmlorderinglist.htmlindex.htmlinheritance.htmlinheritance_loading.htmlinternals.htmljoin_conditions.htmlloading.htmlloading_columns.htmlloading_objects.htmlloading_relationships.htmlmapped_attributes.htmlmapped_sql_expr.htmlmapper_config.htmlmapping_api.htmlmapping_columns.htmlmapping_styles.htmlnonstandard_mappings.htmlpersistence_techniques.htmlquery.htmlrelationship_api.htmlrelationship_persistence.htmlrelationships.htmlscalar_mapping.htmlself_referential.htmlsession.htmlsession_api.htmlsession_basics.htmlsession_events.htmlsession_state_management.htmlsession_transaction.htmltutorial.htmlversioning.htmlsearch.htmlsearchindex.jsexamples__init__.pyadjacency_list__init__.pyadjacency_list.pyassociation__init__.pybasic_association.pydict_of_sets_with_default.pyproxied_association.pycustom_attributes__init__.pyactive_column_defaults.pycustom_management.pylisten_for_events.pydogpile_caching__init__.pyadvanced.pycaching_query.pyenvironment.pyfixture_data.pyhelloworld.pylocal_session_caching.pymodel.pyrelationship_caching.pydynamic_dict__init__.pydynamic_dict.pyelementtree__init__.pyadjacency_list.pyoptimized_al.pypickle.pytest.xmltest2.xmltest3.xmlgeneric_associations__init__.pydiscriminator_on_association.pygeneric_fk.pytable_per_association.pytable_per_related.pygraphs__init__.pydirected_graph.pyinheritance__init__.pyconcrete.pyjoined.pysingle.pyjoin_conditions__init__.pycast.pythreeway.pylarge_collection__init__.pylarge_collection.pymaterialized_paths__init__.pymaterialized_paths.pynested_sets__init__.pynested_sets.pyperformance__init__.py__main__.pybulk_inserts.pybulk_updates.pylarge_resultsets.pyshort_selects.pysingle_inserts.pypostgis__init__.pypostgis.pysharding__init__.pyattribute_shard.pyversioned_history__init__.pyhistory_meta.pytest_versioning.pyversioned_rows__init__.pyversioned_map.pyversioned_rows.pyvertical__init__.pydictlike-polymorphic.pydictlike.py/usr/share/doc/packages//usr/share/doc/packages/python-SQLAlchemy-doc//usr/share/doc/packages/python-SQLAlchemy-doc/doc//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_images//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/adjacency_list//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/association//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/custom_attributes//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/dogpile_caching//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/dynamic_dict//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/elementtree//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/generic_associations//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/graphs//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/inheritance//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/join_conditions//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/large_collection//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/materialized_paths//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/nested_sets//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/performance//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/postgis//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/sharding//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/versioned_history//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/versioned_rows//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_modules/examples/vertical//usr/share/doc/packages/python-SQLAlchemy-doc/doc/_static//usr/share/doc/packages/python-SQLAlchemy-doc/doc/changelog//usr/share/doc/packages/python-SQLAlchemy-doc/doc/core//usr/share/doc/packages/python-SQLAlchemy-doc/doc/dialects//usr/share/doc/packages/python-SQLAlchemy-doc/doc/faq//usr/share/doc/packages/python-SQLAlchemy-doc/doc/orm//usr/share/doc/packages/python-SQLAlchemy-doc/doc/orm/extensions//usr/share/doc/packages/python-SQLAlchemy-doc/doc/orm/extensions/declarative//usr/share/doc/packages/python-SQLAlchemy-doc/examples//usr/share/doc/packages/python-SQLAlchemy-doc/examples/adjacency_list//usr/share/doc/packages/python-SQLAlchemy-doc/examples/association//usr/share/doc/packages/python-SQLAlchemy-doc/examples/custom_attributes//usr/share/doc/packages/python-SQLAlchemy-doc/examples/dogpile_caching//usr/share/doc/packages/python-SQLAlchemy-doc/examples/dynamic_dict//usr/share/doc/packages/python-SQLAlchemy-doc/examples/elementtree//usr/share/doc/packages/python-SQLAlchemy-doc/examples/generic_associations//usr/share/doc/packages/python-SQLAlchemy-doc/examples/graphs//usr/share/doc/packages/python-SQLAlchemy-doc/examples/inheritance//usr/share/doc/packages/python-SQLAlchemy-doc/examples/join_conditions//usr/share/doc/packages/python-SQLAlchemy-doc/examples/large_collection//usr/share/doc/packages/python-SQLAlchemy-doc/examples/materialized_paths//usr/share/doc/packages/python-SQLAlchemy-doc/examples/nested_sets//usr/share/doc/packages/python-SQLAlchemy-doc/examples/performance//usr/share/doc/packages/python-SQLAlchemy-doc/examples/postgis//usr/share/doc/packages/python-SQLAlchemy-doc/examples/sharding//usr/share/doc/packages/python-SQLAlchemy-doc/examples/versioned_history//usr/share/doc/packages/python-SQLAlchemy-doc/examples/versioned_rows//usr/share/doc/packages/python-SQLAlchemy-doc/examples/vertical/-fmessage-length=0 -grecord-gcc-switches -O2 -Wall -D_FORTIFY_SOURCE=2 -fstack-protector-strong -funwind-tables -fasynchronous-unwind-tables -fstack-clash-protection -gobs://build.opensuse.org/openSUSE:Maintenance:10931/openSUSE_Leap_15.0_Update/70db3b2c21dac7aa9dc33cd0c6d542fd-python-SQLAlchemy.openSUSE_Leap_15.0_Updatedrpmxz5x86_64-suse-linux       directoryPNG image data, 469 x 333, 8-bit/color RGBA, non-interlacedPNG image data, 683 x 185, 8-bit/color RGBA, non-interlacedHTML document, ASCII text, with very long linesHTML document, ASCII textASCII textPNG image data, 16 x 16, 8-bit/color RGBA, non-interlacedASCII text, with very long linesPNG image data, 16 x 16, 8-bit gray+alpha, non-interlacedPNG image data, 11 x 11, 8-bit grayscale, non-interlacedHTML document, UTF-8 Unicode text, with very long linesHTML document, UTF-8 Unicode textASCII text, with very long lines, with no line terminatorsemptyPython script, ASCII text executable|EG|"-Futf-820ee31ef650d0e6428e174ec8e1f91915a56d30c11a5ea73055928dd5dd7423f?P7zXZ !t/ ]"k%a RlߵlS<Cgo`9]Mfq`] zVʜC Ƴw WV%x?4..MwNx+J=&L !BM8z/tawUe$>sؠvЧMp)0z/#jlT~T&Y] #/-mR?VCVnpVFwB50Xn [(M% Cg1&ۋ%/jSBN! Q[4]3cQ-QUp]]Ee!&i[RAƗ1__ ih@WUH' ز0,b?&ݟ|%WUvF_Hpr[a?)FdN/~8+މz?^^t+e# PSQdmj5Rb Mɛ2NlGtaOyUmɩZP^zaQDvua"bO=HEJOd"7Q8)*CGJ#s|ױglo?QMdjY&^>[׽A1p|\5XuL{mSG|ґ=.J5} rǴXzk kw_iѓ9T]N`WMk[R4 x ٵ?LuN59ɠ=Ww7-Ѵj ˜քq^P13Xd|CI W`VV_ܮ_iACAY0sգ&`n2HY|ugZsȡ.w$+ߪe!JeTr.-r,dniCD48>Y2x'RZB-@ߕ4ٚsá }ÿ.2ht ?"g:A=VEkDxFuh`/hԿ !c:u@(z!6 }6:'*Hes:BlRhk0A^O љbrD`11ch(;yyt%V!JMSʔ^Ъbk4Nj|_}g0M)JRd)2VфsOEX/KV)!xS=xPsu Lmb75<]☤p ADL8ko <\]C4be')`77y_rزC ζZ!i5)|&eIR)UއVū;^C5wH I cEؿPp5`q(PF k=K*;r54~|G ` ETT EE `1!V^od2w1v(`!#TeW?(}9v#R V-ѭUfKIe[u8 hu0/I[FvieuKؗ¹ 5nz Riamʤߢ?z6CN=yam$/22]xVn/Qn*H1o!ޥWȦP1 4{qYa?ǟd6SsaiGTb qOD4F,>,H,n 26L$I{X !7O0q%INSJb0<(T{]J*im[ҎbJ±;iŇg 9FldTʋJhl]a֊ ,XG*(V 7^䤻?]!lrVisU;'缙_` r 3ocQı=fĖv~/?[Zz6]c3BEѸ -SV`Aeq]3mR8*x0iA+'Hr x Ll["H_`*dVc{'^QtK(H@Qx=h YZ