f7c7355f9c25ef3326f434960b0a53febdfd7693.svn-base 1001 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783678467856786678767886789679067916792679367946795679667976798679968006801680268036804680568066807680868096810681168126813681468156816681768186819682068216822682368246825682668276828682968306831683268336834683568366837683868396840684168426843684468456846684768486849685068516852685368546855685668576858685968606861686268636864686568666867686868696870687168726873687468756876687768786879688068816882688368846885688668876888688968906891689268936894689568966897689868996900690169026903690469056906690769086909691069116912691369146915691669176918691969206921692269236924692569266927692869296930693169326933693469356936693769386939694069416942694369446945694669476948694969506951695269536954695569566957695869596960696169626963696469656966696769686969697069716972697369746975697669776978697969806981698269836984698569866987698869896990699169926993699469956996699769986999700070017002700370047005700670077008700970107011701270137014701570167017701870197020702170227023702470257026702770287029703070317032703370347035703670377038703970407041704270437044704570467047704870497050705170527053705470557056705770587059706070617062706370647065706670677068706970707071707270737074707570767077707870797080708170827083708470857086708770887089709070917092709370947095709670977098709971007101710271037104710571067107710871097110711171127113711471157116711771187119712071217122712371247125712671277128712971307131713271337134713571367137713871397140714171427143714471457146714771487149715071517152715371547155715671577158715971607161716271637164716571667167716871697170717171727173717471757176717771787179718071817182718371847185718671877188718971907191719271937194719571967197719871997200720172027203720472057206720772087209721072117212721372147215721672177218721972207221722272237224722572267227722872297230723172327233723472357236723772387239724072417242724372447245724672477248724972507251725272537254725572567257725872597260726172627263726472657266726772687269727072717272727372747275727672777278727972807281728272837284728572867287728872897290729172927293729472957296729772987299730073017302730373047305730673077308730973107311731273137314731573167317731873197320732173227323732473257326732773287329733073317332733373347335733673377338733973407341734273437344734573467347734873497350735173527353735473557356735773587359736073617362736373647365736673677368736973707371737273737374737573767377737873797380738173827383738473857386738773887389739073917392739373947395739673977398739974007401740274037404740574067407740874097410741174127413741474157416741774187419742074217422742374247425742674277428742974307431743274337434743574367437743874397440744174427443744474457446744774487449745074517452745374547455745674577458745974607461746274637464746574667467746874697470747174727473747474757476747774787479748074817482748374847485748674877488748974907491749274937494749574967497749874997500750175027503750475057506750775087509751075117512751375147515751675177518751975207521752275237524752575267527752875297530753175327533753475357536753775387539754075417542754375447545754675477548754975507551755275537554755575567557755875597560756175627563756475657566756775687569757075717572757375747575757675777578757975807581758275837584758575867587758875897590759175927593759475957596759775987599760076017602760376047605760676077608760976107611761276137614761576167617761876197620762176227623762476257626762776287629763076317632763376347635763676377638763976407641764276437644764576467647764876497650765176527653765476557656765776587659766076617662766376647665766676677668766976707671767276737674767576767677767876797680768176827683768476857686768776887689769076917692769376947695769676977698769977007701770277037704770577067707770877097710771177127713771477157716771777187719772077217722772377247725772677277728772977307731773277337734773577367737773877397740774177427743774477457746774777487749775077517752775377547755775677577758775977607761776277637764776577667767776877697770777177727773777477757776777777787779778077817782778377847785778677877788778977907791779277937794779577967797779877997800780178027803780478057806780778087809781078117812781378147815781678177818781978207821782278237824782578267827782878297830783178327833783478357836783778387839784078417842784378447845784678477848784978507851785278537854785578567857785878597860786178627863786478657866786778687869787078717872787378747875787678777878787978807881788278837884788578867887788878897890789178927893789478957896789778987899790079017902790379047905790679077908790979107911791279137914791579167917791879197920792179227923792479257926792779287929793079317932793379347935793679377938793979407941794279437944794579467947794879497950795179527953795479557956795779587959796079617962796379647965796679677968796979707971797279737974797579767977797879797980798179827983798479857986798779887989799079917992799379947995799679977998799980008001800280038004800580068007800880098010801180128013801480158016801780188019802080218022802380248025802680278028802980308031803280338034803580368037803880398040804180428043804480458046804780488049805080518052805380548055805680578058805980608061806280638064806580668067806880698070807180728073807480758076807780788079808080818082808380848085808680878088808980908091809280938094809580968097809880998100810181028103810481058106810781088109811081118112811381148115811681178118811981208121812281238124812581268127812881298130813181328133813481358136813781388139814081418142814381448145814681478148814981508151815281538154815581568157815881598160816181628163816481658166816781688169817081718172817381748175817681778178817981808181818281838184818581868187818881898190819181928193819481958196819781988199820082018202820382048205820682078208820982108211821282138214821582168217821882198220822182228223822482258226822782288229823082318232823382348235823682378238823982408241824282438244824582468247824882498250825182528253825482558256825782588259826082618262826382648265826682678268826982708271827282738274827582768277827882798280828182828283828482858286828782888289829082918292829382948295829682978298829983008301830283038304830583068307830883098310831183128313831483158316831783188319832083218322832383248325832683278328832983308331833283338334833583368337833883398340834183428343834483458346834783488349835083518352835383548355835683578358835983608361836283638364836583668367836883698370837183728373837483758376837783788379838083818382838383848385838683878388838983908391839283938394839583968397839883998400840184028403840484058406840784088409841084118412841384148415841684178418841984208421842284238424842584268427842884298430843184328433843484358436843784388439844084418442844384448445844684478448844984508451845284538454845584568457845884598460846184628463846484658466846784688469847084718472847384748475847684778478847984808481848284838484848584868487848884898490849184928493849484958496849784988499850085018502850385048505850685078508850985108511851285138514851585168517851885198520852185228523852485258526852785288529853085318532853385348535853685378538853985408541854285438544854585468547854885498550855185528553855485558556855785588559856085618562856385648565856685678568856985708571857285738574857585768577857885798580858185828583858485858586858785888589859085918592859385948595859685978598859986008601860286038604860586068607860886098610861186128613861486158616861786188619862086218622862386248625862686278628862986308631863286338634863586368637863886398640864186428643864486458646864786488649865086518652865386548655865686578658865986608661866286638664866586668667866886698670867186728673867486758676867786788679868086818682868386848685868686878688868986908691869286938694869586968697869886998700870187028703870487058706870787088709871087118712871387148715871687178718871987208721872287238724872587268727872887298730873187328733873487358736873787388739874087418742874387448745874687478748874987508751875287538754875587568757875887598760876187628763876487658766876787688769877087718772877387748775877687778778877987808781878287838784878587868787878887898790879187928793879487958796879787988799880088018802880388048805880688078808880988108811881288138814881588168817881888198820882188228823882488258826882788288829883088318832883388348835883688378838883988408841884288438844884588468847884888498850885188528853885488558856885788588859886088618862886388648865886688678868886988708871887288738874887588768877887888798880888188828883888488858886888788888889889088918892889388948895889688978898889989008901890289038904890589068907890889098910891189128913891489158916891789188919892089218922892389248925892689278928892989308931893289338934893589368937893889398940894189428943894489458946894789488949895089518952895389548955895689578958895989608961896289638964896589668967896889698970897189728973897489758976897789788979898089818982898389848985898689878988898989908991899289938994899589968997899889999000900190029003900490059006900790089009901090119012901390149015901690179018901990209021902290239024902590269027902890299030903190329033903490359036903790389039904090419042904390449045904690479048904990509051905290539054905590569057905890599060906190629063906490659066906790689069907090719072907390749075907690779078907990809081908290839084908590869087908890899090909190929093909490959096909790989099910091019102910391049105910691079108910991109111911291139114911591169117911891199120912191229123912491259126912791289129913091319132913391349135913691379138913991409141914291439144914591469147914891499150915191529153915491559156915791589159916091619162916391649165916691679168916991709171917291739174917591769177917891799180918191829183918491859186918791889189919091919192919391949195919691979198919992009201920292039204920592069207920892099210921192129213921492159216921792189219922092219222922392249225922692279228922992309231923292339234923592369237923892399240924192429243924492459246924792489249925092519252925392549255925692579258925992609261926292639264926592669267926892699270927192729273927492759276927792789279928092819282928392849285928692879288928992909291929292939294929592969297929892999300930193029303930493059306930793089309931093119312931393149315931693179318931993209321932293239324932593269327932893299330933193329333933493359336933793389339934093419342934393449345934693479348934993509351935293539354935593569357935893599360936193629363936493659366936793689369937093719372937393749375937693779378937993809381938293839384938593869387938893899390939193929393939493959396939793989399940094019402940394049405940694079408940994109411941294139414941594169417941894199420942194229423942494259426942794289429943094319432943394349435943694379438943994409441944294439444944594469447944894499450945194529453945494559456945794589459946094619462946394649465946694679468946994709471947294739474947594769477947894799480948194829483948494859486948794889489949094919492949394949495949694979498949995009501950295039504950595069507950895099510951195129513951495159516951795189519952095219522952395249525952695279528952995309531953295339534953595369537953895399540954195429543954495459546954795489549955095519552955395549555955695579558955995609561956295639564956595669567956895699570957195729573957495759576957795789579958095819582958395849585958695879588958995909591959295939594959595969597959895999600960196029603960496059606960796089609961096119612961396149615961696179618961996209621962296239624962596269627962896299630963196329633963496359636963796389639964096419642964396449645964696479648964996509651965296539654965596569657965896599660966196629663966496659666966796689669967096719672967396749675967696779678967996809681968296839684968596869687968896899690969196929693969496959696969796989699970097019702970397049705970697079708970997109711971297139714971597169717971897199720972197229723972497259726972797289729973097319732973397349735973697379738973997409741974297439744974597469747974897499750975197529753975497559756975797589759976097619762976397649765976697679768976997709771977297739774977597769777977897799780978197829783978497859786978797889789979097919792979397949795979697979798979998009801980298039804980598069807980898099810981198129813981498159816981798189819982098219822982398249825982698279828982998309831983298339834983598369837983898399840984198429843984498459846984798489849985098519852985398549855985698579858985998609861986298639864986598669867986898699870987198729873987498759876987798789879988098819882988398849885988698879888988998909891989298939894989598969897989898999900990199029903990499059906990799089909991099119912991399149915991699179918991999209921992299239924992599269927992899299930993199329933993499359936993799389939994099419942994399449945994699479948994999509951995299539954995599569957995899599960996199629963996499659966996799689969997099719972997399749975997699779978997999809981998299839984998599869987998899899990999199929993999499959996999799989999100001000110002100031000410005100061000710008100091001010011100121001310014100151001610017100181001910020100211002210023100241002510026100271002810029100301003110032100331003410035100361003710038100391004010041100421004310044100451004610047100481004910050100511005210053100541005510056100571005810059100601006110062100631006410065100661006710068100691007010071100721007310074100751007610077100781007910080100811008210083100841008510086100871008810089100901009110092100931009410095100961009710098100991010010101101021010310104101051010610107101081010910110101111011210113101141011510116101171011810119101201012110122101231012410125101261012710128101291013010131101321013310134101351013610137101381013910140101411014210143101441014510146101471014810149101501015110152101531015410155101561015710158101591016010161101621016310164101651016610167101681016910170101711017210173101741017510176101771017810179101801018110182101831018410185101861018710188101891019010191101921019310194101951019610197101981019910200102011020210203102041020510206102071020810209102101021110212102131021410215102161021710218102191022010221102221022310224102251022610227102281022910230102311023210233102341023510236102371023810239102401024110242102431024410245102461024710248102491025010251102521025310254102551025610257102581025910260102611026210263102641026510266102671026810269102701027110272102731027410275102761027710278102791028010281102821028310284102851028610287102881028910290102911029210293102941029510296102971029810299103001030110302103031030410305103061030710308103091031010311103121031310314103151031610317103181031910320103211032210323103241032510326103271032810329103301033110332103331033410335103361033710338103391034010341103421034310344103451034610347103481034910350103511035210353103541035510356103571035810359103601036110362103631036410365103661036710368103691037010371103721037310374103751037610377103781037910380103811038210383103841038510386103871038810389103901039110392103931039410395103961039710398103991040010401104021040310404104051040610407104081040910410104111041210413104141041510416104171041810419104201042110422104231042410425104261042710428104291043010431104321043310434104351043610437104381043910440104411044210443104441044510446104471044810449104501045110452104531045410455104561045710458104591046010461104621046310464104651046610467104681046910470104711047210473104741047510476104771047810479104801048110482104831048410485104861048710488104891049010491104921049310494104951049610497104981049910500105011050210503105041050510506105071050810509105101051110512105131051410515105161051710518105191052010521105221052310524105251052610527105281052910530105311053210533105341053510536105371053810539105401054110542105431054410545105461054710548105491055010551105521055310554105551055610557105581055910560105611056210563105641056510566105671056810569105701057110572105731057410575105761057710578105791058010581105821058310584105851058610587105881058910590105911059210593105941059510596105971059810599106001060110602106031060410605106061060710608106091061010611106121061310614106151061610617106181061910620106211062210623106241062510626106271062810629106301063110632106331063410635106361063710638106391064010641106421064310644106451064610647106481064910650106511065210653106541065510656106571065810659106601066110662106631066410665106661066710668106691067010671106721067310674106751067610677106781067910680106811068210683106841068510686106871068810689106901069110692106931069410695106961069710698106991070010701107021070310704107051070610707107081070910710107111071210713107141071510716107171071810719107201072110722107231072410725107261072710728107291073010731107321073310734107351073610737107381073910740107411074210743107441074510746107471074810749107501075110752107531075410755107561075710758107591076010761107621076310764107651076610767107681076910770107711077210773107741077510776107771077810779107801078110782107831078410785107861078710788107891079010791107921079310794107951079610797107981079910800108011080210803108041080510806108071080810809108101081110812108131081410815108161081710818108191082010821108221082310824108251082610827108281082910830108311083210833108341083510836108371083810839108401084110842108431084410845108461084710848108491085010851108521085310854108551085610857108581085910860108611086210863108641086510866108671086810869108701087110872108731087410875108761087710878108791088010881108821088310884108851088610887108881088910890108911089210893108941089510896108971089810899109001090110902109031090410905109061090710908109091091010911109121091310914109151091610917109181091910920109211092210923109241092510926109271092810929109301093110932109331093410935109361093710938109391094010941109421094310944109451094610947109481094910950109511095210953109541095510956109571095810959109601096110962109631096410965109661096710968109691097010971109721097310974109751097610977109781097910980109811098210983109841098510986109871098810989109901099110992109931099410995109961099710998109991100011001110021100311004110051100611007110081100911010110111101211013110141101511016110171101811019110201102111022110231102411025110261102711028110291103011031110321103311034110351103611037110381103911040110411104211043110441104511046110471104811049110501105111052110531105411055110561105711058110591106011061110621106311064110651106611067110681106911070110711107211073110741107511076110771107811079110801108111082110831108411085110861108711088110891109011091110921109311094110951109611097110981109911100111011110211103111041110511106111071110811109111101111111112111131111411115111161111711118111191112011121111221112311124111251112611127111281112911130111311113211133111341113511136111371113811139111401114111142111431114411145111461114711148111491115011151111521115311154111551115611157111581115911160111611116211163111641116511166111671116811169111701117111172111731117411175111761117711178111791118011181111821118311184111851118611187111881118911190111911119211193111941119511196111971119811199112001120111202112031120411205112061120711208112091121011211112121121311214112151121611217112181121911220112211122211223112241122511226112271122811229112301123111232112331123411235112361123711238112391124011241112421124311244112451124611247112481124911250112511125211253112541125511256112571125811259112601126111262112631126411265112661126711268112691127011271112721127311274112751127611277112781127911280112811128211283112841128511286112871128811289112901129111292112931129411295112961129711298112991130011301113021130311304113051130611307113081130911310113111131211313113141131511316113171131811319113201132111322113231132411325113261132711328113291133011331113321133311334113351133611337113381133911340113411134211343113441134511346113471134811349113501135111352113531135411355113561135711358113591136011361113621136311364113651136611367113681136911370113711137211373113741137511376113771137811379113801138111382113831138411385113861138711388113891139011391113921139311394113951139611397113981139911400114011140211403114041140511406114071140811409114101141111412114131141411415114161141711418114191142011421114221142311424114251142611427114281142911430114311143211433114341143511436114371143811439114401144111442114431144411445114461144711448114491145011451114521145311454114551145611457114581145911460114611146211463114641146511466114671146811469114701147111472114731147411475114761147711478114791148011481114821148311484114851148611487114881148911490114911149211493114941149511496114971149811499115001150111502115031150411505115061150711508115091151011511115121151311514115151151611517115181151911520115211152211523115241152511526115271152811529115301153111532115331153411535115361153711538115391154011541115421154311544115451154611547115481154911550115511155211553115541155511556115571155811559115601156111562115631156411565115661156711568115691157011571115721157311574115751157611577115781157911580115811158211583115841158511586115871158811589115901159111592115931159411595115961159711598115991160011601116021160311604116051160611607116081160911610116111161211613116141161511616116171161811619116201162111622116231162411625116261162711628116291163011631116321163311634116351163611637116381163911640116411164211643116441164511646116471164811649116501165111652116531165411655116561165711658116591166011661116621166311664116651166611667116681166911670116711167211673116741167511676116771167811679116801168111682116831168411685116861168711688116891169011691116921169311694116951169611697116981169911700117011170211703117041170511706117071170811709117101171111712117131171411715117161171711718117191172011721117221172311724117251172611727117281172911730117311173211733117341173511736117371173811739117401174111742117431174411745117461174711748117491175011751117521175311754117551175611757117581175911760117611176211763117641176511766117671176811769117701177111772117731177411775117761177711778117791178011781117821178311784117851178611787117881178911790117911179211793117941179511796117971179811799118001180111802118031180411805118061180711808118091181011811118121181311814118151181611817118181181911820118211182211823118241182511826118271182811829118301183111832118331183411835118361183711838118391184011841118421184311844118451184611847118481184911850118511185211853118541185511856118571185811859118601186111862118631186411865118661186711868118691187011871118721187311874118751187611877118781187911880118811188211883118841188511886118871188811889118901189111892118931189411895118961189711898118991190011901119021190311904119051190611907119081190911910119111191211913119141191511916119171191811919119201192111922119231192411925119261192711928119291193011931119321193311934119351193611937119381193911940119411194211943119441194511946119471194811949119501195111952119531195411955119561195711958119591196011961119621196311964119651196611967119681196911970119711197211973119741197511976119771197811979119801198111982119831198411985119861198711988119891199011991119921199311994119951199611997119981199912000120011200212003120041200512006120071200812009120101201112012120131201412015120161201712018120191202012021120221202312024120251202612027120281202912030120311203212033120341203512036120371203812039120401204112042120431204412045120461204712048120491205012051120521205312054120551205612057120581205912060120611206212063120641206512066120671206812069120701207112072120731207412075120761207712078120791208012081120821208312084120851208612087120881208912090120911209212093120941209512096120971209812099121001210112102121031210412105121061210712108121091211012111121121211312114121151211612117121181211912120121211212212123121241212512126121271212812129121301213112132121331213412135121361213712138121391214012141121421214312144121451214612147121481214912150121511215212153121541215512156121571215812159121601216112162121631216412165121661216712168121691217012171121721217312174121751217612177121781217912180121811218212183121841218512186121871218812189121901219112192121931219412195121961219712198121991220012201122021220312204122051220612207122081220912210122111221212213122141221512216122171221812219122201222112222122231222412225122261222712228122291223012231122321223312234122351223612237122381223912240122411224212243122441224512246122471224812249122501225112252122531225412255122561225712258122591226012261122621226312264122651226612267122681226912270122711227212273122741227512276122771227812279122801228112282122831228412285122861228712288122891229012291122921229312294122951229612297122981229912300123011230212303123041230512306123071230812309123101231112312123131231412315123161231712318123191232012321123221232312324123251232612327123281232912330123311233212333123341233512336123371233812339123401234112342123431234412345123461234712348123491235012351123521235312354123551235612357123581235912360123611236212363123641236512366123671236812369123701237112372123731237412375123761237712378123791238012381123821238312384123851238612387123881238912390123911239212393123941239512396123971239812399124001240112402124031240412405124061240712408124091241012411124121241312414124151241612417124181241912420124211242212423124241242512426124271242812429124301243112432124331243412435124361243712438124391244012441124421244312444124451244612447124481244912450124511245212453124541245512456124571245812459124601246112462124631246412465124661246712468124691247012471124721247312474124751247612477124781247912480124811248212483124841248512486124871248812489124901249112492124931249412495124961249712498124991250012501125021250312504125051250612507125081250912510125111251212513125141251512516125171251812519125201252112522125231252412525125261252712528125291253012531125321253312534125351253612537125381253912540125411254212543125441254512546125471254812549125501255112552125531255412555125561255712558125591256012561125621256312564125651256612567125681256912570125711257212573125741257512576125771257812579125801258112582125831258412585125861258712588125891259012591125921259312594125951259612597125981259912600126011260212603126041260512606126071260812609126101261112612126131261412615126161261712618126191262012621126221262312624126251262612627126281262912630126311263212633126341263512636126371263812639126401264112642126431264412645126461264712648126491265012651126521265312654126551265612657126581265912660126611266212663126641266512666126671266812669126701267112672126731267412675126761267712678126791268012681126821268312684126851268612687126881268912690126911269212693126941269512696126971269812699127001270112702127031270412705127061270712708127091271012711127121271312714127151271612717127181271912720127211272212723127241272512726127271272812729127301273112732127331273412735127361273712738127391274012741127421274312744127451274612747127481274912750127511275212753127541275512756127571275812759127601276112762127631276412765127661276712768127691277012771127721277312774127751277612777127781277912780127811278212783127841278512786127871278812789127901279112792127931279412795127961279712798127991280012801128021280312804128051280612807128081280912810128111281212813128141281512816128171281812819128201282112822128231282412825128261282712828128291283012831128321283312834128351283612837128381283912840128411284212843128441284512846128471284812849128501285112852128531285412855128561285712858128591286012861128621286312864128651286612867128681286912870128711287212873128741287512876128771287812879128801288112882128831288412885128861288712888128891289012891128921289312894128951289612897128981289912900129011290212903129041290512906129071290812909129101291112912129131291412915129161291712918129191292012921129221292312924129251292612927129281292912930129311293212933129341293512936129371293812939129401294112942129431294412945129461294712948129491295012951129521295312954129551295612957129581295912960129611296212963129641296512966129671296812969129701297112972129731297412975129761297712978129791298012981129821298312984129851298612987129881298912990129911299212993129941299512996129971299812999130001300113002130031300413005130061300713008130091301013011130121301313014130151301613017130181301913020130211302213023130241302513026130271302813029130301303113032130331303413035130361303713038130391304013041130421304313044130451304613047130481304913050130511305213053130541305513056130571305813059130601306113062130631306413065130661306713068130691307013071130721307313074130751307613077130781307913080130811308213083130841308513086130871308813089130901309113092130931309413095130961309713098130991310013101131021310313104131051310613107131081310913110131111311213113131141311513116131171311813119131201312113122131231312413125131261312713128131291313013131131321313313134131351313613137131381313913140131411314213143131441314513146131471314813149131501315113152131531315413155131561315713158131591316013161131621316313164131651316613167131681316913170131711317213173131741317513176131771317813179131801318113182131831318413185131861318713188131891319013191131921319313194131951319613197131981319913200132011320213203132041320513206132071320813209132101321113212132131321413215132161321713218132191322013221132221322313224132251322613227132281322913230132311323213233132341323513236132371323813239132401324113242132431324413245132461324713248132491325013251132521325313254132551325613257132581325913260132611326213263132641326513266132671326813269132701327113272132731327413275132761327713278132791328013281132821328313284132851328613287132881328913290132911329213293132941329513296132971329813299133001330113302133031330413305133061330713308133091331013311133121331313314133151331613317133181331913320133211332213323133241332513326133271332813329133301333113332133331333413335133361333713338133391334013341133421334313344133451334613347133481334913350133511335213353133541335513356133571335813359133601336113362133631336413365133661336713368133691337013371133721337313374133751337613377133781337913380133811338213383133841338513386133871338813389133901339113392133931339413395133961339713398133991340013401134021340313404134051340613407134081340913410134111341213413134141341513416134171341813419134201342113422134231342413425134261342713428134291343013431134321343313434134351343613437134381343913440134411344213443134441344513446134471344813449134501345113452134531345413455134561345713458134591346013461134621346313464134651346613467134681346913470134711347213473134741347513476134771347813479134801348113482134831348413485134861348713488134891349013491134921349313494134951349613497134981349913500135011350213503135041350513506135071350813509135101351113512135131351413515135161351713518135191352013521135221352313524135251352613527135281352913530135311353213533135341353513536135371353813539135401354113542135431354413545135461354713548135491355013551135521355313554135551355613557135581355913560135611356213563135641356513566135671356813569135701357113572135731357413575135761357713578135791358013581135821358313584135851358613587135881358913590135911359213593135941359513596135971359813599136001360113602136031360413605136061360713608136091361013611136121361313614136151361613617136181361913620136211362213623136241362513626136271362813629136301363113632136331363413635136361363713638136391364013641136421364313644136451364613647136481364913650136511365213653136541365513656136571365813659136601366113662136631366413665136661366713668136691367013671136721367313674136751367613677136781367913680136811368213683136841368513686136871368813689136901369113692136931369413695136961369713698136991370013701137021370313704137051370613707137081370913710137111371213713137141371513716137171371813719137201372113722137231372413725137261372713728137291373013731137321373313734137351373613737137381373913740137411374213743137441374513746137471374813749137501375113752137531375413755137561375713758137591376013761137621376313764137651376613767137681376913770137711377213773137741377513776137771377813779137801378113782137831378413785137861378713788137891379013791137921379313794137951379613797137981379913800138011380213803138041380513806138071380813809138101381113812138131381413815138161381713818138191382013821138221382313824138251382613827138281382913830138311383213833138341383513836138371383813839138401384113842138431384413845138461384713848138491385013851138521385313854138551385613857138581385913860138611386213863138641386513866138671386813869138701387113872138731387413875138761387713878138791388013881138821388313884138851388613887138881388913890138911389213893138941389513896138971389813899139001390113902139031390413905139061390713908139091391013911139121391313914139151391613917139181391913920139211392213923139241392513926139271392813929139301393113932139331393413935139361393713938139391394013941139421394313944139451394613947139481394913950139511395213953139541395513956139571395813959139601396113962139631396413965139661396713968139691397013971139721397313974139751397613977139781397913980139811398213983139841398513986139871398813989139901399113992139931399413995139961399713998139991400014001140021400314004140051400614007140081400914010140111401214013140141401514016140171401814019140201402114022140231402414025140261402714028140291403014031140321403314034140351403614037140381403914040140411404214043140441404514046140471404814049140501405114052140531405414055140561405714058140591406014061140621406314064140651406614067140681406914070140711407214073140741407514076140771407814079140801408114082140831408414085140861408714088140891409014091140921409314094140951409614097140981409914100141011410214103141041410514106141071410814109141101411114112141131411414115141161411714118141191412014121141221412314124141251412614127141281412914130141311413214133141341413514136141371413814139141401414114142141431414414145141461414714148141491415014151141521415314154141551415614157141581415914160141611416214163141641416514166141671416814169141701417114172141731417414175141761417714178141791418014181141821418314184141851418614187141881418914190141911419214193141941419514196141971419814199142001420114202142031420414205142061420714208142091421014211142121421314214142151421614217142181421914220142211422214223142241422514226142271422814229142301423114232142331423414235142361423714238142391424014241142421424314244142451424614247142481424914250142511425214253142541425514256142571425814259142601426114262142631426414265142661426714268142691427014271142721427314274142751427614277142781427914280142811428214283142841428514286142871428814289142901429114292142931429414295142961429714298142991430014301143021430314304143051430614307143081430914310143111431214313143141431514316143171431814319143201432114322143231432414325143261432714328143291433014331143321433314334143351433614337143381433914340143411434214343143441434514346143471434814349143501435114352143531435414355143561435714358143591436014361143621436314364143651436614367143681436914370143711437214373143741437514376143771437814379143801438114382143831438414385143861438714388143891439014391143921439314394143951439614397143981439914400144011440214403144041440514406144071440814409144101441114412144131441414415144161441714418144191442014421144221442314424144251442614427144281442914430144311443214433144341443514436144371443814439144401444114442144431444414445144461444714448144491445014451144521445314454144551445614457144581445914460144611446214463144641446514466144671446814469144701447114472144731447414475144761447714478144791448014481144821448314484144851448614487144881448914490144911449214493144941449514496144971449814499145001450114502145031450414505145061450714508145091451014511145121451314514145151451614517145181451914520145211452214523145241452514526145271452814529145301453114532145331453414535145361453714538145391454014541145421454314544145451454614547145481454914550145511455214553145541455514556145571455814559145601456114562145631456414565145661456714568145691457014571145721457314574145751457614577145781457914580145811458214583145841458514586145871458814589145901459114592145931459414595145961459714598145991460014601146021460314604146051460614607146081460914610146111461214613146141461514616146171461814619146201462114622146231462414625146261462714628146291463014631146321463314634146351463614637146381463914640146411464214643146441464514646146471464814649146501465114652146531465414655146561465714658146591466014661146621466314664146651466614667146681466914670146711467214673146741467514676146771467814679146801468114682146831468414685146861468714688146891469014691146921469314694146951469614697146981469914700147011470214703147041470514706147071470814709147101471114712147131471414715147161471714718147191472014721147221472314724147251472614727147281472914730147311473214733147341473514736147371473814739147401474114742147431474414745147461474714748147491475014751147521475314754147551475614757147581475914760147611476214763147641476514766147671476814769147701477114772147731477414775147761477714778147791478014781147821478314784147851478614787147881478914790147911479214793147941479514796147971479814799148001480114802148031480414805148061480714808148091481014811148121481314814148151481614817148181481914820148211482214823148241482514826148271482814829148301483114832148331483414835148361483714838148391484014841148421484314844148451484614847148481484914850148511485214853148541485514856148571485814859148601486114862148631486414865148661486714868148691487014871148721487314874148751487614877148781487914880148811488214883148841488514886148871488814889148901489114892148931489414895148961489714898148991490014901149021490314904149051490614907149081490914910149111491214913149141491514916149171491814919149201492114922149231492414925149261492714928149291493014931149321493314934149351493614937149381493914940149411494214943149441494514946149471494814949149501495114952149531495414955149561495714958149591496014961149621496314964149651496614967149681496914970149711497214973149741497514976149771497814979149801498114982149831498414985149861498714988149891499014991149921499314994149951499614997149981499915000150011500215003150041500515006150071500815009150101501115012150131501415015150161501715018150191502015021150221502315024150251502615027150281502915030150311503215033150341503515036150371503815039150401504115042150431504415045150461504715048150491505015051150521505315054150551505615057150581505915060150611506215063150641506515066150671506815069150701507115072150731507415075150761507715078150791508015081150821508315084150851508615087150881508915090150911509215093150941509515096150971509815099151001510115102151031510415105151061510715108151091511015111151121511315114151151511615117151181511915120151211512215123151241512515126151271512815129151301513115132151331513415135151361513715138151391514015141151421514315144151451514615147151481514915150151511515215153151541515515156151571515815159151601516115162151631516415165151661516715168151691517015171151721517315174151751517615177151781517915180151811518215183151841518515186151871518815189151901519115192151931519415195151961519715198151991520015201152021520315204152051520615207152081520915210152111521215213152141521515216152171521815219152201522115222152231522415225152261522715228152291523015231152321523315234152351523615237152381523915240152411524215243152441524515246152471524815249152501525115252152531525415255152561525715258152591526015261152621526315264152651526615267152681526915270152711527215273152741527515276152771527815279152801528115282152831528415285152861528715288152891529015291152921529315294152951529615297152981529915300153011530215303153041530515306153071530815309153101531115312153131531415315153161531715318153191532015321153221532315324153251532615327153281532915330153311533215333153341533515336153371533815339153401534115342153431534415345153461534715348153491535015351153521535315354153551535615357153581535915360153611536215363153641536515366153671536815369153701537115372153731537415375153761537715378153791538015381153821538315384153851538615387153881538915390153911539215393153941539515396153971539815399154001540115402154031540415405154061540715408154091541015411154121541315414154151541615417154181541915420154211542215423154241542515426154271542815429154301543115432154331543415435154361543715438154391544015441154421544315444154451544615447154481544915450154511545215453154541545515456154571545815459154601546115462154631546415465154661546715468154691547015471154721547315474154751547615477154781547915480154811548215483154841548515486154871548815489154901549115492154931549415495154961549715498154991550015501155021550315504155051550615507155081550915510155111551215513155141551515516155171551815519155201552115522155231552415525155261552715528155291553015531155321553315534155351553615537155381553915540155411554215543155441554515546155471554815549155501555115552155531555415555155561555715558155591556015561155621556315564155651556615567155681556915570155711557215573155741557515576155771557815579155801558115582155831558415585155861558715588155891559015591155921559315594155951559615597155981559915600156011560215603156041560515606156071560815609156101561115612156131561415615156161561715618156191562015621156221562315624156251562615627156281562915630156311563215633156341563515636156371563815639156401564115642156431564415645156461564715648156491565015651156521565315654156551565615657156581565915660156611566215663156641566515666156671566815669156701567115672156731567415675156761567715678156791568015681156821568315684156851568615687156881568915690156911569215693156941569515696156971569815699157001570115702157031570415705157061570715708157091571015711157121571315714157151571615717157181571915720157211572215723157241572515726157271572815729157301573115732157331573415735157361573715738157391574015741157421574315744157451574615747157481574915750157511575215753157541575515756157571575815759157601576115762157631576415765157661576715768157691577015771157721577315774157751577615777157781577915780157811578215783157841578515786157871578815789157901579115792157931579415795157961579715798157991580015801158021580315804158051580615807158081580915810158111581215813158141581515816158171581815819158201582115822158231582415825158261582715828158291583015831158321583315834158351583615837158381583915840158411584215843158441584515846158471584815849158501585115852158531585415855158561585715858158591586015861158621586315864158651586615867158681586915870158711587215873158741587515876158771587815879158801588115882158831588415885158861588715888158891589015891158921589315894158951589615897158981589915900159011590215903159041590515906159071590815909159101591115912159131591415915159161591715918159191592015921159221592315924159251592615927159281592915930159311593215933159341593515936159371593815939159401594115942159431594415945159461594715948159491595015951159521595315954159551595615957159581595915960159611596215963159641596515966159671596815969159701597115972159731597415975159761597715978159791598015981159821598315984159851598615987159881598915990159911599215993159941599515996159971599815999160001600116002160031600416005160061600716008160091601016011160121601316014160151601616017160181601916020160211602216023160241602516026160271602816029160301603116032160331603416035160361603716038160391604016041160421604316044160451604616047160481604916050160511605216053160541605516056160571605816059160601606116062160631606416065160661606716068160691607016071160721607316074160751607616077160781607916080160811608216083160841608516086160871608816089160901609116092160931609416095160961609716098160991610016101161021610316104161051610616107161081610916110161111611216113161141611516116161171611816119161201612116122161231612416125161261612716128161291613016131161321613316134161351613616137161381613916140161411614216143161441614516146161471614816149161501615116152161531615416155161561615716158161591616016161161621616316164161651616616167161681616916170161711617216173161741617516176161771617816179161801618116182161831618416185161861618716188161891619016191161921619316194161951619616197161981619916200162011620216203162041620516206162071620816209162101621116212162131621416215162161621716218162191622016221162221622316224162251622616227162281622916230162311623216233162341623516236162371623816239162401624116242162431624416245162461624716248162491625016251162521625316254162551625616257162581625916260162611626216263162641626516266162671626816269162701627116272162731627416275162761627716278162791628016281162821628316284162851628616287162881628916290162911629216293162941629516296162971629816299163001630116302163031630416305163061630716308163091631016311163121631316314163151631616317163181631916320163211632216323163241632516326163271632816329163301633116332163331633416335163361633716338163391634016341163421634316344163451634616347163481634916350163511635216353163541635516356163571635816359163601636116362163631636416365163661636716368163691637016371163721637316374163751637616377163781637916380163811638216383163841638516386163871638816389163901639116392163931639416395163961639716398163991640016401164021640316404164051640616407164081640916410164111641216413164141641516416164171641816419164201642116422164231642416425164261642716428164291643016431164321643316434164351643616437164381643916440164411644216443164441644516446164471644816449164501645116452164531645416455164561645716458164591646016461164621646316464164651646616467164681646916470164711647216473164741647516476164771647816479164801648116482164831648416485164861648716488164891649016491164921649316494164951649616497164981649916500165011650216503165041650516506165071650816509165101651116512165131651416515165161651716518165191652016521165221652316524165251652616527165281652916530165311653216533165341653516536165371653816539165401654116542165431654416545165461654716548165491655016551165521655316554165551655616557165581655916560165611656216563165641656516566165671656816569165701657116572165731657416575165761657716578165791658016581165821658316584165851658616587165881658916590165911659216593165941659516596165971659816599166001660116602166031660416605166061660716608166091661016611166121661316614166151661616617166181661916620166211662216623166241662516626166271662816629166301663116632166331663416635166361663716638166391664016641166421664316644166451664616647166481664916650166511665216653166541665516656166571665816659166601666116662166631666416665166661666716668166691667016671166721667316674166751667616677166781667916680166811668216683166841668516686166871668816689166901669116692166931669416695166961669716698166991670016701167021670316704167051670616707167081670916710167111671216713167141671516716167171671816719167201672116722167231672416725167261672716728167291673016731167321673316734167351673616737167381673916740167411674216743167441674516746167471674816749167501675116752167531675416755167561675716758167591676016761167621676316764167651676616767167681676916770167711677216773167741677516776167771677816779167801678116782167831678416785167861678716788167891679016791167921679316794167951679616797167981679916800168011680216803168041680516806168071680816809168101681116812168131681416815168161681716818168191682016821168221682316824168251682616827168281682916830168311683216833168341683516836168371683816839168401684116842168431684416845168461684716848168491685016851168521685316854168551685616857168581685916860168611686216863168641686516866168671686816869168701687116872168731687416875168761687716878168791688016881168821688316884168851688616887168881688916890168911689216893168941689516896168971689816899169001690116902169031690416905169061690716908169091691016911169121691316914169151691616917169181691916920169211692216923169241692516926169271692816929169301693116932169331693416935169361693716938169391694016941169421694316944169451694616947169481694916950169511695216953169541695516956169571695816959169601696116962169631696416965169661696716968169691697016971169721697316974169751697616977169781697916980169811698216983169841698516986169871698816989169901699116992169931699416995169961699716998169991700017001170021700317004170051700617007170081700917010170111701217013170141701517016170171701817019170201702117022170231702417025170261702717028170291703017031170321703317034170351703617037170381703917040170411704217043170441704517046170471704817049170501705117052170531705417055170561705717058170591706017061170621706317064170651706617067170681706917070170711707217073170741707517076170771707817079170801708117082170831708417085170861708717088170891709017091170921709317094170951709617097170981709917100171011710217103171041710517106171071710817109171101711117112171131711417115171161711717118171191712017121171221712317124171251712617127171281712917130171311713217133171341713517136171371713817139171401714117142171431714417145171461714717148171491715017151171521715317154171551715617157171581715917160171611716217163171641716517166171671716817169171701717117172171731717417175171761717717178171791718017181171821718317184171851718617187171881718917190171911719217193171941719517196171971719817199172001720117202172031720417205172061720717208172091721017211172121721317214172151721617217172181721917220172211722217223172241722517226172271722817229172301723117232172331723417235172361723717238172391724017241172421724317244172451724617247172481724917250172511725217253172541725517256172571725817259172601726117262172631726417265172661726717268172691727017271172721727317274172751727617277172781727917280172811728217283172841728517286172871728817289172901729117292172931729417295172961729717298172991730017301173021730317304173051730617307173081730917310173111731217313173141731517316173171731817319173201732117322173231732417325173261732717328173291733017331173321733317334173351733617337173381733917340173411734217343173441734517346173471734817349173501735117352173531735417355173561735717358173591736017361173621736317364173651736617367173681736917370173711737217373173741737517376173771737817379173801738117382173831738417385173861738717388173891739017391173921739317394173951739617397173981739917400174011740217403174041740517406174071740817409174101741117412174131741417415174161741717418174191742017421174221742317424174251742617427174281742917430174311743217433174341743517436174371743817439174401744117442174431744417445174461744717448174491745017451174521745317454174551745617457174581745917460174611746217463174641746517466174671746817469174701747117472174731747417475174761747717478174791748017481174821748317484174851748617487174881748917490174911749217493174941749517496174971749817499175001750117502175031750417505175061750717508175091751017511175121751317514175151751617517175181751917520175211752217523175241752517526175271752817529175301753117532175331753417535175361753717538175391754017541175421754317544175451754617547175481754917550175511755217553175541755517556175571755817559175601756117562175631756417565175661756717568175691757017571175721757317574175751757617577175781757917580175811758217583175841758517586175871758817589175901759117592175931759417595175961759717598175991760017601176021760317604176051760617607176081760917610176111761217613176141761517616176171761817619176201762117622176231762417625176261762717628176291763017631176321763317634176351763617637176381763917640176411764217643176441764517646176471764817649176501765117652176531765417655176561765717658176591766017661176621766317664176651766617667176681766917670176711767217673176741767517676176771767817679176801768117682176831768417685176861768717688176891769017691176921769317694176951769617697176981769917700177011770217703177041770517706177071770817709177101771117712177131771417715177161771717718177191772017721177221772317724177251772617727177281772917730177311773217733177341773517736177371773817739177401774117742177431774417745177461774717748177491775017751177521775317754177551775617757177581775917760177611776217763177641776517766177671776817769177701777117772177731777417775177761777717778177791778017781177821778317784177851778617787177881778917790177911779217793177941779517796177971779817799178001780117802178031780417805178061780717808178091781017811178121781317814178151781617817178181781917820178211782217823178241782517826178271782817829178301783117832178331783417835178361783717838178391784017841178421784317844178451784617847178481784917850178511785217853178541785517856178571785817859178601786117862178631786417865178661786717868178691787017871178721787317874178751787617877178781787917880178811788217883178841788517886178871788817889178901789117892178931789417895178961789717898178991790017901179021790317904179051790617907179081790917910179111791217913179141791517916179171791817919179201792117922179231792417925179261792717928179291793017931179321793317934179351793617937179381793917940179411794217943179441794517946179471794817949179501795117952179531795417955179561795717958179591796017961179621796317964179651796617967179681796917970179711797217973179741797517976179771797817979179801798117982179831798417985179861798717988179891799017991179921799317994179951799617997179981799918000180011800218003180041800518006180071800818009180101801118012180131801418015180161801718018180191802018021180221802318024180251802618027180281802918030180311803218033180341803518036180371803818039180401804118042180431804418045180461804718048180491805018051180521805318054180551805618057180581805918060180611806218063180641806518066180671806818069180701807118072180731807418075180761807718078180791808018081180821808318084180851808618087180881808918090180911809218093180941809518096180971809818099181001810118102181031810418105181061810718108181091811018111181121811318114181151811618117181181811918120181211812218123181241812518126181271812818129181301813118132181331813418135181361813718138181391814018141181421814318144181451814618147181481814918150181511815218153181541815518156181571815818159181601816118162181631816418165181661816718168181691817018171181721817318174181751817618177181781817918180181811818218183181841818518186181871818818189181901819118192181931819418195181961819718198181991820018201182021820318204182051820618207182081820918210182111821218213182141821518216182171821818219182201822118222182231822418225182261822718228182291823018231182321823318234182351823618237182381823918240182411824218243182441824518246182471824818249182501825118252182531825418255182561825718258182591826018261182621826318264182651826618267182681826918270182711827218273182741827518276182771827818279182801828118282182831828418285182861828718288182891829018291182921829318294182951829618297182981829918300183011830218303183041830518306183071830818309183101831118312183131831418315183161831718318183191832018321183221832318324183251832618327183281832918330183311833218333183341833518336183371833818339183401834118342183431834418345183461834718348183491835018351183521835318354183551835618357183581835918360183611836218363183641836518366183671836818369183701837118372183731837418375183761837718378183791838018381183821838318384183851838618387183881838918390183911839218393183941839518396183971839818399184001840118402184031840418405184061840718408184091841018411184121841318414184151841618417184181841918420184211842218423184241842518426184271842818429184301843118432184331843418435184361843718438184391844018441184421844318444184451844618447184481844918450184511845218453184541845518456184571845818459184601846118462184631846418465184661846718468184691847018471184721847318474184751847618477184781847918480184811848218483184841848518486184871848818489184901849118492184931849418495184961849718498184991850018501185021850318504185051850618507185081850918510185111851218513185141851518516185171851818519185201852118522185231852418525185261852718528185291853018531185321853318534185351853618537185381853918540185411854218543185441854518546185471854818549185501855118552185531855418555185561855718558185591856018561185621856318564185651856618567185681856918570185711857218573185741857518576185771857818579185801858118582185831858418585185861858718588185891859018591185921859318594185951859618597185981859918600186011860218603186041860518606186071860818609186101861118612186131861418615186161861718618186191862018621186221862318624186251862618627186281862918630186311863218633186341863518636186371863818639186401864118642186431864418645186461864718648186491865018651186521865318654186551865618657186581865918660186611866218663186641866518666186671866818669186701867118672186731867418675186761867718678186791868018681186821868318684186851868618687186881868918690186911869218693186941869518696186971869818699187001870118702187031870418705187061870718708187091871018711187121871318714187151871618717187181871918720187211872218723187241872518726187271872818729187301873118732187331873418735187361873718738187391874018741187421874318744187451874618747187481874918750187511875218753187541875518756187571875818759187601876118762187631876418765187661876718768187691877018771187721877318774187751877618777187781877918780187811878218783187841878518786187871878818789187901879118792187931879418795187961879718798187991880018801188021880318804188051880618807188081880918810188111881218813188141881518816188171881818819188201882118822188231882418825188261882718828188291883018831188321883318834188351883618837188381883918840188411884218843188441884518846188471884818849188501885118852188531885418855188561885718858188591886018861188621886318864188651886618867188681886918870188711887218873188741887518876188771887818879188801888118882188831888418885188861888718888188891889018891188921889318894188951889618897188981889918900189011890218903189041890518906189071890818909189101891118912189131891418915189161891718918189191892018921189221892318924189251892618927189281892918930189311893218933189341893518936189371893818939189401894118942189431894418945189461894718948189491895018951189521895318954189551895618957189581895918960189611896218963189641896518966189671896818969189701897118972189731897418975189761897718978189791898018981189821898318984189851898618987189881898918990189911899218993189941899518996189971899818999190001900119002190031900419005190061900719008190091901019011190121901319014190151901619017190181901919020190211902219023190241902519026190271902819029190301903119032190331903419035190361903719038190391904019041190421904319044190451904619047190481904919050190511905219053190541905519056190571905819059190601906119062190631906419065190661906719068190691907019071190721907319074190751907619077190781907919080190811908219083190841908519086190871908819089190901909119092190931909419095190961909719098190991910019101191021910319104191051910619107191081910919110191111911219113191141911519116191171911819119191201912119122191231912419125191261912719128191291913019131191321913319134191351913619137191381913919140191411914219143191441914519146191471914819149191501915119152191531915419155191561915719158191591916019161191621916319164191651916619167191681916919170191711917219173191741917519176191771917819179191801918119182191831918419185191861918719188191891919019191191921919319194191951919619197191981919919200192011920219203192041920519206192071920819209192101921119212192131921419215192161921719218192191922019221192221922319224192251922619227192281922919230192311923219233192341923519236192371923819239192401924119242192431924419245192461924719248192491925019251192521925319254192551925619257192581925919260192611926219263192641926519266192671926819269192701927119272192731927419275192761927719278192791928019281192821928319284192851928619287192881928919290192911929219293192941929519296192971929819299193001930119302193031930419305193061930719308193091931019311193121931319314193151931619317193181931919320193211932219323193241932519326193271932819329193301933119332193331933419335193361933719338193391934019341193421934319344193451934619347193481934919350193511935219353193541935519356193571935819359193601936119362193631936419365193661936719368193691937019371193721937319374193751937619377193781937919380193811938219383193841938519386193871938819389193901939119392193931939419395193961939719398193991940019401194021940319404194051940619407194081940919410194111941219413194141941519416194171941819419194201942119422194231942419425194261942719428194291943019431194321943319434194351943619437194381943919440194411944219443194441944519446194471944819449194501945119452194531945419455194561945719458194591946019461194621946319464194651946619467194681946919470194711947219473194741947519476194771947819479194801948119482194831948419485194861948719488194891949019491194921949319494194951949619497194981949919500195011950219503195041950519506195071950819509195101951119512195131951419515195161951719518195191952019521195221952319524195251952619527195281952919530195311953219533195341953519536195371953819539195401954119542195431954419545195461954719548195491955019551195521955319554195551955619557195581955919560195611956219563195641956519566195671956819569195701957119572195731957419575195761957719578195791958019581195821958319584195851958619587195881958919590195911959219593195941959519596195971959819599196001960119602196031960419605196061960719608196091961019611196121961319614196151961619617196181961919620196211962219623196241962519626196271962819629196301963119632196331963419635196361963719638196391964019641196421964319644196451964619647196481964919650196511965219653196541965519656196571965819659196601966119662196631966419665196661966719668196691967019671196721967319674196751967619677196781967919680196811968219683196841968519686196871968819689196901969119692196931969419695196961969719698196991970019701197021970319704197051970619707197081970919710197111971219713197141971519716197171971819719197201972119722197231972419725197261972719728197291973019731197321973319734197351973619737197381973919740197411974219743197441974519746197471974819749197501975119752197531975419755197561975719758197591976019761197621976319764197651976619767197681976919770197711977219773197741977519776197771977819779197801978119782197831978419785197861978719788197891979019791197921979319794197951979619797197981979919800198011980219803198041980519806198071980819809198101981119812198131981419815198161981719818198191982019821198221982319824198251982619827198281982919830198311983219833198341983519836198371983819839198401984119842198431984419845198461984719848198491985019851198521985319854198551985619857198581985919860198611986219863198641986519866198671986819869198701987119872198731987419875198761987719878198791988019881198821988319884198851988619887198881988919890198911989219893198941989519896198971989819899199001990119902199031990419905199061990719908199091991019911199121991319914199151991619917199181991919920199211992219923199241992519926199271992819929199301993119932199331993419935199361993719938199391994019941199421994319944199451994619947199481994919950199511995219953199541995519956199571995819959199601996119962199631996419965199661996719968199691997019971199721997319974199751997619977199781997919980199811998219983199841998519986199871998819989199901999119992199931999419995199961999719998199992000020001200022000320004200052000620007200082000920010200112001220013200142001520016200172001820019200202002120022200232002420025200262002720028200292003020031200322003320034200352003620037200382003920040200412004220043200442004520046200472004820049200502005120052200532005420055200562005720058200592006020061200622006320064200652006620067200682006920070200712007220073200742007520076200772007820079200802008120082200832008420085200862008720088200892009020091200922009320094200952009620097200982009920100201012010220103201042010520106201072010820109201102011120112201132011420115201162011720118201192012020121201222012320124201252012620127201282012920130201312013220133201342013520136201372013820139201402014120142201432014420145201462014720148201492015020151201522015320154201552015620157201582015920160201612016220163201642016520166201672016820169201702017120172201732017420175201762017720178201792018020181201822018320184201852018620187201882018920190201912019220193201942019520196201972019820199202002020120202202032020420205202062020720208202092021020211202122021320214202152021620217202182021920220202212022220223202242022520226202272022820229202302023120232202332023420235202362023720238202392024020241202422024320244202452024620247202482024920250202512025220253202542025520256202572025820259202602026120262202632026420265202662026720268202692027020271202722027320274202752027620277202782027920280202812028220283202842028520286202872028820289202902029120292202932029420295202962029720298202992030020301203022030320304203052030620307203082030920310203112031220313203142031520316203172031820319203202032120322203232032420325203262032720328203292033020331203322033320334203352033620337203382033920340203412034220343203442034520346203472034820349203502035120352203532035420355203562035720358203592036020361203622036320364203652036620367203682036920370203712037220373203742037520376203772037820379203802038120382203832038420385203862038720388203892039020391203922039320394203952039620397203982039920400204012040220403204042040520406204072040820409204102041120412204132041420415204162041720418204192042020421204222042320424204252042620427204282042920430204312043220433204342043520436204372043820439204402044120442204432044420445204462044720448204492045020451204522045320454204552045620457204582045920460204612046220463204642046520466204672046820469204702047120472204732047420475204762047720478204792048020481204822048320484204852048620487204882048920490204912049220493204942049520496204972049820499205002050120502205032050420505205062050720508205092051020511205122051320514205152051620517205182051920520205212052220523205242052520526205272052820529205302053120532205332053420535205362053720538205392054020541205422054320544205452054620547205482054920550205512055220553205542055520556205572055820559205602056120562205632056420565205662056720568205692057020571205722057320574205752057620577205782057920580205812058220583205842058520586205872058820589205902059120592205932059420595205962059720598205992060020601206022060320604206052060620607206082060920610206112061220613206142061520616206172061820619206202062120622206232062420625206262062720628206292063020631206322063320634206352063620637206382063920640206412064220643206442064520646206472064820649206502065120652206532065420655206562065720658206592066020661206622066320664206652066620667206682066920670206712067220673206742067520676206772067820679206802068120682206832068420685206862068720688206892069020691206922069320694206952069620697206982069920700207012070220703207042070520706207072070820709207102071120712207132071420715207162071720718207192072020721207222072320724207252072620727207282072920730207312073220733207342073520736207372073820739207402074120742207432074420745207462074720748207492075020751207522075320754207552075620757207582075920760207612076220763207642076520766207672076820769207702077120772207732077420775207762077720778207792078020781207822078320784207852078620787207882078920790207912079220793207942079520796207972079820799208002080120802208032080420805208062080720808208092081020811208122081320814208152081620817208182081920820208212082220823208242082520826208272082820829208302083120832208332083420835208362083720838208392084020841208422084320844208452084620847208482084920850208512085220853208542085520856208572085820859208602086120862208632086420865208662086720868208692087020871208722087320874208752087620877208782087920880208812088220883208842088520886208872088820889208902089120892208932089420895208962089720898208992090020901209022090320904209052090620907209082090920910209112091220913209142091520916209172091820919209202092120922209232092420925209262092720928209292093020931209322093320934209352093620937209382093920940209412094220943209442094520946209472094820949
  1. package QCM.QCM03.QCM0307;
  2. import CoreFS.SA01.CoreIComponent;
  3. import CoreFS.SA06.CoreReturnObject;
  4. import QCM.COMMUNAL.QCM02.SqlJoint;
  5. import QCM.COMMUNAL.VO.*;
  6. import QCM.JHY01.JHY0101.DuplicateSample2;
  7. import QCM.JHY01.JHY0102.UpdateInfo;
  8. import QCM.QCM03.QCM0301.QcmJhyElementsServiceImpl;
  9. import QCM.QCM03.QCM0302.QcmJhyPhyresultServiceImpl;
  10. import QCM.QCM03.QCM0302.QcmJudgePhysicalServiceImpl;
  11. import QCM.QCM03.QCM0303.QcmJudgeMeasureServiceImpl;
  12. import QCM.QCM03.QCM0305.QcmJudgeSurfaceServiceImpl;
  13. import com.alibaba.fastjson.JSON;
  14. import com.alibaba.fastjson.JSONArray;
  15. import com.alibaba.fastjson.JSONObject;
  16. import org.apache.axis.client.Call;
  17. import org.apache.axis.client.Service;
  18. import org.apache.commons.lang.StringEscapeUtils;
  19. import org.apache.commons.lang.StringUtils;
  20. import org.apache.http.HttpResponse;
  21. import org.apache.http.HttpStatus;
  22. import org.apache.http.NameValuePair;
  23. import org.apache.http.client.HttpClient;
  24. import org.apache.http.client.entity.UrlEncodedFormEntity;
  25. import org.apache.http.client.methods.CloseableHttpResponse;
  26. import org.apache.http.client.methods.HttpPost;
  27. import org.apache.http.entity.StringEntity;
  28. import org.apache.http.impl.client.CloseableHttpClient;
  29. import org.apache.http.impl.client.DefaultHttpClient;
  30. import org.apache.http.impl.client.HttpClients;
  31. import org.apache.http.message.BasicHeader;
  32. import org.apache.http.message.BasicNameValuePair;
  33. import org.apache.http.protocol.HTTP;
  34. import org.apache.http.util.EntityUtils;
  35. import org.apache.ibatis.session.SqlSession;
  36. import org.apache.log4j.Logger;
  37. import pda.WebService1Impl;
  38. import java.io.BufferedReader;
  39. import java.io.IOException;
  40. import java.io.InputStream;
  41. import java.io.InputStreamReader;
  42. import java.sql.CallableStatement;
  43. import java.sql.Connection;
  44. import java.sql.ResultSet;
  45. import java.text.DecimalFormat;
  46. import java.text.SimpleDateFormat;
  47. import java.util.*;
  48. import java.util.regex.Matcher;
  49. import java.util.regex.Pattern;
  50. import javax.xml.namespace.QName;
  51. import javax.xml.rpc.ParameterMode;
  52. @SuppressWarnings("unused")
  53. public class QcmRejudgeApplyServiceImpl extends CoreIComponent{
  54. CoreReturnObject cro = new CoreReturnObject();
  55. SqlSession SqlSession =
  56. QCM.COMMUNAL.SqlSessionBuilder.openSqlSession();
  57. QCM.COMMUNAL.OrderSqMapper mapper = SqlSession.getMapper(QCM.COMMUNAL.OrderSqMapper.class);
  58. Logger logger = Logger.getLogger(this.getClass().getName());
  59. //QcmJhyElementsServiceImpl qjes = new QcmJhyElementsServiceImpl();
  60. public String StrSky(String begintime,String endtime){
  61. String sql = "select (to_date('"+endtime+"','yyyy-MM-dd') - to_date('"+begintime+"','yyyy-MM-dd')) SKY from dual";
  62. HashMap list = mapper.queryOne(sql);
  63. Double ble = Double.parseDouble(list.get("SKY").toString());
  64. String tstr="查询时间不能大于一年,请核实查询时间条件!";
  65. if(ble>=0 && ble <=365 ){
  66. tstr="TRUE";
  67. }
  68. return tstr;
  69. }
  70. /**
  71. * 异常材处置界面,查询待处置信息
  72. * @param sum
  73. * @return
  74. */
  75. @SuppressWarnings({ "rawtypes", "unchecked" })
  76. public CoreReturnObject getInformation2(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String judge_type,String lock_type_desc) {
  77. String conn="unlock_type_code is null ";
  78. try {
  79. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  80. String sky=StrSky(begintime,endtime);
  81. if(!sky.equals("TRUE")){
  82. SqlSession.close();
  83. cro.setV_errCode(-1);
  84. cro.setV_errMsg(sky);
  85. return cro;
  86. }
  87. }
  88. if (!SqlJoint.IsNullOrSpace(design_key)) {
  89. conn+=" and a.design_key like '%"+design_key+"%'";
  90. }
  91. if (!SqlJoint.IsNullOrSpace(psc)) {
  92. conn+=" and psc_desc like '%"+psc+"%'";
  93. }
  94. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  95. conn+=" and to_date(to_char(lock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  96. }
  97. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  98. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  99. }
  100. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  101. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  102. }
  103. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  104. if(lock_type_desc.equals("成分判定")){
  105. conn += " and a.lock_type_code = 'C'";
  106. }else if(lock_type_desc.equals("材质判定")){
  107. conn += " and a.lock_type_code = 'P'";
  108. }else if(lock_type_desc.equals("表面检验")){
  109. conn += " and a.lock_type_code = 'F'";
  110. }else if(lock_type_desc.equals("公差检验")){
  111. conn += " and a.lock_type_code = 'S'";
  112. }else if(lock_type_desc.equals("工艺检验")){
  113. conn += " and a.lock_type_code = 'T'";
  114. }
  115. else
  116. {
  117. conn+= " and a.lock_type_code = 'D'";
  118. }
  119. }
  120. if(!SqlJoint.IsNullOrSpace(type)){
  121. //卷板
  122. if(type.equals("0")){
  123. conn += " and a.pline_code in ('LT1','SZ1','RZ1')";
  124. }
  125. //中厚板
  126. else if(type.equals("1")){
  127. conn += " and a.pline_code in ('ZB1','HB1')";
  128. }
  129. //线棒
  130. else if(type.equals("2")){
  131. conn += " and a.pline_code in ('GX1','BC1','BC2','GX2','4001GX1','4001GX2','4001BC2')";
  132. }
  133. else if(type.equals("3")){
  134. conn += " and a.pline_code in ('4001LG0')";
  135. }
  136. else if(type.equals("4")){
  137. conn += " and a.pline_code in ('4001LGX')";
  138. }
  139. else if(type.equals("5")){
  140. conn += " and a.pline_code in ('YT1')";
  141. }
  142. }
  143. if(prodline.equals("中板线")){
  144. conn += " and a.pline_code in ('ZB1') ";
  145. }else if(prodline.equals("厚板线")){
  146. conn += " and a.pline_code in ('HB1') ";
  147. }else if(prodline.equals("热连轧")){
  148. conn += " and a.pline_code in ('RZ1') ";
  149. }else if(prodline.equals("酸轧")){
  150. conn += " and a.pline_code in ('SZ1') ";
  151. }else if(prodline.equals("连退")){
  152. conn += " and a.pline_code in ('LT1') ";
  153. }else if(prodline.equals("高棒")){
  154. conn += " and a.pline_code in ('GX1','4001GX1') ";
  155. }else if(prodline.equals("棒二")){
  156. conn += " and a.pline_code in ('BC2','4001BC2') ";
  157. }else if(prodline.equals("高线")){
  158. conn += " and a.pline_code in ('GX2','4001GX2') ";
  159. }else if(prodline.equals("优特")){
  160. conn += " and a.pline_code in ('YT1') ";
  161. }
  162. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  163. if(StringUtils.isNotEmpty(judge_type)){
  164. if("1".equals(judge_type)) {
  165. conn += " and a.lock_type_code in ('C','P','D') ";
  166. } else if("2".equals(judge_type)) {
  167. conn += " and a.lock_type_code in ('S','F') ";
  168. }
  169. }
  170. conn += " and status in ('0','1','3') ";
  171. //conn += "order by lock_time desc";
  172. /*String sql = "select a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id,"
  173. + " a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  174. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  175. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  176. + " a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  177. + " where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID) or a.inspection_lot in (SELECT z.inspection_lot FROM qcm_judge_chemical Z WHERE Z.cic_id = A.LOCK_ID)) smp_type, "
  178. + " ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type from qcm_judge_locking a, qcm_judge_surface b where 1 = 1 and a.lock_id = b.surface_id(+) and "+conn+"";*/
  179. String sql = "select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status, a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  180. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  181. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  182. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  183. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  184. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  185. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,'' CUTSIDESTATE, (select name_ from scm_base_info@xgcx where id_ = RuLE) FIXSIZE,"
  186. +" c.ply thick,c.width,c.length,psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,c.THEORYWEIGHT weight,"
  187. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  188. +" from qcm_judge_locking a, qcm_judge_surface b,Kcx_Turnofflist@Xgcx c,sel_pactdetail@xgcx d"
  189. +" where 1 = 1"
  190. +" and a.lock_id = b.surface_id(+)"
  191. +" and a.material_no = c.billetid"
  192. +" and c.orderno = d.orderno(+) AND " +conn+"";
  193. System.out.print(sql);
  194. List<HashMap> listqjb = mapper.query(sql);
  195. cro.setResult(listqjb);
  196. } catch (Exception e) {
  197. cro.setV_errCode(-1);
  198. cro.setV_errMsg("查询失败!"+e.getMessage());
  199. logger.info(e.getMessage());
  200. }
  201. SqlSession.close();
  202. return cro;
  203. }
  204. /**
  205. * 异常材处置界面,查询待处置信息
  206. * @param sum
  207. * @return
  208. */
  209. @SuppressWarnings({ "rawtypes", "unchecked" })
  210. public CoreReturnObject getInformation2S(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String judge_type,String lock_type_desc) {
  211. String conn="unlock_type_code is null ";
  212. try {
  213. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  214. String sky=StrSky(begintime,endtime);
  215. if(!sky.equals("TRUE")){
  216. SqlSession.close();
  217. cro.setV_errCode(-1);
  218. cro.setV_errMsg(sky);
  219. return cro;
  220. }
  221. }
  222. if (!SqlJoint.IsNullOrSpace(design_key)) {
  223. conn+=" and a.design_key like '%"+design_key+"%'";
  224. }
  225. if (!SqlJoint.IsNullOrSpace(psc)) {
  226. conn+=" and psc_desc like '%"+psc+"%'";
  227. }
  228. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  229. conn+=" and to_date(to_char(lock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  230. }
  231. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  232. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  233. }
  234. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  235. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  236. }
  237. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  238. if(lock_type_desc.equals("成分判定")){
  239. conn += " and a.lock_type_code = 'C'";
  240. }else if(lock_type_desc.equals("材质判定")){
  241. conn += " and a.lock_type_code = 'P'";
  242. }else if(lock_type_desc.equals("表面检验")){
  243. conn += " and a.lock_type_code = 'F'";
  244. }else if(lock_type_desc.equals("公差检验")){
  245. conn += " and a.lock_type_code = 'S'";
  246. }else if(lock_type_desc.equals("工艺检验")){
  247. conn += " and a.lock_type_code = 'T'";
  248. }
  249. else
  250. {
  251. conn+= " and a.lock_type_code = 'D'";
  252. }
  253. }
  254. if(!SqlJoint.IsNullOrSpace(type)){
  255. //卷板
  256. if(type.equals("0")){
  257. conn += " and a.pline_code in ('LT1','SZ1','RZ1')";
  258. }
  259. //中厚板
  260. else if(type.equals("1")){
  261. conn += " and a.pline_code in ('ZB1','HB1')";
  262. }
  263. //线棒
  264. else if(type.equals("2")){
  265. conn += " and a.pline_code in ('GX1','BC1','BC2','GX2','4001GX1','4001GX2','4001BC2')";
  266. }
  267. else if(type.equals("3")){
  268. conn += " and a.pline_code in ('4001LG0')";
  269. }
  270. else if(type.equals("4")){
  271. conn += " and a.pline_code in ('4001LGX')";
  272. }
  273. else if(type.equals("5")){
  274. conn += " and a.pline_code in ('YT1')";
  275. }
  276. }
  277. if(prodline.equals("中板线")){
  278. conn += " and a.pline_code in ('ZB1') ";
  279. }else if(prodline.equals("厚板线")){
  280. conn += " and a.pline_code in ('HB1') ";
  281. }else if(prodline.equals("热连轧")){
  282. conn += " and a.pline_code in ('RZ1') ";
  283. }else if(prodline.equals("酸轧")){
  284. conn += " and a.pline_code in ('SZ1') ";
  285. }else if(prodline.equals("连退")){
  286. conn += " and a.pline_code in ('LT1') ";
  287. }else if(prodline.equals("高棒")){
  288. conn += " and a.pline_code in ('GX1','4001GX1') ";
  289. }else if(prodline.equals("棒二")){
  290. conn += " and a.pline_code in ('BC2','4001BC2') ";
  291. }else if(prodline.equals("高线")){
  292. conn += " and a.pline_code in ('GX2','4001GX2') ";
  293. }else if(prodline.equals("优特")){
  294. conn += " and a.pline_code in ('YT1') ";
  295. }
  296. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  297. if(StringUtils.isNotEmpty(judge_type)){
  298. if("1".equals(judge_type)) {
  299. conn += " and a.lock_type_code in ('C','P','D') ";
  300. } else if("2".equals(judge_type)) {
  301. conn += " and a.lock_type_code in ('S','F') ";
  302. }
  303. }
  304. conn += " and status in ('1') ";
  305. //conn += "order by lock_time desc";
  306. /*String sql = "select a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id,"
  307. + " a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  308. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  309. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  310. + " a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  311. + " where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID) or a.inspection_lot in (SELECT z.inspection_lot FROM qcm_judge_chemical Z WHERE Z.cic_id = A.LOCK_ID)) smp_type, "
  312. + " ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type from qcm_judge_locking a, qcm_judge_surface b where 1 = 1 and a.lock_id = b.surface_id(+) and "+conn+"";*/
  313. String sql = "select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status, a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  314. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  315. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  316. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  317. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  318. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  319. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,'' CUTSIDESTATE, (select name_ from scm_base_info@xgcx where id_ = RuLE) FIXSIZE,"
  320. +" c.ply thick,c.width,c.length,psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,c.THEORYWEIGHT weight,"
  321. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  322. +" from qcm_judge_locking a, qcm_judge_surface b,Kcx_Turnofflist@Xgcx c,sel_pactdetail@xgcx d"
  323. +" where 1 = 1"
  324. +" and a.lock_id = b.surface_id(+)"
  325. +" and a.material_no = c.billetid"
  326. +" and c.orderno = d.orderno(+) AND " +conn+"";
  327. System.out.print(sql);
  328. List<HashMap> listqjb = mapper.query(sql);
  329. cro.setResult(listqjb);
  330. } catch (Exception e) {
  331. cro.setV_errCode(-1);
  332. cro.setV_errMsg("查询失败!"+e.getMessage());
  333. logger.info(e.getMessage());
  334. }
  335. SqlSession.close();
  336. return cro;
  337. }
  338. /**
  339. * 异常材处置界面,查询待处置信息
  340. * @param sum
  341. * @return
  342. */
  343. @SuppressWarnings({ "rawtypes", "unchecked" })
  344. public CoreReturnObject getInformation(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String lock_type_desc) {
  345. String conn="unlock_type_code is null";
  346. try {
  347. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  348. String sky=StrSky(begintime,endtime);
  349. if(!sky.equals("TRUE")){
  350. SqlSession.close();
  351. cro.setV_errCode(-1);
  352. cro.setV_errMsg(sky);
  353. return cro;
  354. }
  355. }
  356. if (!SqlJoint.IsNullOrSpace(design_key)) {
  357. conn+=" and a.design_key like '%"+design_key+"%'";
  358. }
  359. if (!SqlJoint.IsNullOrSpace(psc)) {
  360. conn+=" and psc_desc like '%"+psc+"%'";
  361. }
  362. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  363. conn+=" and to_date(to_char(lock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  364. }
  365. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  366. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  367. }
  368. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  369. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  370. }
  371. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  372. if(lock_type_desc.equals("成分判定")){
  373. conn += " and a.lock_type_code = 'C'";
  374. }else if(lock_type_desc.equals("材质判定")){
  375. conn += " and a.lock_type_code = 'P'";
  376. }else if(lock_type_desc.equals("表面检验")){
  377. conn += " and a.lock_type_code = 'F'";
  378. }else if(lock_type_desc.equals("公差检验")){
  379. conn += " and a.lock_type_code = 'S'";
  380. }else if(lock_type_desc.equals("工艺检验")){
  381. conn += " and a.lock_type_code = 'T'";
  382. }
  383. else
  384. {
  385. conn+= " and a.lock_type_code = 'D'";
  386. }
  387. }
  388. if(!SqlJoint.IsNullOrSpace(type)){
  389. //卷板
  390. if(type.equals("0")){
  391. conn += " and a.pline_code in ('LT1','SZ1','RZ1')";
  392. }
  393. //中厚板
  394. else if(type.equals("1")){
  395. conn += " and a.pline_code in ('ZB1','HB1')";
  396. }
  397. //线棒
  398. else if(type.equals("2")){
  399. conn += " and a.pline_code in ('GX1','BC1','BC2','GX2','4001GX1','4001GX2','4001BC2')";
  400. }
  401. else if(type.equals("3")){
  402. conn += " and a.pline_code in ('4001LG0')";
  403. }
  404. else if(type.equals("4")){
  405. conn += " and a.pline_code in ('4001LGX')";
  406. }
  407. else if(type.equals("5")){
  408. conn += " and a.pline_code in ('YT1')";
  409. }
  410. }
  411. if(prodline.equals("中板线")){
  412. conn += " and a.pline_code in ('ZB1') ";
  413. }else if(prodline.equals("厚板线")){
  414. conn += " and a.pline_code in ('HB1') ";
  415. }else if(prodline.equals("热连轧")){
  416. conn += " and a.pline_code in ('RZ1') ";
  417. }else if(prodline.equals("酸轧")){
  418. conn += " and a.pline_code in ('SZ1') ";
  419. }else if(prodline.equals("连退")){
  420. conn += " and a.pline_code in ('LT1') ";
  421. }else if(prodline.equals("高棒")){
  422. conn += " and a.pline_code in ('GX1','4001GX1') ";
  423. }else if(prodline.equals("棒二")){
  424. conn += " and a.pline_code in ('BC2','4001BC2') ";
  425. }else if(prodline.equals("高线")){
  426. conn += " and a.pline_code in ('GX2','4001GX2') ";
  427. }else if(prodline.equals("优特")){
  428. conn += " and a.pline_code in ('YT1') ";
  429. }
  430. conn += " and status in ('0','1','3') ";
  431. //conn += "order by lock_time desc";
  432. String sql = "select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  433. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  434. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  435. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  436. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  437. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  438. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,'' CUTSIDESTATE, (select name_ from scm_base_info@xgcx where id_ = RuLE) FIXSIZE,"
  439. +" c.ply thick,c.width,c.length,psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,c.THEORYWEIGHT weight, "
  440. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  441. +" from qcm_judge_locking a, qcm_judge_surface b,Kcx_Turnofflist@Xgcx c,sel_pactdetail@xgcx d"
  442. +" where 1 = 1"
  443. +" and a.lock_id = b.surface_id(+)"
  444. +" and a.material_no = c.billetid"
  445. +" and c.orderno = d.orderno(+) AND " +conn+"";
  446. List<HashMap> listqjb = mapper.query(sql);
  447. cro.setResult(listqjb);
  448. } catch (Exception e) {
  449. cro.setV_errCode(-1);
  450. cro.setV_errMsg("查询失败!"+e.getMessage());
  451. logger.info(e.getMessage());
  452. }
  453. SqlSession.close();
  454. return cro;
  455. }
  456. /**
  457. * 异常材处置界面,查询待处置信息
  458. * @param sum
  459. * @return
  460. */
  461. @SuppressWarnings({ "rawtypes", "unchecked" })
  462. public CoreReturnObject getInformationS(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String lock_type_desc) {
  463. String conn="status = '0'";
  464. try {
  465. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  466. String sky=StrSky(begintime,endtime);
  467. if(!sky.equals("TRUE")){
  468. SqlSession.close();
  469. cro.setV_errCode(-1);
  470. cro.setV_errMsg(sky);
  471. return cro;
  472. }
  473. }
  474. if (!SqlJoint.IsNullOrSpace(design_key)) {
  475. conn+=" and a.design_key like '%"+design_key+"%'";
  476. }
  477. if (!SqlJoint.IsNullOrSpace(psc)) {
  478. conn+=" and psc_desc like '%"+psc+"%'";
  479. }
  480. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  481. conn+=" and to_date(to_char(create_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  482. }
  483. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  484. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  485. }
  486. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  487. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  488. }
  489. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  490. if(lock_type_desc.equals("成分判定")){
  491. conn += " and a.lock_type_code = 'C'";
  492. }else if(lock_type_desc.equals("材质判定")){
  493. conn += " and a.lock_type_code = 'P'";
  494. }else if(lock_type_desc.equals("表面检验")){
  495. conn += " and a.lock_type_code = 'F'";
  496. }else if(lock_type_desc.equals("公差检验")){
  497. conn += " and a.lock_type_code = 'S'";
  498. }else if(lock_type_desc.equals("工艺检验")){
  499. conn += " and a.lock_type_code = 'T'";
  500. }
  501. else
  502. {
  503. conn+= " and a.lock_type_code = 'D'";
  504. }
  505. }
  506. if(!SqlJoint.IsNullOrSpace(type)){
  507. //卷板
  508. if(type.equals("0")){
  509. conn += " and a.pline_code in ('LT1','SZ1','RZ1')";
  510. }
  511. //中厚板
  512. else if(type.equals("1")){
  513. conn += " and a.pline_code in ('ZB1','HB1')";
  514. }
  515. //线棒
  516. else if(type.equals("2")){
  517. conn += " and a.pline_code in ('GX1','BC1','BC2','GX2','4001GX1','4001GX2','4001BC2')";
  518. }
  519. else if(type.equals("3")){
  520. conn += " and a.pline_code in ('4001LG0')";
  521. }
  522. else if(type.equals("4")){
  523. conn += " and a.pline_code in ('4001LGX')";
  524. }
  525. else if(type.equals("5")){
  526. conn += " and a.pline_code in ('YT1')";
  527. }
  528. }
  529. if(prodline.equals("中板线")){
  530. conn += " and a.pline_code in ('ZB1') ";
  531. }else if(prodline.equals("厚板线")){
  532. conn += " and a.pline_code in ('HB1') ";
  533. }else if(prodline.equals("热连轧")){
  534. conn += " and a.pline_code in ('RZ1') ";
  535. }else if(prodline.equals("酸轧")){
  536. conn += " and a.pline_code in ('SZ1') ";
  537. }else if(prodline.equals("连退")){
  538. conn += " and a.pline_code in ('LT1') ";
  539. }else if(prodline.equals("高棒")){
  540. conn += " and a.pline_code in ('GX1','4001GX1') ";
  541. }else if(prodline.equals("棒二")){
  542. conn += " and a.pline_code in ('BC2','4001BC2') ";
  543. }else if(prodline.equals("高线")){
  544. conn += " and a.pline_code in ('GX2','4001GX2') ";
  545. }else if(prodline.equals("优特")){
  546. conn += " and a.pline_code in ('YT1') ";
  547. }
  548. //conn += "order by lock_time desc";
  549. String sql = "select apply_id,a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  550. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key,a.unlock_type_desc, "
  551. + " a.psc, a.pline_code, a.pline_name, a.create_name,a.unlock_memo, "
  552. + " a.create_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  553. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  554. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  555. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,'' CUTSIDESTATE, (select name_ from scm_base_info@xgcx where id_ = RuLE) FIXSIZE,"
  556. +" c.ply thick,c.width,c.length,psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,c.THEORYWEIGHT weight, "
  557. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  558. +" from qcm_judge_locking_apply a, qcm_judge_surface b,Kcx_Turnofflist@Xgcx c,sel_pactdetail@xgcx d"
  559. +" where 1 = 1"
  560. +" and a.lock_id = b.surface_id(+)"
  561. +" and a.material_no = c.billetid"
  562. +" and c.orderno = d.orderno(+) AND " +conn+"";
  563. List<HashMap> listqjb = mapper.query(sql);
  564. cro.setResult(listqjb);
  565. } catch (Exception e) {
  566. cro.setV_errCode(-1);
  567. cro.setV_errMsg("查询失败!"+e.getMessage());
  568. logger.info(e.getMessage());
  569. }
  570. SqlSession.close();
  571. return cro;
  572. }
  573. /**
  574. * 异常材处置界面,查询待处置信息
  575. * @param sum
  576. * @return
  577. */
  578. @SuppressWarnings({ "rawtypes", "unchecked" })
  579. public CoreReturnObject getInformation2J(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String judge_type,String lock_type_desc) {
  580. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  581. String sky=StrSky(begintime,endtime);
  582. if(!sky.equals("TRUE")){
  583. SqlSession.close();
  584. cro.setV_errCode(-1);
  585. cro.setV_errMsg(sky);
  586. return cro;
  587. }
  588. }
  589. String conn="unlock_type_code is null ";
  590. String swhere = "";
  591. try {
  592. if (!SqlJoint.IsNullOrSpace(design_key)) {
  593. conn+=" and a.design_key like '%"+design_key+"%'";
  594. }
  595. if (!SqlJoint.IsNullOrSpace(psc)) {
  596. conn+=" and psc_desc like '%"+psc+"%'";
  597. }
  598. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  599. conn+=" and to_date(to_char(lock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  600. }
  601. if(type.equals("5")){
  602. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  603. conn += " and a.material_no like '%"+sbatchno+"%'";
  604. }
  605. if(!SqlJoint.IsNullOrSpace(ebatchno)){
  606. if(ebatchno.equals("4mm分条机组")){
  607. swhere += " and MACHINE_CODE = 'M0001'";
  608. }else if(ebatchno.equals("12mm分条机组")){
  609. swhere += " and MACHINE_CODE = 'M0002'";
  610. }else if(ebatchno.equals("3mm横剪机组")){
  611. swhere += " and MACHINE_CODE = 'M0003'";
  612. }else if(ebatchno.equals("退火炉宝信")){
  613. swhere += " and MACHINE_CODE = 'M0004'";
  614. }else if(ebatchno.equals("退火炉南方D")){
  615. swhere += " and MACHINE_CODE = 'M0005'";
  616. }else if(ebatchno.equals("退火炉艾伯纳")){
  617. swhere += " and MACHINE_CODE = 'M0006'";
  618. }else if(ebatchno.equals("平整机组")){
  619. swhere += " and MACHINE_CODE = 'M0007'";
  620. }else if(ebatchno.equals("轧机机组")){
  621. swhere += " and MACHINE_CODE = 'M0008'";
  622. }else if(ebatchno.equals("退火炉南方G")){
  623. swhere += " and MACHINE_CODE = 'M0009'";
  624. }else if(ebatchno.equals("酸洗机组")){
  625. swhere += " and MACHINE_CODE = 'M0010'";
  626. }
  627. }
  628. }else{
  629. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  630. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  631. }
  632. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  633. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  634. }
  635. }
  636. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  637. if(lock_type_desc.equals("成分判定")){
  638. conn += " and a.lock_type_code = 'C'";
  639. }else if(lock_type_desc.equals("材质判定")){
  640. conn += " and a.lock_type_code = 'P'";
  641. }else if(lock_type_desc.equals("表面检验")){
  642. conn += " and a.lock_type_code = 'F'";
  643. }else if(lock_type_desc.equals("公差检验")){
  644. conn += " and a.lock_type_code = 'S'";
  645. }else if(lock_type_desc.equals("工艺检验")){
  646. conn += " and a.lock_type_code = 'T'";
  647. }
  648. else
  649. {
  650. conn+= " and a.lock_type_code = 'D'";
  651. }
  652. }
  653. if(!SqlJoint.IsNullOrSpace(type)){
  654. //卷板
  655. if(type.equals("0")){
  656. conn += " and a.pline_code in ('LT1','SZ1','RZ1')";
  657. }
  658. //中厚板
  659. else if(type.equals("1")){
  660. conn += " and a.pline_code in ('ZB1','HB1')";
  661. }
  662. //线棒
  663. else if(type.equals("2")){
  664. conn += " and a.pline_code in ('GX1','BC1','BC2','GX2','4001GX1','4001GX2','4001BC2')";
  665. }
  666. else if(type.equals("3")){
  667. conn += " and a.pline_code in ('4001LG0')";
  668. }
  669. else if(type.equals("4")){
  670. conn += " and a.pline_code in ('4001LGX')";
  671. }
  672. else if(type.equals("5")){
  673. conn += " and a.pline_code in ('YT1')";
  674. }
  675. }
  676. if(prodline.equals("中板线")){
  677. conn += " and a.pline_code in ('ZB1') ";
  678. }else if(prodline.equals("厚板线")){
  679. conn += " and a.pline_code in ('HB1') ";
  680. }else if(prodline.equals("热连轧")){
  681. conn += " and a.pline_code in ('RZ1') ";
  682. }else if(prodline.equals("酸轧")){
  683. conn += " and a.pline_code in ('SZ1') ";
  684. }else if(prodline.equals("连退")){
  685. conn += " and a.pline_code in ('LT1') ";
  686. }else if(prodline.equals("高棒")){
  687. conn += " and a.pline_code in ('GX1','4001GX1') ";
  688. }else if(prodline.equals("棒二")){
  689. conn += " and a.pline_code in ('BC2','4001BC2') ";
  690. }else if(prodline.equals("高线")){
  691. conn += " and a.pline_code in ('GX2','4001GX2') ";
  692. }else if(prodline.equals("优特")){
  693. conn += " and a.pline_code in ('YT1') ";
  694. }
  695. conn += " and status in ('0','1','3') ";
  696. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  697. if(StringUtils.isNotEmpty(judge_type)){
  698. if("1".equals(judge_type)) {
  699. conn += " and a.lock_type_code in ('C','P','D') ";
  700. } else if("2".equals(judge_type)) {
  701. conn += " and a.lock_type_code in ('S','F') ";
  702. }
  703. }
  704. //conn += "order by lock_time desc";
  705. /*String sql = "select a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id,"
  706. + " a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  707. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  708. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  709. + " a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  710. + " where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID) or a.inspection_lot in (SELECT z.inspection_lot FROM qcm_judge_chemical Z WHERE Z.cic_id = A.LOCK_ID)) smp_type, "
  711. + " ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type from qcm_judge_locking a, qcm_judge_surface b where 1 = 1 and a.lock_id = b.surface_id(+) and "+conn+"";*/
  712. String sql = "select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  713. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  714. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  715. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  716. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  717. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  718. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,'','',"
  719. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight, "
  720. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX"
  721. +" from qcm_judge_locking a, qcm_judge_surface b,tbh02_coil_comm c"
  722. +" where 1 = 1"
  723. +" and a.lock_id = b.surface_id(+)"
  724. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  725. +" union all"
  726. +" select a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  727. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  728. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  729. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  730. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  731. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  732. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,'','',"
  733. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  734. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  735. +" from qcm_judge_locking a, qcm_judge_surface b,c_tbl02_coil_comm c"
  736. +" where 1 = 1"
  737. +" and a.lock_id = b.surface_id(+)"
  738. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  739. +" union all"
  740. +" select a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  741. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  742. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  743. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  744. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  745. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  746. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,'','',"
  747. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  748. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select b.psc from qcm_ord_design_std_cic b where b.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  749. +" from qcm_judge_locking a, qcm_judge_surface b,c_tbc02_coil_comm c"
  750. +" where 1 = 1"
  751. +" and a.lock_id = b.surface_id(+)"
  752. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+"";
  753. System.out.print(sql);
  754. List<HashMap> listqjb = mapper.query(sql);
  755. cro.setResult(listqjb);
  756. } catch (Exception e) {
  757. cro.setV_errCode(-1);
  758. cro.setV_errMsg("查询失败!"+e.getMessage());
  759. logger.info(e.getMessage());
  760. }
  761. SqlSession.close();
  762. return cro;
  763. }
  764. /**
  765. * 异常材处置界面,查询待处置信息
  766. * @param sum
  767. * @return
  768. */
  769. @SuppressWarnings({ "rawtypes", "unchecked" })
  770. public CoreReturnObject getInformation2JS(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String judge_type,String lock_type_desc) {
  771. String conn="unlock_type_code is null ";
  772. String swhere = "";
  773. try {
  774. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  775. String sky=StrSky(begintime,endtime);
  776. if(!sky.equals("TRUE")){
  777. SqlSession.close();
  778. cro.setV_errCode(-1);
  779. cro.setV_errMsg(sky);
  780. return cro;
  781. }
  782. }
  783. if (!SqlJoint.IsNullOrSpace(design_key)) {
  784. conn+=" and a.design_key like '%"+design_key+"%'";
  785. }
  786. if (!SqlJoint.IsNullOrSpace(psc)) {
  787. conn+=" and psc_desc like '%"+psc+"%'";
  788. }
  789. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  790. conn+=" and to_date(to_char(lock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  791. }
  792. if(type.equals("5")){
  793. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  794. conn += " and a.material_no like '%"+sbatchno+"%'";
  795. }
  796. if(!SqlJoint.IsNullOrSpace(ebatchno)){
  797. if(ebatchno.equals("4mm分条机组")){
  798. swhere += " and MACHINE_CODE = 'M0001'";
  799. }else if(ebatchno.equals("12mm分条机组")){
  800. swhere += " and MACHINE_CODE = 'M0002'";
  801. }else if(ebatchno.equals("3mm横剪机组")){
  802. swhere += " and MACHINE_CODE = 'M0003'";
  803. }else if(ebatchno.equals("退火炉宝信")){
  804. swhere += " and MACHINE_CODE = 'M0004'";
  805. }else if(ebatchno.equals("退火炉南方D")){
  806. swhere += " and MACHINE_CODE = 'M0005'";
  807. }else if(ebatchno.equals("退火炉艾伯纳")){
  808. swhere += " and MACHINE_CODE = 'M0006'";
  809. }else if(ebatchno.equals("平整机组")){
  810. swhere += " and MACHINE_CODE = 'M0007'";
  811. }else if(ebatchno.equals("轧机机组")){
  812. swhere += " and MACHINE_CODE = 'M0008'";
  813. }else if(ebatchno.equals("退火炉南方G")){
  814. swhere += " and MACHINE_CODE = 'M0009'";
  815. }else if(ebatchno.equals("酸洗机组")){
  816. swhere += " and MACHINE_CODE = 'M0010'";
  817. }
  818. }
  819. }else{
  820. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  821. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  822. }
  823. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  824. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  825. }
  826. }
  827. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  828. if(lock_type_desc.equals("成分判定")){
  829. conn += " and a.lock_type_code = 'C'";
  830. }else if(lock_type_desc.equals("材质判定")){
  831. conn += " and a.lock_type_code = 'P'";
  832. }else if(lock_type_desc.equals("表面检验")){
  833. conn += " and a.lock_type_code = 'F'";
  834. }else if(lock_type_desc.equals("公差检验")){
  835. conn += " and a.lock_type_code = 'S'";
  836. }else if(lock_type_desc.equals("工艺检验")){
  837. conn += " and a.lock_type_code = 'T'";
  838. }
  839. else
  840. {
  841. conn+= " and a.lock_type_code = 'D'";
  842. }
  843. }
  844. if(!SqlJoint.IsNullOrSpace(type)){
  845. //卷板
  846. if(type.equals("0")){
  847. conn += " and a.pline_code in ('LT1','SZ1','RZ1')";
  848. }
  849. //中厚板
  850. else if(type.equals("1")){
  851. conn += " and a.pline_code in ('ZB1','HB1')";
  852. }
  853. //线棒
  854. else if(type.equals("2")){
  855. conn += " and a.pline_code in ('GX1','BC1','BC2','GX2','4001GX1','4001GX2','4001BC2')";
  856. }
  857. else if(type.equals("3")){
  858. conn += " and a.pline_code in ('4001LG0')";
  859. }
  860. else if(type.equals("4")){
  861. conn += " and a.pline_code in ('4001LGX')";
  862. }
  863. else if(type.equals("5")){
  864. conn += " and a.pline_code in ('YT1')";
  865. }
  866. }
  867. if(prodline.equals("中板线")){
  868. conn += " and a.pline_code in ('ZB1') ";
  869. }else if(prodline.equals("厚板线")){
  870. conn += " and a.pline_code in ('HB1') ";
  871. }else if(prodline.equals("热连轧")){
  872. conn += " and a.pline_code in ('RZ1') ";
  873. }else if(prodline.equals("酸轧")){
  874. conn += " and a.pline_code in ('SZ1') ";
  875. }else if(prodline.equals("连退")){
  876. conn += " and a.pline_code in ('LT1') ";
  877. }else if(prodline.equals("高棒")){
  878. conn += " and a.pline_code in ('GX1','4001GX1') ";
  879. }else if(prodline.equals("棒二")){
  880. conn += " and a.pline_code in ('BC2','4001BC2') ";
  881. }else if(prodline.equals("高线")){
  882. conn += " and a.pline_code in ('GX2','4001GX2') ";
  883. }else if(prodline.equals("优特")){
  884. conn += " and a.pline_code in ('YT1') ";
  885. }
  886. conn += " and status in ('1') ";
  887. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  888. if(StringUtils.isNotEmpty(judge_type)){
  889. if("1".equals(judge_type)) {
  890. conn += " and a.lock_type_code in ('C','P','D') ";
  891. } else if("2".equals(judge_type)) {
  892. conn += " and a.lock_type_code in ('S','F') ";
  893. }
  894. }
  895. //conn += "order by lock_time desc";
  896. /*String sql = "select a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id,"
  897. + " a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  898. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  899. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  900. + " a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  901. + " where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID) or a.inspection_lot in (SELECT z.inspection_lot FROM qcm_judge_chemical Z WHERE Z.cic_id = A.LOCK_ID)) smp_type, "
  902. + " ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type from qcm_judge_locking a, qcm_judge_surface b where 1 = 1 and a.lock_id = b.surface_id(+) and "+conn+"";*/
  903. String sql = "select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  904. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  905. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  906. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  907. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  908. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  909. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,'','',"
  910. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight, "
  911. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX"
  912. +" from qcm_judge_locking a, qcm_judge_surface b,tbh02_coil_comm c"
  913. +" where 1 = 1"
  914. +" and a.lock_id = b.surface_id(+)"
  915. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  916. +" union all"
  917. +" select a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  918. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  919. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  920. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  921. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  922. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  923. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,'','',"
  924. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  925. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  926. +" from qcm_judge_locking a, qcm_judge_surface b,c_tbl02_coil_comm c"
  927. +" where 1 = 1"
  928. +" and a.lock_id = b.surface_id(+)"
  929. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  930. +" union all"
  931. +" select a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  932. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  933. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  934. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  935. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  936. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  937. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,'','',"
  938. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  939. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select b.psc from qcm_ord_design_std_cic b where b.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  940. +" from qcm_judge_locking a, qcm_judge_surface b,c_tbc02_coil_comm c"
  941. +" where 1 = 1"
  942. +" and a.lock_id = b.surface_id(+)"
  943. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+"";
  944. System.out.print(sql);
  945. List<HashMap> listqjb = mapper.query(sql);
  946. cro.setResult(listqjb);
  947. } catch (Exception e) {
  948. cro.setV_errCode(-1);
  949. cro.setV_errMsg("查询失败!"+e.getMessage());
  950. logger.info(e.getMessage());
  951. }
  952. SqlSession.close();
  953. return cro;
  954. }
  955. /**
  956. * 异常材处置界面,查询待处置信息
  957. * @param sum
  958. * @return
  959. */
  960. @SuppressWarnings({ "rawtypes", "unchecked" })
  961. public CoreReturnObject getInformationJ(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String lock_type_desc) {
  962. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  963. String sky=StrSky(begintime,endtime);
  964. if(!sky.equals("TRUE")){
  965. SqlSession.close();
  966. cro.setV_errCode(-1);
  967. cro.setV_errMsg(sky);
  968. return cro;
  969. }
  970. }
  971. String conn="unlock_type_code is null";
  972. String swhere = "";
  973. try {
  974. if (!SqlJoint.IsNullOrSpace(design_key)) {
  975. conn+=" and a.design_key like '%"+design_key+"%'";
  976. }
  977. if (!SqlJoint.IsNullOrSpace(psc)) {
  978. conn+=" and psc_desc like '%"+psc+"%'";
  979. }
  980. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  981. conn+=" and to_date(to_char(lock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  982. }
  983. if(type.equals("5")){
  984. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  985. conn += " and a.material_no like '%"+sbatchno+"%'";
  986. }
  987. if(!SqlJoint.IsNullOrSpace(ebatchno)){
  988. if(ebatchno.equals("4mm分条机组")){
  989. swhere += " and MACHINE_CODE = 'M0001'";
  990. }else if(ebatchno.equals("12mm分条机组")){
  991. swhere += " and MACHINE_CODE = 'M0002'";
  992. }else if(ebatchno.equals("3mm横剪机组")){
  993. swhere += " and MACHINE_CODE = 'M0003'";
  994. }else if(ebatchno.equals("退火炉宝信")){
  995. swhere += " and MACHINE_CODE = 'M0004'";
  996. }else if(ebatchno.equals("退火炉南方D")){
  997. swhere += " and MACHINE_CODE = 'M0005'";
  998. }else if(ebatchno.equals("退火炉艾伯纳")){
  999. swhere += " and MACHINE_CODE = 'M0006'";
  1000. }else if(ebatchno.equals("平整机组")){
  1001. swhere += " and MACHINE_CODE = 'M0007'";
  1002. }else if(ebatchno.equals("轧机机组")){
  1003. swhere += " and MACHINE_CODE = 'M0008'";
  1004. }else if(ebatchno.equals("退火炉南方G")){
  1005. swhere += " and MACHINE_CODE = 'M0009'";
  1006. }else if(ebatchno.equals("酸洗机组")){
  1007. swhere += " and MACHINE_CODE = 'M0010'";
  1008. }
  1009. }
  1010. }else{
  1011. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  1012. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  1013. }
  1014. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  1015. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  1016. }
  1017. }
  1018. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  1019. if(lock_type_desc.equals("成分判定")){
  1020. conn += " and a.lock_type_code = 'C'";
  1021. }else if(lock_type_desc.equals("材质判定")){
  1022. conn += " and a.lock_type_code = 'P'";
  1023. }else if(lock_type_desc.equals("表面检验")){
  1024. conn += " and a.lock_type_code = 'F'";
  1025. }else if(lock_type_desc.equals("公差检验")){
  1026. conn += " and a.lock_type_code = 'S'";
  1027. }else if(lock_type_desc.equals("工艺检验")){
  1028. conn += " and a.lock_type_code = 'T'";
  1029. }
  1030. else
  1031. {
  1032. conn+= " and a.lock_type_code = 'D'";
  1033. }
  1034. }
  1035. if(!SqlJoint.IsNullOrSpace(type)){
  1036. //卷板
  1037. if(type.equals("0")){
  1038. conn += " and a.pline_code in ('LT1','SZ1','RZ1')";
  1039. }
  1040. //中厚板
  1041. else if(type.equals("1")){
  1042. conn += " and a.pline_code in ('ZB1','HB1')";
  1043. }
  1044. //线棒
  1045. else if(type.equals("2")){
  1046. conn += " and a.pline_code in ('GX1','BC1','BC2','GX2','4001GX1','4001GX2','4001BC2')";
  1047. }
  1048. else if(type.equals("3")){
  1049. conn += " and a.pline_code in ('4001LG0')";
  1050. }
  1051. else if(type.equals("4")){
  1052. conn += " and a.pline_code in ('4001LGX')";
  1053. }
  1054. else if(type.equals("5")){
  1055. conn += " and a.pline_code in ('YT1')";
  1056. }
  1057. }
  1058. if(prodline.equals("中板线")){
  1059. conn += " and a.pline_code in ('ZB1') ";
  1060. }else if(prodline.equals("厚板线")){
  1061. conn += " and a.pline_code in ('HB1') ";
  1062. }else if(prodline.equals("热连轧")){
  1063. conn += " and a.pline_code in ('RZ1') ";
  1064. }else if(prodline.equals("酸轧")){
  1065. conn += " and a.pline_code in ('SZ1') ";
  1066. }else if(prodline.equals("连退")){
  1067. conn += " and a.pline_code in ('LT1') ";
  1068. }else if(prodline.equals("高棒")){
  1069. conn += " and a.pline_code in ('GX1','4001GX1') ";
  1070. }else if(prodline.equals("棒二")){
  1071. conn += " and a.pline_code in ('BC2','4001BC2') ";
  1072. }else if(prodline.equals("高线")){
  1073. conn += " and a.pline_code in ('GX2','4001GX2') ";
  1074. }else if(prodline.equals("优特")){
  1075. conn += " and a.pline_code in ('YT1') ";
  1076. }
  1077. conn += " and status in ('0','1','3') ";
  1078. //conn += "order by lock_time desc";
  1079. String sql ="";//241216 增加IF分优特代码
  1080. if(!type.equals("5")){
  1081. sql = "select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  1082. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  1083. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  1084. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  1085. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  1086. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  1087. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,''CUTSIDESTATE,''FIXSIZE,"
  1088. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  1089. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  1090. +" from qcm_judge_locking a, qcm_judge_surface b,tbh02_coil_comm c"
  1091. +" where 1 = 1"
  1092. +" and a.lock_id = b.surface_id(+)"
  1093. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  1094. +" union all"
  1095. +" select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  1096. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  1097. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  1098. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  1099. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  1100. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  1101. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,''CUTSIDESTATE,'' FIXSIZE,"
  1102. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  1103. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  1104. +" from qcm_judge_locking a, qcm_judge_surface b,c_tbl02_coil_comm c"
  1105. +" where 1 = 1"
  1106. +" and a.lock_id = b.surface_id(+)"
  1107. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  1108. +" union all"
  1109. +" select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  1110. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  1111. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  1112. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  1113. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  1114. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  1115. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,''CUTSIDESTATE,''FIXSIZE,"
  1116. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  1117. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select b.psc from qcm_ord_design_std_cic b where b.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  1118. +" from qcm_judge_locking a, qcm_judge_surface b,c_tbc02_coil_comm c"
  1119. +" where 1 = 1"
  1120. +" and a.lock_id = b.surface_id(+)"
  1121. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+"";
  1122. // +" union all"
  1123. }else{
  1124. sql = " select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  1125. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  1126. + " a.psc, a.pline_code, a.pline_name, a.lock_name,a.unlock_memo, "
  1127. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  1128. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  1129. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  1130. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,'','',"
  1131. +" c.thick,c.width,c.length,c.DELIVERY_STATE_DESC,c.FACTWEIGHT/1000 weight,"
  1132. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select b.psc from qcm_ord_design_std_cic b where b.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  1133. +" from qcm_judge_locking a, qcm_judge_surface b,YDM_PRODUCT_DETAIL@LINK_YTG c"
  1134. +" where 1 = 1"
  1135. +" and a.lock_id = b.surface_id(+)"
  1136. +" and a.material_no = c.COILNO AND " +conn+swhere+"";
  1137. }
  1138. //System.out.println(sql);
  1139. List<HashMap> listqjb = mapper.query(sql);
  1140. cro.setResult(listqjb);
  1141. } catch (Exception e) {
  1142. cro.setV_errCode(-1);
  1143. cro.setV_errMsg("查询失败!"+e.getMessage());
  1144. logger.info(e.getMessage());
  1145. }
  1146. SqlSession.close();
  1147. return cro;
  1148. }
  1149. /**
  1150. * 异常材处置界面,查询待处置信息
  1151. * @param sum
  1152. * @return
  1153. */
  1154. @SuppressWarnings({ "rawtypes", "unchecked" })
  1155. public CoreReturnObject getInformationJS(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String lock_type_desc) {
  1156. String conn="status = '0' and a.VALID_FLAG = '1' ";
  1157. String swhere = "";
  1158. try {
  1159. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  1160. String sky=StrSky(begintime,endtime);
  1161. if(!sky.equals("TRUE")){
  1162. SqlSession.close();
  1163. cro.setV_errCode(-1);
  1164. cro.setV_errMsg(sky);
  1165. return cro;
  1166. }
  1167. }
  1168. if (!SqlJoint.IsNullOrSpace(design_key)) {
  1169. conn+=" and a.design_key like '%"+design_key+"%'";
  1170. }
  1171. if (!SqlJoint.IsNullOrSpace(psc)) {
  1172. conn+=" and psc_desc like '%"+psc+"%'";
  1173. }
  1174. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  1175. conn+=" and to_date(to_char(create_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  1176. }
  1177. if(type.equals("5")){
  1178. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  1179. conn += " and a.material_no like '%"+sbatchno+"%'";
  1180. }
  1181. if(!SqlJoint.IsNullOrSpace(ebatchno)){
  1182. if(ebatchno.equals("4mm分条机组")){
  1183. swhere += " and MACHINE_CODE = 'M0001'";
  1184. }else if(ebatchno.equals("12mm分条机组")){
  1185. swhere += " and MACHINE_CODE = 'M0002'";
  1186. }else if(ebatchno.equals("3mm横剪机组")){
  1187. swhere += " and MACHINE_CODE = 'M0003'";
  1188. }else if(ebatchno.equals("退火炉宝信")){
  1189. swhere += " and MACHINE_CODE = 'M0004'";
  1190. }else if(ebatchno.equals("退火炉南方D")){
  1191. swhere += " and MACHINE_CODE = 'M0005'";
  1192. }else if(ebatchno.equals("退火炉艾伯纳")){
  1193. swhere += " and MACHINE_CODE = 'M0006'";
  1194. }else if(ebatchno.equals("平整机组")){
  1195. swhere += " and MACHINE_CODE = 'M0007'";
  1196. }else if(ebatchno.equals("轧机机组")){
  1197. swhere += " and MACHINE_CODE = 'M0008'";
  1198. }else if(ebatchno.equals("退火炉南方G")){
  1199. swhere += " and MACHINE_CODE = 'M0009'";
  1200. }else if(ebatchno.equals("酸洗机组")){
  1201. swhere += " and MACHINE_CODE = 'M0010'";
  1202. }
  1203. }
  1204. }else{
  1205. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  1206. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  1207. }
  1208. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  1209. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  1210. }
  1211. }
  1212. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  1213. if(lock_type_desc.equals("成分判定")){
  1214. conn += " and a.lock_type_code = 'C'";
  1215. }else if(lock_type_desc.equals("材质判定")){
  1216. conn += " and a.lock_type_code = 'P'";
  1217. }else if(lock_type_desc.equals("表面检验")){
  1218. conn += " and a.lock_type_code = 'F'";
  1219. }else if(lock_type_desc.equals("公差检验")){
  1220. conn += " and a.lock_type_code = 'S'";
  1221. }else if(lock_type_desc.equals("工艺检验")){
  1222. conn += " and a.lock_type_code = 'T'";
  1223. }
  1224. else
  1225. {
  1226. conn+= " and a.lock_type_code = 'D'";
  1227. }
  1228. }
  1229. if(!SqlJoint.IsNullOrSpace(type)){
  1230. //卷板
  1231. if(type.equals("0")){
  1232. conn += " and a.pline_code in ('LT1','SZ1','RZ1')";
  1233. }
  1234. //中厚板
  1235. else if(type.equals("1")){
  1236. conn += " and a.pline_code in ('ZB1','HB1')";
  1237. }
  1238. //线棒
  1239. else if(type.equals("2")){
  1240. conn += " and a.pline_code in ('GX1','BC1','BC2','GX2','4001GX1','4001GX2','4001BC2')";
  1241. }
  1242. else if(type.equals("3")){
  1243. conn += " and a.pline_code in ('4001LG0')";
  1244. }
  1245. else if(type.equals("4")){
  1246. conn += " and a.pline_code in ('4001LGX')";
  1247. }
  1248. else if(type.equals("5")){
  1249. conn += " and a.pline_code in ('YT1')";
  1250. }
  1251. }
  1252. if(prodline.equals("中板线")){
  1253. conn += " and a.pline_code in ('ZB1') ";
  1254. }else if(prodline.equals("厚板线")){
  1255. conn += " and a.pline_code in ('HB1') ";
  1256. }else if(prodline.equals("热连轧")){
  1257. conn += " and a.pline_code in ('RZ1') ";
  1258. }else if(prodline.equals("酸轧")){
  1259. conn += " and a.pline_code in ('SZ1') ";
  1260. }else if(prodline.equals("连退")){
  1261. conn += " and a.pline_code in ('LT1') ";
  1262. }else if(prodline.equals("高棒")){
  1263. conn += " and a.pline_code in ('GX1','4001GX1') ";
  1264. }else if(prodline.equals("棒二")){
  1265. conn += " and a.pline_code in ('BC2','4001BC2') ";
  1266. }else if(prodline.equals("高线")){
  1267. conn += " and a.pline_code in ('GX2','4001GX2') ";
  1268. }else if(prodline.equals("优特")){
  1269. conn += " and a.pline_code in ('YT1') ";
  1270. }
  1271. //conn += "order by lock_time desc";
  1272. String sql="";
  1273. if(!type.equals("5")){//241216 分优特
  1274. sql = "select apply_id,a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  1275. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key,a.unlock_type_desc, "
  1276. + " a.psc, a.pline_code, a.pline_name, a.create_name,a.unlock_memo, "
  1277. + " a.create_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  1278. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  1279. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  1280. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,''CUTSIDESTATE,''FIXSIZE,"
  1281. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  1282. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  1283. +" from qcm_judge_locking_apply a, qcm_judge_surface b,tbh02_coil_comm c"
  1284. +" where 1 = 1"
  1285. +" and a.lock_id = b.surface_id(+)"
  1286. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  1287. +" union all"
  1288. +" select apply_id,a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  1289. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key,a.unlock_type_desc, "
  1290. + " a.psc, a.pline_code, a.pline_name, a.create_name,a.unlock_memo, "
  1291. + " a.create_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  1292. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  1293. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  1294. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,''CUTSIDESTATE,'' FIXSIZE,"
  1295. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  1296. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  1297. +" from qcm_judge_locking_apply a, qcm_judge_surface b,c_tbl02_coil_comm c"
  1298. +" where 1 = 1"
  1299. +" and a.lock_id = b.surface_id(+)"
  1300. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  1301. +" union all"
  1302. +" select apply_id,a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  1303. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key,a.unlock_type_desc, "
  1304. + " a.psc, a.pline_code, a.pline_name, a.create_name,a.unlock_memo, "
  1305. + " a.create_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  1306. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  1307. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  1308. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,''CUTSIDESTATE,''FIXSIZE,"
  1309. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  1310. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select b.psc from qcm_ord_design_std_cic b where b.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  1311. +" from qcm_judge_locking_apply a, qcm_judge_surface b,c_tbc02_coil_comm c"
  1312. +" where 1 = 1"
  1313. +" and a.lock_id = b.surface_id(+)"
  1314. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+"";
  1315. // +" union all"
  1316. }else{
  1317. sql=" select apply_id,a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id, "
  1318. +" a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key,a.unlock_type_desc, "
  1319. + " a.psc, a.pline_code, a.pline_name, a.create_name,a.unlock_memo, "
  1320. + " a.create_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  1321. +" a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  1322. +" where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  1323. +" ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name ,decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,'','',"
  1324. +" c.thick,c.width,c.length,c.DELIVERY_STATE_DESC,c.FACTWEIGHT/1000 weight,"
  1325. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select b.psc from qcm_ord_design_std_cic b where b.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  1326. +" from qcm_judge_locking_apply a, qcm_judge_surface b,YDM_PRODUCT_DETAIL@LINK_YTG c"
  1327. +" where 1 = 1"
  1328. +" and a.lock_id = b.surface_id(+)"
  1329. +" and a.material_no = c.COILNO AND " +conn+swhere+"";
  1330. }
  1331. List<HashMap> listqjb = mapper.query(sql);
  1332. cro.setResult(listqjb);
  1333. } catch (Exception e) {
  1334. cro.setV_errCode(-1);
  1335. cro.setV_errMsg("查询失败!"+e.getMessage());
  1336. logger.info(e.getMessage());
  1337. }
  1338. SqlSession.close();
  1339. return cro;
  1340. }
  1341. /**
  1342. * 中厚板异常材处置界面,查询待处置信息
  1343. * @param sum
  1344. * @return
  1345. */
  1346. @SuppressWarnings({ "rawtypes", "unchecked" })
  1347. public CoreReturnObject getInformation2H(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String judge_type,String lock_type_desc,String heat_no,String type1) {
  1348. String conn="unlock_type_code is null ";
  1349. try {
  1350. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  1351. String sky=StrSky(begintime,endtime);
  1352. if(!sky.equals("TRUE")){
  1353. SqlSession.close();
  1354. cro.setV_errCode(-1);
  1355. cro.setV_errMsg(sky);
  1356. return cro;
  1357. }
  1358. }
  1359. if (!SqlJoint.IsNullOrSpace(design_key)) {
  1360. conn+=" and a.design_key like '%"+design_key+"%'";
  1361. }
  1362. if(type1.equals("1")){
  1363. conn+=" and a.design_key not like '19%'";
  1364. }else{
  1365. conn+=" and a.design_key like '19%'";
  1366. }
  1367. if (!SqlJoint.IsNullOrSpace(psc)) {
  1368. conn+=" and psc_desc like '%"+psc+"%'";
  1369. }
  1370. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  1371. conn+=" and to_date(to_char(lock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  1372. }
  1373. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  1374. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  1375. }
  1376. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  1377. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  1378. }
  1379. if(!SqlJoint.IsNullOrSpace(heat_no)){
  1380. conn += " and a.heat_no like '%"+heat_no+"%'";
  1381. }
  1382. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  1383. if(lock_type_desc.equals("成分判定")){
  1384. conn += " and a.lock_type_code = 'C'";
  1385. }else if(lock_type_desc.equals("材质判定")){
  1386. conn += " and a.lock_type_code = 'P'";
  1387. }else if(lock_type_desc.equals("表面检验")){
  1388. conn += " and a.lock_type_code = 'F'";
  1389. }else if(lock_type_desc.equals("公差检验")){
  1390. conn += " and a.lock_type_code = 'S'";
  1391. }else
  1392. {
  1393. conn+= " and a.lock_type_code = 'D'";
  1394. }
  1395. }
  1396. if(!SqlJoint.IsNullOrSpace(type)){
  1397. //中厚板
  1398. if(type.equals("1")){
  1399. conn += " and a.pline_code in ('ZB1','HB1')";
  1400. }
  1401. }
  1402. if(prodline.equals("中板线")){
  1403. conn += " and a.pline_code in ('ZB1') ";
  1404. }else if(prodline.equals("厚板线")){
  1405. conn += " and a.pline_code in ('HB1') ";
  1406. }
  1407. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  1408. if(StringUtils.isNotEmpty(judge_type)){
  1409. if("1".equals(judge_type)) {
  1410. conn += " and a.lock_type_code in ('C','P','D') ";
  1411. } else if("2".equals(judge_type)) {
  1412. conn += " and a.lock_type_code in ('S','F') ";
  1413. }
  1414. }
  1415. conn += " and status in ('0','1','3') ";
  1416. //conn += "order by lock_time desc";
  1417. String sql = "select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no, "
  1418. + " a.lock_seq,"
  1419. + " a.lock_type_code,"
  1420. + " a.lock_type_desc,"
  1421. + " a.lock_memo,"
  1422. + " a.lock_id,"
  1423. + " a.heat_no,"
  1424. + " a.batch_no,"
  1425. + " a.board_no,"
  1426. + " a.plan_no,"
  1427. + " A.ht_no,"
  1428. + " a.design_key,"
  1429. + " a.psc,"
  1430. + " a.pline_code,"
  1431. + " a.pline_name,"
  1432. + " a.lock_name,"
  1433. + " a.unlock_memo,"
  1434. + " (select t.batch_no"
  1435. + " from QCM_JHY_SAMPLE_CONSIGN_D t"
  1436. + " where t.HEAT_NO = a.heat_no"
  1437. + " and t.FREQ_CODE = 'D'"
  1438. + " and t.smp_type_code = '0'"
  1439. + " and T.QUOTE_CONSIGN_NO is null"
  1440. + " and rownum <= 1) batch_no1,"
  1441. + " a.lock_time,"
  1442. + " a.psc_desc,"
  1443. + " a.prod_code,"
  1444. + " a.prod_name,"
  1445. + " a.steel_code,"
  1446. + " a.steel_name,"
  1447. + " a.std_code,"
  1448. + " a.std_name,"
  1449. + " (select case when max(a.Smp_Type_Code) = '3' then '件件取样' when max(a.Smp_Type_Code) = '4' then '按母板取样' when max(a.Smp_Type_Code) = '1' then '复样' "
  1450. + " when max(a.Smp_Type_Code) = '0' and max(o.CERT_INST_CODE) in ('IC003', 'IC004','IC001', 'IC010', '5000') then "
  1451. + " '初样' when max(a.smp_no) is null then '' else '认证样' end from qcm_jhy_sample_consign_d a left join QCM_JHY_SAMPLE_R_ORD o on a.smp_no = o.smp_no"
  1452. + " where a.specimen_no in"
  1453. + " (SELECT z.specimen_no"
  1454. + " FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  1455. + " WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  1456. + " ((SELECT z.cert_inst_name"
  1457. + " FROM qcm_judge_physical Z"
  1458. + " WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  1459. + " decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,"
  1460. + " c.ply thick,"
  1461. + " c.width,"
  1462. + " c.length,"
  1463. + " psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,"
  1464. + " c.PLANORDERNO,"
  1465. + " c.orderno,"
  1466. + " (select name_ from scm_base_info@xgcx where id_ = CUTSIDESTATE) CUTSIDESTATE,"
  1467. + " (select name_ from scm_base_info@xgcx where id_ = RuLE) FIXSIZE,c.THEORYWEIGHT weight,"
  1468. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  1469. + " from qcm_judge_locking a,"
  1470. + " qcm_judge_surface b,"
  1471. + " kcz_turnofflist@xgcx c,"
  1472. + " sel_pactdetail@xgcx d"
  1473. + " where 1 = 1"
  1474. + " and a.lock_id = b.surface_id(+)"
  1475. + " and a.material_no = c.billetid(+)"
  1476. + " and d.orderno(+) = c.PLANORDERNO AND A.MATERIAL_NO LIKE 'Z%' AND "+conn+""
  1477. + " union all"
  1478. + " select a.material_no,"
  1479. + " a.lock_seq,"
  1480. + " a.lock_type_code,"
  1481. + " a.lock_type_desc,"
  1482. + " a.lock_memo,"
  1483. + " a.lock_id,"
  1484. + " a.heat_no,"
  1485. + " a.batch_no,"
  1486. + " a.board_no,"
  1487. + " a.plan_no,"
  1488. + " A.ht_no,"
  1489. + " a.design_key,"
  1490. + " a.psc,"
  1491. + " a.pline_code,"
  1492. + " a.pline_name,"
  1493. + " a.lock_name,"
  1494. + " a.unlock_memo,"
  1495. + " (select t.batch_no"
  1496. + " from QCM_JHY_SAMPLE_CONSIGN_D t"
  1497. + " where t.HEAT_NO = a.heat_no"
  1498. + " and t.FREQ_CODE = 'D'"
  1499. + " and t.smp_type_code = '0'"
  1500. + " and T.QUOTE_CONSIGN_NO is null"
  1501. + " and rownum <= 1) batch_no1,"
  1502. + " a.lock_time,"
  1503. + " a.psc_desc,"
  1504. + " a.prod_code,"
  1505. + " a.prod_name,"
  1506. + " a.steel_code,"
  1507. + " a.steel_name,"
  1508. + " a.std_code,"
  1509. + " a.std_name,"
  1510. + " (select case when max(a.Smp_Type_Code) = '3' then '件件取样' when max(a.Smp_Type_Code) = '4' then '按母板取样' when max(a.Smp_Type_Code) = '1' then '复样' "
  1511. + " when max(a.Smp_Type_Code) = '0' and max(o.CERT_INST_CODE) in ('IC003', 'IC004','IC001', 'IC010', '5000') then "
  1512. + " '初样' when max(a.smp_no) is null then '' else '认证样' end from qcm_jhy_sample_consign_d a left join QCM_JHY_SAMPLE_R_ORD o on a.smp_no = o.smp_no"
  1513. + " where a.specimen_no in"
  1514. + " (SELECT z.specimen_no"
  1515. + " FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  1516. + " WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  1517. + " ((SELECT z.cert_inst_name"
  1518. + " FROM qcm_judge_physical Z"
  1519. + " WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  1520. + " decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,"
  1521. + " c.ply thick,"
  1522. + " c.width,"
  1523. + " c.length,"
  1524. + " psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,"
  1525. + " c.planorderform,"
  1526. + " c.allotorderform orderno,"
  1527. + " (select name_ from scm_base_info@xgcx where id_ = CUTSIDESTATE) CUTSIDESTATE,"
  1528. + " (select name_ from scm_base_info@xgcx where id_ = ROLE) FIXSIZE,c.THEORYWEIGHT weight,"
  1529. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  1530. + " from qcm_judge_locking a,"
  1531. + " qcm_judge_surface b,"
  1532. + " kch_turnofflist@xgcx c,"
  1533. + " sel_pactdetail@xgcx d"
  1534. + " where 1 = 1"
  1535. + " and a.lock_id = b.surface_id(+)"
  1536. + " and a.material_no = c.billetid(+)"
  1537. + " and d.orderno(+) = c.planorderform AND A.MATERIAL_NO LIKE 'H%' AND "+conn+"";
  1538. List<HashMap> listqjb = mapper.query(sql);
  1539. cro.setResult(listqjb);
  1540. } catch (Exception e) {
  1541. cro.setV_errCode(-1);
  1542. cro.setV_errMsg("查询失败!"+e.getMessage());
  1543. logger.info(e.getMessage());
  1544. }
  1545. SqlSession.close();
  1546. return cro;
  1547. }
  1548. /**
  1549. * 中厚板异常材处置界面,查询待处置信息
  1550. * @param sum
  1551. * @return
  1552. */
  1553. /*@SuppressWarnings({ "rawtypes", "unchecked" })
  1554. public CoreReturnObject getInformation2HS(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String judge_type,String lock_type_desc,String heat_no,String type1) {
  1555. String conn="status = '0' ";
  1556. try {
  1557. if (!SqlJoint.IsNullOrSpace(design_key)) {
  1558. conn+=" and a.design_key like '%"+design_key+"%'";
  1559. }
  1560. if(type1.equals("1")){
  1561. conn+=" and a.design_key not like '19%'";
  1562. }else{
  1563. conn+=" and a.design_key like '19%'";
  1564. }
  1565. if (!SqlJoint.IsNullOrSpace(psc)) {
  1566. conn+=" and psc_desc like '%"+psc+"%'";
  1567. }
  1568. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  1569. conn+=" and to_date(to_char(check_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  1570. }
  1571. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  1572. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  1573. }
  1574. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  1575. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  1576. }
  1577. if(!SqlJoint.IsNullOrSpace(heat_no)){
  1578. conn += " and a.heat_no like '%"+heat_no+"%'";
  1579. }
  1580. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  1581. if(lock_type_desc.equals("成分判定")){
  1582. conn += " and a.lock_type_code = 'C'";
  1583. }else if(lock_type_desc.equals("材质判定")){
  1584. conn += " and a.lock_type_code = 'P'";
  1585. }else if(lock_type_desc.equals("表面检验")){
  1586. conn += " and a.lock_type_code = 'F'";
  1587. }else if(lock_type_desc.equals("公差检验")){
  1588. conn += " and a.lock_type_code = 'S'";
  1589. }else
  1590. {
  1591. conn+= " and a.lock_type_code = 'D'";
  1592. }
  1593. }
  1594. if(!SqlJoint.IsNullOrSpace(type)){
  1595. //中厚板
  1596. if(type.equals("1")){
  1597. conn += " and a.pline_code in ('ZB1','HB1')";
  1598. }
  1599. }
  1600. if(prodline.equals("中板线")){
  1601. conn += " and a.pline_code in ('ZB1') ";
  1602. }else if(prodline.equals("厚板线")){
  1603. conn += " and a.pline_code in ('HB1') ";
  1604. }
  1605. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  1606. if(StringUtils.isNotEmpty(judge_type)){
  1607. if("1".equals(judge_type)) {
  1608. conn += " and a.lock_type_code in ('C','P','D') ";
  1609. } else if("2".equals(judge_type)) {
  1610. conn += " and a.lock_type_code in ('S','F') ";
  1611. }
  1612. }
  1613. //conn += "order by lock_time desc";
  1614. String sql = "select a.material_no, "
  1615. + " a.lock_seq,"
  1616. + " a.lock_type_code,"
  1617. + " a.lock_type_desc,"
  1618. + " a.lock_memo,"
  1619. + " a.lock_id,"
  1620. + " a.heat_no,"
  1621. + " a.batch_no,"
  1622. + " a.board_no,"
  1623. + " a.plan_no,"
  1624. + " A.ht_no,"
  1625. + " a.design_key,"
  1626. + " a.psc,"
  1627. + " a.pline_code,"
  1628. + " a.pline_name,"
  1629. + " a.create_name,"
  1630. + " a.unlock_memo,"
  1631. + " a.unlock_type_desc,"
  1632. + " (select t.batch_no"
  1633. + " from QCM_JHY_SAMPLE_CONSIGN_D t"
  1634. + " where t.HEAT_NO = a.heat_no"
  1635. + " and t.FREQ_CODE = 'D'"
  1636. + " and t.smp_type_code = '0'"
  1637. + " and T.QUOTE_CONSIGN_NO is null"
  1638. + " and rownum <= 1) batch_no1,"
  1639. + " a.create_time,"
  1640. + " a.psc_desc,"
  1641. + " a.prod_code,"
  1642. + " a.prod_name,"
  1643. + " a.steel_code,"
  1644. + " a.steel_name,"
  1645. + " a.std_code,"
  1646. + " a.std_name,"
  1647. + " (select case when max(a.Smp_Type_Code) = '3' then '件件取样' when max(a.Smp_Type_Code) = '4' then '按母板取样' when max(a.Smp_Type_Code) = '1' then '复样' "
  1648. + " when max(a.Smp_Type_Code) = '0' and max(o.CERT_INST_CODE) in ('IC003', 'IC004','IC001', 'IC010', '5000') then "
  1649. + " '初样' when max(a.smp_no) is null then '' else '认证样' end from qcm_jhy_sample_consign_d a left join QCM_JHY_SAMPLE_R_ORD o on a.smp_no = o.smp_no"
  1650. + " where a.specimen_no in"
  1651. + " (SELECT z.specimen_no"
  1652. + " FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  1653. + " WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  1654. + " ((SELECT z.cert_inst_name"
  1655. + " FROM qcm_judge_physical Z"
  1656. + " WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  1657. + " decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,"
  1658. + " c.ply thick,"
  1659. + " c.width,"
  1660. + " c.length,"
  1661. + " psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,"
  1662. + " c.PLANORDERNO,"
  1663. + " c.orderno,"
  1664. + " (select name_ from scm_base_info@xgcx where id_ = CUTSIDESTATE) CUTSIDESTATE,"
  1665. + " (select name_ from scm_base_info@xgcx where id_ = RuLE) FIXSIZE,c.THEORYWEIGHT weight,"
  1666. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  1667. + " from qcm_judge_locking a,"
  1668. + " qcm_judge_surface b,"
  1669. + " kcz_turnofflist@xgcx c,"
  1670. + " sel_pactdetail@xgcx d"
  1671. + " where 1 = 1"
  1672. + " and a.lock_id = b.surface_id(+)"
  1673. + " and a.material_no = c.billetid(+)"
  1674. + " and d.orderno(+) = c.PLANORDERNO AND A.MATERIAL_NO LIKE 'Z%' AND "+conn+""
  1675. + " union all"
  1676. + " select a.material_no,"
  1677. + " a.lock_seq,"
  1678. + " a.lock_type_code,"
  1679. + " a.lock_type_desc,"
  1680. + " a.lock_memo,"
  1681. + " a.lock_id,"
  1682. + " a.heat_no,"
  1683. + " a.batch_no,"
  1684. + " a.board_no,"
  1685. + " a.plan_no,"
  1686. + " A.ht_no,"
  1687. + " a.design_key,"
  1688. + " a.psc,"
  1689. + " a.pline_code,"
  1690. + " a.pline_name,"
  1691. + " a.create_name,"
  1692. + " a.unlock_memo,"
  1693. + " a.unlock_type_desc,"
  1694. + " (select t.batch_no"
  1695. + " from QCM_JHY_SAMPLE_CONSIGN_D t"
  1696. + " where t.HEAT_NO = a.heat_no"
  1697. + " and t.FREQ_CODE = 'D'"
  1698. + " and t.smp_type_code = '0'"
  1699. + " and T.QUOTE_CONSIGN_NO is null"
  1700. + " and rownum <= 1) batch_no1,"
  1701. + " a.create_time,"
  1702. + " a.psc_desc,"
  1703. + " a.prod_code,"
  1704. + " a.prod_name,"
  1705. + " a.steel_code,"
  1706. + " a.steel_name,"
  1707. + " a.std_code,"
  1708. + " a.std_name,"
  1709. + " (select case when max(a.Smp_Type_Code) = '3' then '件件取样' when max(a.Smp_Type_Code) = '4' then '按母板取样' when max(a.Smp_Type_Code) = '1' then '复样' "
  1710. + " when max(a.Smp_Type_Code) = '0' and max(o.CERT_INST_CODE) in ('IC003', 'IC004','IC001', 'IC010', '5000') then "
  1711. + " '初样' when max(a.smp_no) is null then '' else '认证样' end from qcm_jhy_sample_consign_d a left join QCM_JHY_SAMPLE_R_ORD o on a.smp_no = o.smp_no"
  1712. + " where a.specimen_no in"
  1713. + " (SELECT z.specimen_no"
  1714. + " FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  1715. + " WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  1716. + " ((SELECT z.cert_inst_name"
  1717. + " FROM qcm_judge_physical Z"
  1718. + " WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  1719. + " decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,"
  1720. + " c.ply thick,"
  1721. + " c.width,"
  1722. + " c.length,"
  1723. + " psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,"
  1724. + " c.planorderform,"
  1725. + " c.allotorderform orderno,"
  1726. + " (select name_ from scm_base_info@xgcx where id_ = CUTSIDESTATE) CUTSIDESTATE,"
  1727. + " (select name_ from scm_base_info@xgcx where id_ = ROLE) FIXSIZE,c.THEORYWEIGHT weight,"
  1728. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  1729. + " from qcm_judge_locking a,"
  1730. + " qcm_judge_surface b,"
  1731. + " kch_turnofflist@xgcx c,"
  1732. + " sel_pactdetail@xgcx d"
  1733. + " where 1 = 1"
  1734. + " and a.lock_id = b.surface_id(+)"
  1735. + " and a.material_no = c.billetid(+)"
  1736. + " and d.orderno(+) = c.planorderform AND A.MATERIAL_NO LIKE 'H%' AND "+conn+"";
  1737. List<HashMap> listqjb = mapper.query(sql);
  1738. cro.setResult(listqjb);
  1739. } catch (Exception e) {
  1740. cro.setV_errCode(-1);
  1741. cro.setV_errMsg("查询失败!"+e.getMessage());
  1742. logger.info(e.getMessage());
  1743. }
  1744. SqlSession.close();
  1745. return cro;
  1746. }*/
  1747. /**
  1748. * 异常材处置界面,查询待处置信息
  1749. * @param sum
  1750. * @return
  1751. */
  1752. @SuppressWarnings({ "rawtypes", "unchecked" })
  1753. public CoreReturnObject getInformationH(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String lock_type_desc,String heat_no,String type1) {
  1754. String conn="unlock_type_code is null";
  1755. try {
  1756. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  1757. String sky=StrSky(begintime,endtime);
  1758. if(!sky.equals("TRUE")){
  1759. SqlSession.close();
  1760. cro.setV_errCode(-1);
  1761. cro.setV_errMsg(sky);
  1762. return cro;
  1763. }
  1764. }
  1765. if (!SqlJoint.IsNullOrSpace(design_key)) {
  1766. conn+=" and a.design_key like '%"+design_key+"%'";
  1767. }
  1768. if(type1.equals("1")){
  1769. conn+=" and a.design_key not like '19%'";
  1770. }else{
  1771. conn+=" and a.design_key like '19%'";
  1772. }
  1773. if (!SqlJoint.IsNullOrSpace(psc)) {
  1774. conn+=" and psc_desc like '%"+psc+"%'";
  1775. }
  1776. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  1777. conn+=" and to_date(to_char(lock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  1778. }
  1779. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  1780. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  1781. }
  1782. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  1783. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  1784. }
  1785. if(!SqlJoint.IsNullOrSpace(heat_no)){
  1786. conn += " and a.heat_no like '%"+heat_no+"%'";
  1787. }
  1788. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  1789. if(lock_type_desc.equals("成分判定")){
  1790. conn += " and a.lock_type_code = 'C'";
  1791. }else if(lock_type_desc.equals("材质判定")){
  1792. conn += " and a.lock_type_code = 'P'";
  1793. }else if(lock_type_desc.equals("表面检验")){
  1794. conn += " and a.lock_type_code = 'F'";
  1795. }else if(lock_type_desc.equals("公差检验")){
  1796. conn += " and a.lock_type_code = 'S'";
  1797. }else
  1798. {
  1799. conn+= " and a.lock_type_code = 'D'";
  1800. }
  1801. }
  1802. if(!SqlJoint.IsNullOrSpace(type)){
  1803. if(type.equals("1")){
  1804. conn += " and a.pline_code in ('ZB1','HB1')";
  1805. }
  1806. }
  1807. if(prodline.equals("中板线")){
  1808. conn += " and a.pline_code in ('ZB1') ";
  1809. }else if(prodline.equals("厚板线")){
  1810. conn += " and a.pline_code in ('HB1') ";
  1811. }
  1812. conn += " and status in ('0','1','3') ";
  1813. //conn += "order by lock_time desc";
  1814. String sql = "select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no, "
  1815. + " a.lock_seq,"
  1816. + " a.lock_type_code,"
  1817. + " a.lock_type_desc,"
  1818. + " a.lock_memo,"
  1819. + " a.lock_id,"
  1820. + " a.heat_no,"
  1821. + " a.batch_no,"
  1822. + " a.board_no,"
  1823. + " a.plan_no,"
  1824. + " A.ht_no,"
  1825. + " a.design_key,"
  1826. + " a.psc,"
  1827. + " a.pline_code,"
  1828. + " a.pline_name,"
  1829. + " a.lock_name,"
  1830. + " a.unlock_memo,"
  1831. + " (select t.batch_no"
  1832. + " from QCM_JHY_SAMPLE_CONSIGN_D t"
  1833. + " where t.HEAT_NO = a.heat_no"
  1834. + " and t.FREQ_CODE = 'D'"
  1835. + " and t.smp_type_code = '0'"
  1836. + " and T.QUOTE_CONSIGN_NO is null"
  1837. + " and rownum <= 1) batch_no1,"
  1838. + " a.lock_time,"
  1839. + " a.psc_desc,"
  1840. + " a.prod_code,"
  1841. + " a.prod_name,"
  1842. + " a.steel_code,"
  1843. + " a.steel_name,"
  1844. + " a.std_code,"
  1845. + " a.std_name,"
  1846. + " (select case when max(a.Smp_Type_Code) = '3' then '件件取样' when max(a.Smp_Type_Code) = '4' then '按母板取样' when max(a.Smp_Type_Code) = '1' then '复样' "
  1847. + " when max(a.Smp_Type_Code) = '0' and max(o.CERT_INST_CODE) in ('IC003', 'IC004','IC001', 'IC010', '5000') then "
  1848. + " '初样' when max(a.smp_no) is null then '' else '认证样' end from qcm_jhy_sample_consign_d a left join QCM_JHY_SAMPLE_R_ORD o on a.smp_no = o.smp_no"
  1849. + " where a.specimen_no in"
  1850. + " (SELECT z.specimen_no"
  1851. + " FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  1852. + " WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  1853. + " ((SELECT z.cert_inst_name"
  1854. + " FROM qcm_judge_physical Z"
  1855. + " WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  1856. + " decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,"
  1857. + " c.ply thick,"
  1858. + " c.width,"
  1859. + " c.length,"
  1860. + " psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,"
  1861. + " c.PLANORDERNO,"
  1862. + " c.orderno,"
  1863. + " (select name_ from scm_base_info@xgcx where id_ = CUTSIDESTATE) CUTSIDESTATE,"
  1864. + " (select name_ from scm_base_info@xgcx where id_ = RuLE) FIXSIZE,c.THEORYWEIGHT weight,"
  1865. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  1866. + " from qcm_judge_locking a,"
  1867. + " qcm_judge_surface b,"
  1868. + " kcz_turnofflist@xgcx c,"
  1869. + " sel_pactdetail@xgcx d"
  1870. + " where 1 = 1"
  1871. + " and a.lock_id = b.surface_id(+)"
  1872. + " and a.material_no = c.billetid(+)"
  1873. + " and d.orderno(+) = c.PLANORDERNO AND A.MATERIAL_NO LIKE 'Z%' AND "+conn+""
  1874. + " union all"
  1875. + " select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no,"
  1876. + " a.lock_seq,"
  1877. + " a.lock_type_code,"
  1878. + " a.lock_type_desc,"
  1879. + " a.lock_memo,"
  1880. + " a.lock_id,"
  1881. + " a.heat_no,"
  1882. + " a.batch_no,"
  1883. + " a.board_no,"
  1884. + " a.plan_no,"
  1885. + " A.ht_no,"
  1886. + " a.design_key,"
  1887. + " a.psc,"
  1888. + " a.pline_code,"
  1889. + " a.pline_name,"
  1890. + " a.lock_name,"
  1891. + " a.unlock_memo,"
  1892. + " (select t.batch_no"
  1893. + " from QCM_JHY_SAMPLE_CONSIGN_D t"
  1894. + " where t.HEAT_NO = a.heat_no"
  1895. + " and t.FREQ_CODE = 'D'"
  1896. + " and t.smp_type_code = '0'"
  1897. + " and T.QUOTE_CONSIGN_NO is null"
  1898. + " and rownum <= 1) batch_no1,"
  1899. + " a.lock_time,"
  1900. + " a.psc_desc,"
  1901. + " a.prod_code,"
  1902. + " a.prod_name,"
  1903. + " a.steel_code,"
  1904. + " a.steel_name,"
  1905. + " a.std_code,"
  1906. + " a.std_name,"
  1907. + " (select case when max(a.Smp_Type_Code) = '3' then '件件取样' when max(a.Smp_Type_Code) = '4' then '按母板取样' when max(a.Smp_Type_Code) = '1' then '复样' "
  1908. + " when max(a.Smp_Type_Code) = '0' and max(o.CERT_INST_CODE) in ('IC003', 'IC004','IC001', 'IC010', '5000') then "
  1909. + " '初样' when max(a.smp_no) is null then '' else '认证样' end from qcm_jhy_sample_consign_d a left join QCM_JHY_SAMPLE_R_ORD o on a.smp_no = o.smp_no"
  1910. + " where a.specimen_no in"
  1911. + " (SELECT z.specimen_no"
  1912. + " FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  1913. + " WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  1914. + " ((SELECT z.cert_inst_name"
  1915. + " FROM qcm_judge_physical Z"
  1916. + " WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  1917. + " decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,"
  1918. + " c.ply thick,"
  1919. + " c.width,"
  1920. + " c.length,"
  1921. + " psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,"
  1922. + " c.planorderform,"
  1923. + " c.allotorderform orderno,"
  1924. + " (select name_ from scm_base_info@xgcx where id_ = CUTSIDESTATE) CUTSIDESTATE,"
  1925. + " (select name_ from scm_base_info@xgcx where id_ = ROLE) FIXSIZE,c.THEORYWEIGHT weight,"
  1926. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  1927. + " from qcm_judge_locking a,"
  1928. + " qcm_judge_surface b,"
  1929. + " kch_turnofflist@xgcx c,"
  1930. + " sel_pactdetail@xgcx d"
  1931. + " where 1 = 1"
  1932. + " and a.lock_id = b.surface_id(+)"
  1933. + " and a.material_no = c.billetid(+)"
  1934. + " and d.orderno(+) = c.planorderform AND A.MATERIAL_NO LIKE 'H%' AND "+conn+"";
  1935. List<HashMap> listqjb = mapper.query(sql);
  1936. cro.setResult(listqjb);
  1937. } catch (Exception e) {
  1938. cro.setV_errCode(-1);
  1939. cro.setV_errMsg("查询失败!"+e.getMessage());
  1940. logger.info(e.getMessage());
  1941. }
  1942. SqlSession.close();
  1943. return cro;
  1944. }
  1945. /**
  1946. * 异常材处置界面,查询待处置信息
  1947. * @param sum
  1948. * @return
  1949. */
  1950. @SuppressWarnings({ "rawtypes", "unchecked" })
  1951. public CoreReturnObject getInformationHS(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String lock_type_desc,String heat_no,String type1) {
  1952. String conn="status = '0'";
  1953. try {
  1954. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  1955. String sky=StrSky(begintime,endtime);
  1956. if(!sky.equals("TRUE")){
  1957. SqlSession.close();
  1958. cro.setV_errCode(-1);
  1959. cro.setV_errMsg(sky);
  1960. return cro;
  1961. }
  1962. }
  1963. if (!SqlJoint.IsNullOrSpace(design_key)) {
  1964. conn+=" and a.design_key like '%"+design_key+"%'";
  1965. }
  1966. if(type1.equals("1")){
  1967. conn+=" and a.design_key not like '19%'";
  1968. }else{
  1969. conn+=" and a.design_key like '19%'";
  1970. }
  1971. if (!SqlJoint.IsNullOrSpace(psc)) {
  1972. conn+=" and psc_desc like '%"+psc+"%'";
  1973. }
  1974. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  1975. conn+=" and to_date(to_char(create_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  1976. }
  1977. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  1978. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  1979. }
  1980. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  1981. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  1982. }
  1983. if(!SqlJoint.IsNullOrSpace(heat_no)){
  1984. conn += " and a.heat_no like '%"+heat_no+"%'";
  1985. }
  1986. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  1987. if(lock_type_desc.equals("成分判定")){
  1988. conn += " and a.lock_type_code = 'C'";
  1989. }else if(lock_type_desc.equals("材质判定")){
  1990. conn += " and a.lock_type_code = 'P'";
  1991. }else if(lock_type_desc.equals("表面检验")){
  1992. conn += " and a.lock_type_code = 'F'";
  1993. }else if(lock_type_desc.equals("公差检验")){
  1994. conn += " and a.lock_type_code = 'S'";
  1995. }else
  1996. {
  1997. conn+= " and a.lock_type_code = 'D'";
  1998. }
  1999. }
  2000. if(!SqlJoint.IsNullOrSpace(type)){
  2001. if(type.equals("1")){
  2002. conn += " and a.pline_code in ('ZB1','HB1')";
  2003. }
  2004. }
  2005. if(prodline.equals("中板线")){
  2006. conn += " and a.pline_code in ('ZB1') ";
  2007. }else if(prodline.equals("厚板线")){
  2008. conn += " and a.pline_code in ('HB1') ";
  2009. }
  2010. //conn += "order by lock_time desc";
  2011. String sql = "select a.apply_id,a.material_no, "
  2012. + " a.lock_seq,"
  2013. + " a.lock_type_code,"
  2014. + " a.lock_type_desc,"
  2015. + " a.lock_memo,"
  2016. + " a.lock_id,"
  2017. + " a.heat_no,"
  2018. + " a.batch_no,"
  2019. + " a.board_no,"
  2020. + " a.plan_no,"
  2021. + " A.ht_no,"
  2022. + " a.design_key,"
  2023. + " a.psc,"
  2024. + " a.pline_code,"
  2025. + " a.pline_name,"
  2026. + " a.create_name,"
  2027. + " a.unlock_memo,"
  2028. + " a.unlock_type_desc,"
  2029. + " (select t.batch_no"
  2030. + " from QCM_JHY_SAMPLE_CONSIGN_D t"
  2031. + " where t.HEAT_NO = a.heat_no"
  2032. + " and t.FREQ_CODE = 'D'"
  2033. + " and t.smp_type_code = '0'"
  2034. + " and T.QUOTE_CONSIGN_NO is null"
  2035. + " and rownum <= 1) batch_no1,"
  2036. + " a.create_time,"
  2037. + " a.psc_desc,"
  2038. + " a.prod_code,"
  2039. + " a.prod_name,"
  2040. + " a.steel_code,"
  2041. + " a.steel_name,"
  2042. + " a.std_code,"
  2043. + " a.std_name,"
  2044. + " (select case when max(a.Smp_Type_Code) = '3' then '件件取样' when max(a.Smp_Type_Code) = '4' then '按母板取样' when max(a.Smp_Type_Code) = '1' then '复样' "
  2045. + " when max(a.Smp_Type_Code) = '0' and max(o.CERT_INST_CODE) in ('IC003', 'IC004','IC001', 'IC010', '5000') then "
  2046. + " '初样' when max(a.smp_no) is null then '' else '认证样' end from qcm_jhy_sample_consign_d a left join QCM_JHY_SAMPLE_R_ORD o on a.smp_no = o.smp_no"
  2047. + " where a.specimen_no in"
  2048. + " (SELECT z.specimen_no"
  2049. + " FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  2050. + " WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  2051. + " ((SELECT z.cert_inst_name"
  2052. + " FROM qcm_judge_physical Z"
  2053. + " WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  2054. + " decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,"
  2055. + " c.ply thick,"
  2056. + " c.width,"
  2057. + " c.length,"
  2058. + " psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,"
  2059. + " c.PLANORDERNO,"
  2060. + " c.orderno,"
  2061. + " (select name_ from scm_base_info@xgcx where id_ = CUTSIDESTATE) CUTSIDESTATE,"
  2062. + " (select name_ from scm_base_info@xgcx where id_ = RuLE) FIXSIZE,c.THEORYWEIGHT weight,"
  2063. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  2064. + " from qcm_judge_locking_apply a,"
  2065. + " qcm_judge_surface b,"
  2066. + " kcz_turnofflist@xgcx c,"
  2067. + " sel_pactdetail@xgcx d"
  2068. + " where 1 = 1"
  2069. + " and a.lock_id = b.surface_id(+)"
  2070. + " and a.material_no = c.billetid(+)"
  2071. + " and d.orderno(+) = c.PLANORDERNO AND A.MATERIAL_NO LIKE 'Z%' AND "+conn+""
  2072. + " union all"
  2073. + " select a.apply_id,a.material_no,"
  2074. + " a.lock_seq,"
  2075. + " a.lock_type_code,"
  2076. + " a.lock_type_desc,"
  2077. + " a.lock_memo,"
  2078. + " a.lock_id,"
  2079. + " a.heat_no,"
  2080. + " a.batch_no,"
  2081. + " a.board_no,"
  2082. + " a.plan_no,"
  2083. + " A.ht_no,"
  2084. + " a.design_key,"
  2085. + " a.psc,"
  2086. + " a.pline_code,"
  2087. + " a.pline_name,"
  2088. + " a.create_name,"
  2089. + " a.unlock_memo,"
  2090. + " a.unlock_type_desc,"
  2091. + " (select t.batch_no"
  2092. + " from QCM_JHY_SAMPLE_CONSIGN_D t"
  2093. + " where t.HEAT_NO = a.heat_no"
  2094. + " and t.FREQ_CODE = 'D'"
  2095. + " and t.smp_type_code = '0'"
  2096. + " and T.QUOTE_CONSIGN_NO is null"
  2097. + " and rownum <= 1) batch_no1,"
  2098. + " a.create_time,"
  2099. + " a.psc_desc,"
  2100. + " a.prod_code,"
  2101. + " a.prod_name,"
  2102. + " a.steel_code,"
  2103. + " a.steel_name,"
  2104. + " a.std_code,"
  2105. + " a.std_name,"
  2106. + " (select case when max(a.Smp_Type_Code) = '3' then '件件取样' when max(a.Smp_Type_Code) = '4' then '按母板取样' when max(a.Smp_Type_Code) = '1' then '复样' "
  2107. + " when max(a.Smp_Type_Code) = '0' and max(o.CERT_INST_CODE) in ('IC003', 'IC004','IC001', 'IC010', '5000') then "
  2108. + " '初样' when max(a.smp_no) is null then '' else '认证样' end from qcm_jhy_sample_consign_d a left join QCM_JHY_SAMPLE_R_ORD o on a.smp_no = o.smp_no"
  2109. + " where a.specimen_no in"
  2110. + " (SELECT z.specimen_no"
  2111. + " FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  2112. + " WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  2113. + " ((SELECT z.cert_inst_name"
  2114. + " FROM qcm_judge_physical Z"
  2115. + " WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  2116. + " decode(b.sf_type, 'U', '上表面', 'D', '下表面', '') sf_type,"
  2117. + " c.ply thick,"
  2118. + " c.width,"
  2119. + " c.length,"
  2120. + " psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,"
  2121. + " c.planorderform,"
  2122. + " c.allotorderform orderno,"
  2123. + " (select name_ from scm_base_info@xgcx where id_ = CUTSIDESTATE) CUTSIDESTATE,"
  2124. + " (select name_ from scm_base_info@xgcx where id_ = ROLE) FIXSIZE,c.THEORYWEIGHT weight,"
  2125. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  2126. + " from qcm_judge_locking_apply a,"
  2127. + " qcm_judge_surface b,"
  2128. + " kch_turnofflist@xgcx c,"
  2129. + " sel_pactdetail@xgcx d"
  2130. + " where 1 = 1"
  2131. + " and a.lock_id = b.surface_id(+)"
  2132. + " and a.material_no = c.billetid(+)"
  2133. + " and d.orderno(+) = c.planorderform AND A.MATERIAL_NO LIKE 'H%' AND "+conn+"";
  2134. List<HashMap> listqjb = mapper.query(sql);
  2135. cro.setResult(listqjb);
  2136. } catch (Exception e) {
  2137. cro.setV_errCode(-1);
  2138. cro.setV_errMsg("查询失败!"+e.getMessage());
  2139. logger.info(e.getMessage());
  2140. }
  2141. SqlSession.close();
  2142. return cro;
  2143. }
  2144. /**
  2145. * 异常材处置界面,查询待处置信息
  2146. * @param sum
  2147. * @return
  2148. */
  2149. @SuppressWarnings({ "rawtypes", "unchecked" })
  2150. public CoreReturnObject getLgInformationS(String begintime,String endtime,String heatno,String material_no,String prod_name,String type) {
  2151. String conn="status = '0'";
  2152. try {
  2153. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  2154. String sky=StrSky(begintime,endtime);
  2155. if(!sky.equals("TRUE")){
  2156. SqlSession.close();
  2157. cro.setV_errCode(-1);
  2158. cro.setV_errMsg(sky);
  2159. return cro;
  2160. }
  2161. }
  2162. if (!SqlJoint.IsNullOrSpace(heatno)) {
  2163. conn+=" and HEAT_NO like '%"+heatno+"%'";
  2164. }
  2165. if (!SqlJoint.IsNullOrSpace(material_no)) {
  2166. conn+=" and MATERIAL_NO like '%"+material_no+"%'";
  2167. }
  2168. if(!heatno.equals("") || !material_no.equals("")){
  2169. begintime = "";
  2170. endtime = "";
  2171. }
  2172. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  2173. conn+=" and to_date(to_char(create_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  2174. }
  2175. if (!SqlJoint.IsNullOrSpace(prod_name)) {
  2176. conn += " and PROD_NAME = '"+prod_name+"'";
  2177. }
  2178. conn += "order by create_time desc";
  2179. String sql = "select a.apply_id,a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.unlock_type_desc,a.unlock_memo,a.lock_id,"
  2180. + " a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  2181. + " a.psc, a.pline_code, a.pline_name, a.create_name, "
  2182. + " a.create_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  2183. + " a.std_name from qcm_judge_locking_apply a where 1 = 1 and "+conn+"";
  2184. List<HashMap> listqjb = mapper.query(sql);
  2185. String material_nos = "";
  2186. StringBuffer sqlucomm = new StringBuffer();
  2187. /*for(HashMap list1 : listqjb){
  2188. if(sqlucomm.length() == 0){
  2189. sqlucomm.append( "('" + list1.get("MATERIAL_NO").toString()+"'");
  2190. }else{
  2191. sqlucomm.append( ",'"+ list1.get("MATERIAL_NO").toString()+"'");
  2192. }
  2193. }
  2194. if(sqlucomm.length() == 0)
  2195. sqlucomm.append("('')");
  2196. else
  2197. sqlucomm.append(")");*/
  2198. int j=0;
  2199. for(HashMap list1 : listqjb){
  2200. if(j>=900){
  2201. if(j% 900 == 0){
  2202. sqlucomm.append( ") or HEATNO in ('" + list1.get("MATERIAL_NO").toString()+"'") ;
  2203. }
  2204. else
  2205. {
  2206. if(sqlucomm.length() == 0){
  2207. sqlucomm.append( "('" + list1.get("MATERIAL_NO").toString()+"'");
  2208. }else{
  2209. sqlucomm.append( ",'"+ list1.get("MATERIAL_NO").toString()+"'");
  2210. }
  2211. }
  2212. j++;
  2213. }
  2214. else
  2215. {
  2216. if(sqlucomm.length() == 0){
  2217. sqlucomm.append( "('" + list1.get("MATERIAL_NO").toString()+"'");
  2218. }else{
  2219. sqlucomm.append(",'"+ list1.get("MATERIAL_NO").toString()+"'");
  2220. }
  2221. }
  2222. j++;
  2223. }
  2224. if(sqlucomm.length()==0)
  2225. sqlucomm.append("('')");
  2226. else
  2227. sqlucomm.append(")");
  2228. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  2229. List<HashMap> hashmap = (List<HashMap>) getLgjudgeInfobyMaterial_no1("", "", sqlucomm.toString(), type.equals("3")?"4001LG0":"4001LGX", prod_name, "").getResult();
  2230. for(HashMap list1 : listqjb){
  2231. int i = 0;
  2232. for(HashMap hs :hashmap){
  2233. if(list1.get("MATERIAL_NO").toString().equals(hs.get("material_no").toString())){
  2234. list1.put("THICK", hs.get("thick") == null ? "" :hs.get("thick").toString());
  2235. list1.put("WIDTH", hs.get("width") == null ? "" : hs.get("width").toString());
  2236. list1.put("LENGTH", hs.get("length") == null ? "" : hs.get("length").toString());
  2237. list1.put("PROD_THICK", hs.get("prod_thick") == null ? "" : hs.get("prod_thick").toString());
  2238. list1.put("PROD_WIDTH", hs.get("prod_width") == null ? "" : hs.get("prod_width").toString());
  2239. list1.put("DELIVERY_STATE_DESC", hs.get("delivery_state_desc") == null ? "" : hs.get("delivery_state_desc").toString());
  2240. list1.put("PLANSTEEL", hs.get("PLANSTEEL")==null?"":hs.get("PLANSTEEL").toString());
  2241. list1.put("RATIFFLAG",hs.get("RATIFFLAG")== null?"":hs.get("RATIFFLAG").toString());
  2242. list1.put("RATIFYQ", hs.get("RATIFYQ")== null?"":hs.get("RATIFYQ").toString());
  2243. list1.put("MEMO", hs.get("MEMO")==null?"":hs.get("MEMO").toString());
  2244. list1.put("WEIGHT", hs.get("weight") == null ? "" : hs.get("weight").toString());
  2245. list1.put("SC_MEMO", hs.get("SC_MEMO")==null?"":hs.get("SC_MEMO").toString());
  2246. i++;
  2247. }
  2248. if(i==0){
  2249. list1.put("THICK", "");
  2250. list1.put("WIDTH", "");
  2251. list1.put("LENGTH", "");
  2252. list1.put("PROD_THICK", "");
  2253. list1.put("PROD_WIDTH", "");
  2254. list1.put("DELIVERY_STATE_DESC", "");
  2255. list1.put("PLANSTEEL","");
  2256. list1.put("RATIFFLAG","");
  2257. list1.put("RATIFYQ", "");
  2258. list1.put("MEMO", "");
  2259. list1.put("WEIGHT", "");
  2260. list1.put("SC_MEMO", "");
  2261. }
  2262. }
  2263. }
  2264. cro.setResult(listqjb);
  2265. } catch (Exception e) {
  2266. cro.setV_errCode(-1);
  2267. cro.setV_errMsg("查询失败!"+e.getMessage());
  2268. logger.info(e.getMessage());
  2269. }
  2270. SqlSession.close();
  2271. return cro;
  2272. }
  2273. /**
  2274. * 异常材处置界面,查询待处置信息
  2275. * @param sum
  2276. * @return
  2277. */
  2278. @SuppressWarnings({ "rawtypes", "unchecked" })
  2279. public CoreReturnObject getLgInformation(String begintime,String endtime,String heatno,String material_no,String prod_name,String type) {
  2280. String conn="unlock_type_code is null";
  2281. try {
  2282. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  2283. String sky=StrSky(begintime,endtime);
  2284. if(!sky.equals("TRUE")){
  2285. SqlSession.close();
  2286. cro.setV_errCode(-1);
  2287. cro.setV_errMsg(sky);
  2288. return cro;
  2289. }
  2290. }
  2291. if (!SqlJoint.IsNullOrSpace(heatno)) {
  2292. conn+=" and HEAT_NO like '%"+heatno+"%'";
  2293. }
  2294. if (!SqlJoint.IsNullOrSpace(material_no)) {
  2295. conn+=" and MATERIAL_NO like '%"+material_no+"%'";
  2296. }
  2297. if(!heatno.equals("") || !material_no.equals("")){
  2298. begintime = "";
  2299. endtime = "";
  2300. }
  2301. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  2302. conn+=" and to_date(to_char(lock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  2303. }
  2304. if (!SqlJoint.IsNullOrSpace(prod_name)) {
  2305. conn += " and PROD_NAME = '"+prod_name+"'";
  2306. }
  2307. if(!SqlJoint.IsNullOrSpace(type)){
  2308. if(type.equals("3")){
  2309. conn += " and a.pline_code in ('4001LG0')";
  2310. }
  2311. else if(type.equals("4")){
  2312. conn += " and a.pline_code in ('4001LGX')";
  2313. }
  2314. }
  2315. conn += "order by lock_time desc";
  2316. String sql = "select a.material_no, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,a.lock_id,"
  2317. + " a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  2318. + " a.psc, a.pline_code, a.pline_name, a.lock_name, "
  2319. + " a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  2320. + " a.std_name from qcm_judge_locking a where 1 = 1 and "+conn+"";
  2321. List<HashMap> listqjb = mapper.query(sql);
  2322. String material_nos = "";
  2323. StringBuffer sqlucomm = new StringBuffer();
  2324. for(HashMap list1 : listqjb){
  2325. if(sqlucomm.length() == 0){
  2326. sqlucomm.append( "('" + list1.get("MATERIAL_NO").toString()+"'");
  2327. }else{
  2328. sqlucomm.append( ",'"+ list1.get("MATERIAL_NO").toString()+"'");
  2329. }
  2330. }
  2331. if(sqlucomm.length() == 0)
  2332. sqlucomm.append("('')");
  2333. else
  2334. sqlucomm.append(")");
  2335. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  2336. List<HashMap> hashmap = (List<HashMap>) getLgjudgeInfobyMaterial_no1("", "", sqlucomm.toString(), type.equals("3")?"4001LG0":"4001LGX", prod_name, "").getResult();
  2337. for(HashMap list1 : listqjb){
  2338. int i = 0;
  2339. for(HashMap hs :hashmap){
  2340. if(list1.get("MATERIAL_NO").toString().equals(hs.get("material_no").toString())){
  2341. list1.put("THICK", hs.get("thick") == null ? "" :hs.get("thick").toString());
  2342. list1.put("WIDTH", hs.get("width") == null ? "" : hs.get("width").toString());
  2343. list1.put("LENGTH", hs.get("length") == null ? "" : hs.get("length").toString());
  2344. list1.put("PROD_THICK", hs.get("prod_thick") == null ? "" : hs.get("prod_thick").toString());
  2345. list1.put("PROD_WIDTH", hs.get("prod_width") == null ? "" : hs.get("prod_width").toString());
  2346. list1.put("DELIVERY_STATE_DESC", hs.get("delivery_state_desc") == null ? "" : hs.get("delivery_state_desc").toString());
  2347. list1.put("PLANSTEEL", hs.get("PLANSTEEL")==null?"":hs.get("PLANSTEEL").toString());
  2348. list1.put("RATIFFLAG",hs.get("RATIFFLAG")== null?"":hs.get("RATIFFLAG").toString());
  2349. list1.put("RATIFYQ", hs.get("RATIFYQ")== null?"":hs.get("RATIFYQ").toString());
  2350. list1.put("MEMO", hs.get("MEMO")==null?"":hs.get("MEMO").toString());
  2351. list1.put("WEIGHT", hs.get("weight") == null ? "" : hs.get("weight").toString());
  2352. list1.put("SC_MEMO", hs.get("SC_MEMO")==null?"":hs.get("SC_MEMO").toString());
  2353. i++;
  2354. }
  2355. if(i==0){
  2356. list1.put("THICK", "");
  2357. list1.put("WIDTH", "");
  2358. list1.put("LENGTH", "");
  2359. list1.put("PROD_THICK", "");
  2360. list1.put("PROD_WIDTH", "");
  2361. list1.put("DELIVERY_STATE_DESC", "");
  2362. list1.put("PLANSTEEL","");
  2363. list1.put("RATIFFLAG","");
  2364. list1.put("RATIFYQ", "");
  2365. list1.put("MEMO", "");
  2366. list1.put("WEIGHT", "");
  2367. list1.put("SC_MEMO", "");
  2368. }
  2369. }
  2370. }
  2371. cro.setResult(listqjb);
  2372. } catch (Exception e) {
  2373. cro.setV_errCode(-1);
  2374. cro.setV_errMsg("查询失败!"+e.getMessage());
  2375. logger.info(e.getMessage());
  2376. }
  2377. SqlSession.close();
  2378. return cro;
  2379. }
  2380. /**
  2381. * 异常材处理:处置记录查询
  2382. * @param sum
  2383. * @return
  2384. */
  2385. @SuppressWarnings({ "rawtypes", "unchecked" })
  2386. public CoreReturnObject getAbnormalRecordInfo2(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String judge_type,String lock_type_desc) {
  2387. String conn="unlock_type_code is not null";
  2388. try {
  2389. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  2390. String sky=StrSky(begintime,endtime);
  2391. if(!sky.equals("TRUE")){
  2392. SqlSession.close();
  2393. cro.setV_errCode(-1);
  2394. cro.setV_errMsg(sky);
  2395. return cro;
  2396. }
  2397. }
  2398. if (!SqlJoint.IsNullOrSpace(design_key)) {
  2399. conn+=" and a.design_key like '%"+design_key+"%'";
  2400. }
  2401. if (!SqlJoint.IsNullOrSpace(psc)) {
  2402. conn+=" and psc like '%"+psc+"%'";
  2403. }
  2404. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  2405. conn+=" and to_date(to_char(unlock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  2406. }
  2407. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  2408. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  2409. }
  2410. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  2411. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  2412. }
  2413. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  2414. if(lock_type_desc.equals("成分判定")){
  2415. conn += " and a.lock_type_code = 'C'";
  2416. }else if(lock_type_desc.equals("材质判定")){
  2417. conn += " and a.lock_type_code = 'P'";
  2418. }else if(lock_type_desc.equals("表面检验")){
  2419. conn += " and a.lock_type_code = 'F'";
  2420. }else if(lock_type_desc.equals("公差检验")){
  2421. conn += " and a.lock_type_code = 'S'";
  2422. }else if(lock_type_desc.equals("工艺检验")){
  2423. conn += " and a.lock_type_code = 'T'";
  2424. }
  2425. else
  2426. {
  2427. conn+= " and a.lock_type_code = 'D'";
  2428. }
  2429. }
  2430. if(!SqlJoint.IsNullOrSpace(type)){
  2431. //卷板
  2432. if(type.equals("0")){
  2433. conn += " and a.pline_code in ('LT1','SZ1','RZ1')";
  2434. }
  2435. //中厚板
  2436. else if(type.equals("1")){
  2437. conn += " and a.pline_code in ('ZB1','HB1')";
  2438. }
  2439. //线棒
  2440. else if(type.equals("2")){
  2441. conn += " and a.pline_code in ('GX1','BC1','BC2','GX2','4001GX1','4001GX2','4001BC2')";
  2442. }
  2443. else if(type.equals("3")){
  2444. conn += " and a.pline_code in ('4001LG0')";
  2445. }
  2446. else if(type.equals("4")){
  2447. conn += " and a.pline_code in ('4001LGX')";
  2448. }
  2449. else if(type.equals("5")){
  2450. conn += " and a.pline_code in ('YT1')";
  2451. }
  2452. }
  2453. conn += " and status in ('0','1','3') ";
  2454. if(prodline.equals("中板线")){
  2455. conn += " and a.pline_code in ('ZB1') ";
  2456. }else if(prodline.equals("厚板线")){
  2457. conn += " and a.pline_code in ('HB1') ";
  2458. }else if(prodline.equals("热连轧")){
  2459. conn += " and a.pline_code in ('RZ1') ";
  2460. }else if(prodline.equals("酸轧")){
  2461. conn += " and a.pline_code in ('SZ1') ";
  2462. }else if(prodline.equals("连退")){
  2463. conn += " and a.pline_code in ('LT1') ";
  2464. }else if(prodline.equals("高棒")){
  2465. conn += " and a.pline_code in ('GX1','4001GX1') ";
  2466. }else if(prodline.equals("棒二")){
  2467. conn += " and a.pline_code in ('BC2','4001BC2') ";
  2468. }else if(prodline.equals("高线")){
  2469. conn += " and a.pline_code in ('GX2','4001GX2') ";
  2470. }else if(prodline.equals("优特")){
  2471. conn += " and a.pline_code in ('YT1') ";
  2472. }
  2473. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  2474. if(StringUtils.isNotEmpty(judge_type)){
  2475. if("1".equals(judge_type)) {
  2476. conn += " and a.lock_type_code in ('C','P','D') ";
  2477. } else if("2".equals(judge_type)) {
  2478. conn += " and a.lock_type_code in ('S','F') ";
  2479. }
  2480. }
  2481. //conn += "order by unlock_time desc";
  2482. /*String sql = "select a.material_no,lock_type_desc,lock_memo,UNLOCK_TYPE_CODE,UNLOCK_TYPE_DESC, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,"
  2483. + " UNLOCK_MEMO,TARGET_DESIGN_KEY,TARGET_PSC,UNLOCK_NAME,a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  2484. + " a.psc, a.pline_code, a.pline_name, a.lock_name,UNLOCK_TIME, "
  2485. + " a.lock_id,a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, decode(a.lock_type_code, 'F', decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''), '') sf_type, "
  2486. + " a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  2487. + " where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  2488. + " ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name from qcm_judge_locking a, qcm_judge_surface b where 1 = 1 and a.lock_id = b.surface_id(+) and "+conn+"";*/
  2489. String sql = "select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no, "
  2490. +" lock_type_desc,"
  2491. +" lock_memo,"
  2492. +" UNLOCK_TYPE_CODE,"
  2493. +" UNLOCK_TYPE_DESC,"
  2494. +" a.lock_seq,"
  2495. +" a.lock_type_code,"
  2496. +" a.lock_type_desc,"
  2497. +" a.lock_memo,"
  2498. +" UNLOCK_MEMO,"
  2499. +" TARGET_DESIGN_KEY,"
  2500. +" TARGET_PSC,"
  2501. +" UNLOCK_NAME,"
  2502. +" a.heat_no,"
  2503. +" a.batch_no,"
  2504. +" a.board_no,"
  2505. +" a.plan_no,"
  2506. +" a.ht_no,"
  2507. +" a.design_key,"
  2508. +" a.psc,"
  2509. +" a.pline_code,"
  2510. +" a.pline_name,"
  2511. +" a.lock_name,"
  2512. +" UNLOCK_TIME,"
  2513. +" a.lock_id,"
  2514. +" a.lock_time,"
  2515. +" a.psc_desc,"
  2516. +" a.prod_code,"
  2517. +" a.prod_name,"
  2518. +" a.steel_code,"
  2519. +" a.steel_name,"
  2520. +" a.std_code,"
  2521. +" decode(a.lock_type_code,"
  2522. +" 'F',"
  2523. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  2524. +" '') sf_type,"
  2525. +" a.std_name,"
  2526. +" (select decode(max(a.Smp_Type_Code),"
  2527. +" '3',"
  2528. +" '件件取样',"
  2529. +" '1',"
  2530. +" '复样',"
  2531. +" '0',"
  2532. +" '初样')"
  2533. +" from qcm_jhy_sample_consign_d a"
  2534. +" where a.specimen_no in"
  2535. +" (SELECT z.specimen_no"
  2536. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  2537. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  2538. +" ((SELECT z.cert_inst_name"
  2539. +" FROM qcm_judge_physical Z"
  2540. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  2541. +" c.ply thick,c.width,c.length,psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,c.THEORYWEIGHT weight,"
  2542. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  2543. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time "
  2544. +" from qcm_judge_locking a, qcm_judge_surface b,Kcx_Turnofflist@Xgcx c,sel_pactdetail@xgcx d"
  2545. +" where 1 = 1"
  2546. +" and a.lock_id = b.surface_id(+)"
  2547. +" and a.material_no = c.billetid"
  2548. +" and c.orderno = d.orderno(+) AND " +conn+"";
  2549. System.out.print(sql);
  2550. List<HashMap> listqjb = mapper.query(sql);
  2551. cro.setResult(listqjb);
  2552. } catch (Exception e) {
  2553. cro.setV_errCode(-1);
  2554. cro.setV_errMsg("查询失败!"+e.getMessage());
  2555. logger.info(e.getMessage());
  2556. }
  2557. SqlSession.close();
  2558. return cro;
  2559. }
  2560. /**
  2561. * 异常材处理:处置记录查询
  2562. * @param sum
  2563. * @return
  2564. */
  2565. @SuppressWarnings({ "rawtypes", "unchecked" })
  2566. public CoreReturnObject getAbnormalRecordInfo(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String lock_type_desc) {
  2567. String conn="unlock_type_code is not null";
  2568. try {
  2569. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  2570. String sky=StrSky(begintime,endtime);
  2571. if(!sky.equals("TRUE")){
  2572. SqlSession.close();
  2573. cro.setV_errCode(-1);
  2574. cro.setV_errMsg(sky);
  2575. return cro;
  2576. }
  2577. }
  2578. if (!SqlJoint.IsNullOrSpace(design_key)) {
  2579. conn+=" and a.design_key like '%"+design_key+"%'";
  2580. }
  2581. if (!SqlJoint.IsNullOrSpace(psc)) {
  2582. conn+=" and psc like '%"+psc+"%'";
  2583. }
  2584. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  2585. conn+=" and to_date(to_char(unlock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  2586. }
  2587. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  2588. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  2589. }
  2590. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  2591. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  2592. }
  2593. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  2594. if(lock_type_desc.equals("成分判定")){
  2595. conn += " and a.lock_type_code = 'C'";
  2596. }else if(lock_type_desc.equals("材质判定")){
  2597. conn += " and a.lock_type_code = 'P'";
  2598. }else if(lock_type_desc.equals("表面检验")){
  2599. conn += " and a.lock_type_code = 'F'";
  2600. }else if(lock_type_desc.equals("公差检验")){
  2601. conn += " and a.lock_type_code = 'S'";
  2602. }else if(lock_type_desc.equals("工艺检验")){
  2603. conn += " and a.lock_type_code = 'T'";
  2604. }
  2605. else
  2606. {
  2607. conn+= " and a.lock_type_code = 'D'";
  2608. }
  2609. }
  2610. conn += " and status in ('0','1','2','3') ";
  2611. if(!SqlJoint.IsNullOrSpace(type)){
  2612. //卷板
  2613. if(type.equals("0")){
  2614. conn += " and a.pline_code in ('LT1','SZ1','RZ1')";
  2615. }
  2616. //中厚板
  2617. else if(type.equals("1")){
  2618. conn += " and a.pline_code in ('ZB1','HB1')";
  2619. }
  2620. //线棒
  2621. else if(type.equals("2")){
  2622. conn += " and a.pline_code in ('GX1','BC1','BC2','GX2','4001GX1','4001GX2','4001BC2')";
  2623. }
  2624. else if(type.equals("3")){
  2625. conn += " and a.pline_code in ('4001LG0')";
  2626. }
  2627. else if(type.equals("4")){
  2628. conn += " and a.pline_code in ('4001LGX')";
  2629. }
  2630. else if(type.equals("5")){
  2631. conn += " and a.pline_code in ('YT1')";
  2632. }
  2633. }
  2634. if(prodline.equals("中板线")){
  2635. conn += " and a.pline_code in ('ZB1') ";
  2636. }else if(prodline.equals("厚板线")){
  2637. conn += " and a.pline_code in ('HB1') ";
  2638. }else if(prodline.equals("热连轧")){
  2639. conn += " and a.pline_code in ('RZ1') ";
  2640. }else if(prodline.equals("酸轧")){
  2641. conn += " and a.pline_code in ('SZ1') ";
  2642. }else if(prodline.equals("连退")){
  2643. conn += " and a.pline_code in ('LT1') ";
  2644. }else if(prodline.equals("高棒")){
  2645. conn += " and a.pline_code in ('GX1','4001GX1') ";
  2646. }else if(prodline.equals("棒二")){
  2647. conn += " and a.pline_code in ('BC2','4001BC2') ";
  2648. }else if(prodline.equals("高线")){
  2649. conn += " and a.pline_code in ('GX2','4001GX2') ";
  2650. }else if(prodline.equals("优特")){
  2651. conn += " and a.pline_code in ('YT1') ";
  2652. }
  2653. //conn += "order by unlock_time desc";
  2654. /*String sql = "select a.material_no,lock_type_desc,lock_memo,UNLOCK_TYPE_CODE,UNLOCK_TYPE_DESC, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,"
  2655. + " UNLOCK_MEMO,TARGET_DESIGN_KEY,TARGET_PSC,UNLOCK_NAME,a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  2656. + " a.psc, a.pline_code, a.pline_name, a.lock_name,UNLOCK_TIME, "
  2657. + " a.lock_id,a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, decode(a.lock_type_code, 'F', decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''), '') sf_type, "
  2658. + " a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  2659. + " where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  2660. + " ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name from qcm_judge_locking a, qcm_judge_surface b where 1 = 1 and a.lock_id = b.surface_id(+) and "+conn+"";*/
  2661. String sql = "select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no, "
  2662. +" lock_type_desc,"
  2663. +" lock_memo,"
  2664. +" UNLOCK_TYPE_CODE,"
  2665. +" UNLOCK_TYPE_DESC,"
  2666. +" a.lock_seq,"
  2667. +" a.lock_type_code,"
  2668. +" a.lock_type_desc,"
  2669. +" a.lock_memo,"
  2670. +" UNLOCK_MEMO,"
  2671. +" TARGET_DESIGN_KEY,"
  2672. +" TARGET_PSC,"
  2673. +" UNLOCK_NAME,"
  2674. +" a.heat_no,"
  2675. +" a.batch_no,"
  2676. +" a.board_no,"
  2677. +" a.plan_no,"
  2678. +" a.ht_no,"
  2679. +" a.design_key,"
  2680. +" a.psc,"
  2681. +" a.pline_code,"
  2682. +" a.pline_name,"
  2683. +" a.lock_name,"
  2684. +" UNLOCK_TIME,"
  2685. +" a.lock_id,"
  2686. +" a.lock_time,"
  2687. +" a.psc_desc,"
  2688. +" a.prod_code,"
  2689. +" a.prod_name,"
  2690. +" a.steel_code,"
  2691. +" a.steel_name,"
  2692. +" a.std_code,"
  2693. +" decode(a.lock_type_code,"
  2694. +" 'F',"
  2695. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  2696. +" '') sf_type,"
  2697. +" a.std_name,"
  2698. +" (select decode(max(a.Smp_Type_Code),"
  2699. +" '3',"
  2700. +" '件件取样',"
  2701. +" '1',"
  2702. +" '复样',"
  2703. +" '0',"
  2704. +" '初样')"
  2705. +" from qcm_jhy_sample_consign_d a"
  2706. +" where a.specimen_no in"
  2707. +" (SELECT z.specimen_no"
  2708. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  2709. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  2710. +" ((SELECT z.cert_inst_name"
  2711. +" FROM qcm_judge_physical Z"
  2712. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  2713. +" c.ply thick,c.width,c.length,psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,c.THEORYWEIGHT weight,"
  2714. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select b.psc from qcm_ord_design_std_cic b where b.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  2715. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time "
  2716. +" from qcm_judge_locking a, qcm_judge_surface b,Kcx_Turnofflist@Xgcx c,sel_pactdetail@xgcx d"
  2717. +" where 1 = 1"
  2718. +" and a.lock_id = b.surface_id(+)"
  2719. +" and a.material_no = c.billetid"
  2720. +" and c.orderno = d.orderno(+) AND " +conn+"";
  2721. System.out.print(sql);
  2722. List<HashMap> listqjb = mapper.query(sql);
  2723. cro.setResult(listqjb);
  2724. } catch (Exception e) {
  2725. cro.setV_errCode(-1);
  2726. cro.setV_errMsg("查询失败!"+e.getMessage());
  2727. logger.info(e.getMessage());
  2728. }
  2729. SqlSession.close();
  2730. return cro;
  2731. }
  2732. /* 异常材处理:处置记录查询
  2733. * @param sum
  2734. * @return
  2735. */
  2736. @SuppressWarnings({ "rawtypes", "unchecked" })
  2737. public CoreReturnObject getAbnormalRecordInfoS(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String lock_type_desc) {
  2738. String conn="STATUS <> '0'";
  2739. try {
  2740. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  2741. String sky=StrSky(begintime,endtime);
  2742. if(!sky.equals("TRUE")){
  2743. SqlSession.close();
  2744. cro.setV_errCode(-1);
  2745. cro.setV_errMsg(sky);
  2746. return cro;
  2747. }
  2748. }
  2749. if (!SqlJoint.IsNullOrSpace(design_key)) {
  2750. conn+=" and a.design_key like '%"+design_key+"%'";
  2751. }
  2752. if (!SqlJoint.IsNullOrSpace(psc)) {
  2753. conn+=" and psc like '%"+psc+"%'";
  2754. }
  2755. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  2756. conn+=" and to_date(to_char(check_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  2757. }
  2758. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  2759. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  2760. }
  2761. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  2762. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  2763. }
  2764. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  2765. if(lock_type_desc.equals("成分判定")){
  2766. conn += " and a.lock_type_code = 'C'";
  2767. }else if(lock_type_desc.equals("材质判定")){
  2768. conn += " and a.lock_type_code = 'P'";
  2769. }else if(lock_type_desc.equals("表面检验")){
  2770. conn += " and a.lock_type_code = 'F'";
  2771. }else if(lock_type_desc.equals("公差检验")){
  2772. conn += " and a.lock_type_code = 'S'";
  2773. }else if(lock_type_desc.equals("工艺检验")){
  2774. conn += " and a.lock_type_code = 'T'";
  2775. }
  2776. else
  2777. {
  2778. conn+= " and a.lock_type_code = 'D'";
  2779. }
  2780. }
  2781. if(!SqlJoint.IsNullOrSpace(type)){
  2782. //卷板
  2783. if(type.equals("0")){
  2784. conn += " and a.pline_code in ('LT1','SZ1','RZ1')";
  2785. }
  2786. //中厚板
  2787. else if(type.equals("1")){
  2788. conn += " and a.pline_code in ('ZB1','HB1')";
  2789. }
  2790. //线棒
  2791. else if(type.equals("2")){
  2792. conn += " and a.pline_code in ('GX1','BC1','BC2','GX2','4001GX1','4001GX2','4001BC2')";
  2793. }
  2794. else if(type.equals("3")){
  2795. conn += " and a.pline_code in ('4001LG0')";
  2796. }
  2797. else if(type.equals("4")){
  2798. conn += " and a.pline_code in ('4001LGX')";
  2799. }
  2800. else if(type.equals("5")){
  2801. conn += " and a.pline_code in ('YT1')";
  2802. }
  2803. }
  2804. if(prodline.equals("中板线")){
  2805. conn += " and a.pline_code in ('ZB1') ";
  2806. }else if(prodline.equals("厚板线")){
  2807. conn += " and a.pline_code in ('HB1') ";
  2808. }else if(prodline.equals("热连轧")){
  2809. conn += " and a.pline_code in ('RZ1') ";
  2810. }else if(prodline.equals("酸轧")){
  2811. conn += " and a.pline_code in ('SZ1') ";
  2812. }else if(prodline.equals("连退")){
  2813. conn += " and a.pline_code in ('LT1') ";
  2814. }else if(prodline.equals("高棒")){
  2815. conn += " and a.pline_code in ('GX1','4001GX1') ";
  2816. }else if(prodline.equals("棒二")){
  2817. conn += " and a.pline_code in ('BC2','4001BC2') ";
  2818. }else if(prodline.equals("高线")){
  2819. conn += " and a.pline_code in ('GX2','4001GX2') ";
  2820. }else if(prodline.equals("优特")){
  2821. conn += " and a.pline_code in ('YT1') ";
  2822. }
  2823. //conn += "order by unlock_time desc";
  2824. /*String sql = "select a.material_no,lock_type_desc,lock_memo,UNLOCK_TYPE_CODE,UNLOCK_TYPE_DESC, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,"
  2825. + " UNLOCK_MEMO,TARGET_DESIGN_KEY,TARGET_PSC,UNLOCK_NAME,a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  2826. + " a.psc, a.pline_code, a.pline_name, a.lock_name,UNLOCK_TIME, "
  2827. + " a.lock_id,a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, decode(a.lock_type_code, 'F', decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''), '') sf_type, "
  2828. + " a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  2829. + " where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  2830. + " ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name from qcm_judge_locking a, qcm_judge_surface b where 1 = 1 and a.lock_id = b.surface_id(+) and "+conn+"";*/
  2831. String sql = "select apply_id,case when a.status = '1' then '审核通过' else '审核不通过' end status,a.material_no, "
  2832. +" lock_type_desc,"
  2833. +" lock_memo,"
  2834. +" UNLOCK_TYPE_CODE,"
  2835. +" UNLOCK_TYPE_DESC,"
  2836. +" a.lock_seq,"
  2837. +" a.lock_type_code,"
  2838. +" a.lock_type_desc,"
  2839. +" a.lock_memo,"
  2840. +" UNLOCK_MEMO,"
  2841. +" a.heat_no,"
  2842. +" a.batch_no,"
  2843. +" a.board_no,"
  2844. +" a.plan_no,"
  2845. +" a.ht_no,"
  2846. +" a.design_key,"
  2847. +" a.psc,"
  2848. +" a.pline_code,"
  2849. +" a.pline_name,"
  2850. +" a.create_name,"
  2851. +" a.lock_id,"
  2852. +" a.create_time,"
  2853. +" a.psc_desc,"
  2854. +" a.prod_code,"
  2855. +" a.prod_name,"
  2856. +" a.steel_code,"
  2857. +" a.steel_name,"
  2858. +" a.std_code,a.check_name,a.check_time,"
  2859. +" decode(a.lock_type_code,"
  2860. +" 'F',"
  2861. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  2862. +" '') sf_type,"
  2863. +" a.std_name,"
  2864. +" (select decode(max(a.Smp_Type_Code),"
  2865. +" '3',"
  2866. +" '件件取样',"
  2867. +" '1',"
  2868. +" '复样',"
  2869. +" '0',"
  2870. +" '初样')"
  2871. +" from qcm_jhy_sample_consign_d a"
  2872. +" where a.specimen_no in"
  2873. +" (SELECT z.specimen_no"
  2874. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  2875. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  2876. +" ((SELECT z.cert_inst_name"
  2877. +" FROM qcm_judge_physical Z"
  2878. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  2879. +" c.ply thick,c.width,c.length,psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,c.THEORYWEIGHT weight,"
  2880. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select b.psc from qcm_ord_design_std_cic b where b.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  2881. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time,a.HANDLE_MEMO "
  2882. +" from qcm_judge_locking_apply a, qcm_judge_surface b,Kcx_Turnofflist@Xgcx c,sel_pactdetail@xgcx d"
  2883. +" where 1 = 1"
  2884. +" and a.lock_id = b.surface_id(+)"
  2885. +" and a.material_no = c.billetid"
  2886. +" and c.orderno = d.orderno(+) AND " +conn+"";
  2887. System.out.print(sql);
  2888. List<HashMap> listqjb = mapper.query(sql);
  2889. cro.setResult(listqjb);
  2890. } catch (Exception e) {
  2891. cro.setV_errCode(-1);
  2892. cro.setV_errMsg("查询失败!"+e.getMessage());
  2893. logger.info(e.getMessage());
  2894. }
  2895. SqlSession.close();
  2896. return cro;
  2897. }
  2898. /**
  2899. * 异常材处理:处置记录查询
  2900. * @param sum
  2901. * @return
  2902. */
  2903. @SuppressWarnings({ "rawtypes", "unchecked" })
  2904. public CoreReturnObject getAbnormalRecordInfo2J(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String judge_type,String lock_type_desc) {
  2905. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  2906. String sky=StrSky(begintime,endtime);
  2907. if(!sky.equals("TRUE")){
  2908. SqlSession.close();
  2909. cro.setV_errCode(-1);
  2910. cro.setV_errMsg(sky);
  2911. return cro;
  2912. }
  2913. }
  2914. String conn="unlock_type_code is not null";
  2915. String swhere = "";
  2916. try {
  2917. if (!SqlJoint.IsNullOrSpace(design_key)) {
  2918. conn+=" and a.design_key like '%"+design_key+"%'";
  2919. }
  2920. if (!SqlJoint.IsNullOrSpace(psc)) {
  2921. conn+=" and psc like '%"+psc+"%'";
  2922. }
  2923. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  2924. conn+=" and to_date(to_char(unlock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  2925. }
  2926. if(type.equals("5")){
  2927. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  2928. conn += " and a.material_no like '%"+sbatchno+"%'";
  2929. }
  2930. if(!SqlJoint.IsNullOrSpace(ebatchno)){
  2931. if(ebatchno.equals("4mm分条机组")){
  2932. swhere += " and MACHINE_CODE = 'M0001'";
  2933. }else if(ebatchno.equals("12mm分条机组")){
  2934. swhere += " and MACHINE_CODE = 'M0002'";
  2935. }else if(ebatchno.equals("3mm横剪机组")){
  2936. swhere += " and MACHINE_CODE = 'M0003'";
  2937. }else if(ebatchno.equals("退火炉宝信")){
  2938. swhere += " and MACHINE_CODE = 'M0004'";
  2939. }else if(ebatchno.equals("退火炉南方D")){
  2940. swhere += " and MACHINE_CODE = 'M0005'";
  2941. }else if(ebatchno.equals("退火炉艾伯纳")){
  2942. swhere += " and MACHINE_CODE = 'M0006'";
  2943. }else if(ebatchno.equals("平整机组")){
  2944. swhere += " and MACHINE_CODE = 'M0007'";
  2945. }else if(ebatchno.equals("轧机机组")){
  2946. swhere += " and MACHINE_CODE = 'M0008'";
  2947. }else if(ebatchno.equals("退火炉南方G")){
  2948. swhere += " and MACHINE_CODE = 'M0009'";
  2949. }else if(ebatchno.equals("酸洗机组")){
  2950. swhere += " and MACHINE_CODE = 'M0010'";
  2951. }
  2952. }
  2953. }else{
  2954. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  2955. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  2956. }
  2957. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  2958. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  2959. }
  2960. }
  2961. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  2962. if(lock_type_desc.equals("成分判定")){
  2963. conn += " and a.lock_type_code = 'C'";
  2964. }else if(lock_type_desc.equals("材质判定")){
  2965. conn += " and a.lock_type_code = 'P'";
  2966. }else if(lock_type_desc.equals("表面检验")){
  2967. conn += " and a.lock_type_code = 'F'";
  2968. }else if(lock_type_desc.equals("公差检验")){
  2969. conn += " and a.lock_type_code = 'S'";
  2970. }else if(lock_type_desc.equals("工艺检验")){
  2971. conn += " and a.lock_type_code = 'T'";
  2972. }
  2973. else
  2974. {
  2975. conn+= " and a.lock_type_code = 'D'";
  2976. }
  2977. }
  2978. conn += " and status in ('0','1','3') ";
  2979. if(!SqlJoint.IsNullOrSpace(type)){
  2980. //卷板
  2981. if(type.equals("0")){
  2982. conn += " and a.pline_code in ('LT1','SZ1','RZ1')";
  2983. }
  2984. //中厚板
  2985. else if(type.equals("1")){
  2986. conn += " and a.pline_code in ('ZB1','HB1')";
  2987. }
  2988. //线棒
  2989. else if(type.equals("2")){
  2990. conn += " and a.pline_code in ('GX1','BC1','BC2','GX2','4001GX1','4001GX2','4001BC2')";
  2991. }
  2992. else if(type.equals("3")){
  2993. conn += " and a.pline_code in ('4001LG0')";
  2994. }
  2995. else if(type.equals("4")){
  2996. conn += " and a.pline_code in ('4001LGX')";
  2997. }
  2998. else if(type.equals("5")){
  2999. conn += " and a.pline_code in ('YT1')";
  3000. }
  3001. }
  3002. if(prodline.equals("中板线")){
  3003. conn += " and a.pline_code in ('ZB1') ";
  3004. }else if(prodline.equals("厚板线")){
  3005. conn += " and a.pline_code in ('HB1') ";
  3006. }else if(prodline.equals("热连轧")){
  3007. conn += " and a.pline_code in ('RZ1') ";
  3008. }else if(prodline.equals("酸轧")){
  3009. conn += " and a.pline_code in ('SZ1') ";
  3010. }else if(prodline.equals("连退")){
  3011. conn += " and a.pline_code in ('LT1') ";
  3012. }else if(prodline.equals("高棒")){
  3013. conn += " and a.pline_code in ('GX1','4001GX1') ";
  3014. }else if(prodline.equals("棒二")){
  3015. conn += " and a.pline_code in ('BC2','4001BC2') ";
  3016. }else if(prodline.equals("高线")){
  3017. conn += " and a.pline_code in ('GX2','4001GX2') ";
  3018. }else if(prodline.equals("优特")){
  3019. conn += " and a.pline_code in ('YT1') ";
  3020. }
  3021. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  3022. if(StringUtils.isNotEmpty(judge_type)){
  3023. if("1".equals(judge_type)) {
  3024. conn += " and a.lock_type_code in ('C','P','D') ";
  3025. } else if("2".equals(judge_type)) {
  3026. conn += " and a.lock_type_code in ('S','F') ";
  3027. }
  3028. }
  3029. //conn += "order by unlock_time desc";
  3030. /*String sql = "select a.material_no,lock_type_desc,lock_memo,UNLOCK_TYPE_CODE,UNLOCK_TYPE_DESC, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,"
  3031. + " UNLOCK_MEMO,TARGET_DESIGN_KEY,TARGET_PSC,UNLOCK_NAME,a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  3032. + " a.psc, a.pline_code, a.pline_name, a.lock_name,UNLOCK_TIME, "
  3033. + " a.lock_id,a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, decode(a.lock_type_code, 'F', decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''), '') sf_type, "
  3034. + " a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  3035. + " where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  3036. + " ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name from qcm_judge_locking a, qcm_judge_surface b where 1 = 1 and a.lock_id = b.surface_id(+) and "+conn+"";*/
  3037. String sql = "select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no,"
  3038. +" lock_type_desc,"
  3039. +" lock_memo,"
  3040. +" UNLOCK_TYPE_CODE,"
  3041. +" UNLOCK_TYPE_DESC,"
  3042. +" a.lock_seq,"
  3043. +" a.lock_type_code,"
  3044. +" a.lock_type_desc,"
  3045. +" a.lock_memo,"
  3046. +" UNLOCK_MEMO,"
  3047. +" TARGET_DESIGN_KEY,"
  3048. +" TARGET_PSC,"
  3049. +" UNLOCK_NAME,"
  3050. +" a.heat_no,"
  3051. +" a.batch_no,"
  3052. +" a.board_no,"
  3053. +" a.plan_no,"
  3054. +" a.ht_no,"
  3055. +" a.design_key,"
  3056. +" a.psc,"
  3057. +" a.pline_code,"
  3058. +" a.pline_name,"
  3059. +" a.lock_name,"
  3060. +" UNLOCK_TIME,"
  3061. +" a.lock_id,"
  3062. +" a.lock_time,"
  3063. +" a.psc_desc,"
  3064. +" a.prod_code,"
  3065. +" a.prod_name,"
  3066. +" a.steel_code,"
  3067. +" a.steel_name,"
  3068. +" a.std_code,"
  3069. +" decode(a.lock_type_code,"
  3070. +" 'F',"
  3071. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  3072. +" '') sf_type,"
  3073. +" a.std_name,"
  3074. +" (select decode(max(a.Smp_Type_Code),"
  3075. +" '3',"
  3076. +" '件件取样',"
  3077. +" '1',"
  3078. +" '复样',"
  3079. +" '0',"
  3080. +" '初样')"
  3081. +" from qcm_jhy_sample_consign_d a"
  3082. +" where a.specimen_no in"
  3083. +" (SELECT z.specimen_no"
  3084. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  3085. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  3086. +" ((SELECT z.cert_inst_name"
  3087. +" FROM qcm_judge_physical Z"
  3088. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  3089. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  3090. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  3091. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time "
  3092. +" from qcm_judge_locking a, qcm_judge_surface b,tbh02_coil_comm c"
  3093. +" where 1 = 1"
  3094. +" and a.lock_id = b.surface_id(+)"
  3095. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  3096. +" union all"
  3097. +" select a.material_no,"
  3098. +" lock_type_desc,"
  3099. +" lock_memo,"
  3100. +" UNLOCK_TYPE_CODE,"
  3101. +" UNLOCK_TYPE_DESC,"
  3102. +" a.lock_seq,"
  3103. +" a.lock_type_code,"
  3104. +" a.lock_type_desc,"
  3105. +" a.lock_memo,"
  3106. +" UNLOCK_MEMO,"
  3107. +" TARGET_DESIGN_KEY,"
  3108. +" TARGET_PSC,"
  3109. +" UNLOCK_NAME,"
  3110. +" a.heat_no,"
  3111. +" a.batch_no,"
  3112. +" a.board_no,"
  3113. +" a.plan_no,"
  3114. +" a.ht_no,"
  3115. +" a.design_key,"
  3116. +" a.psc,"
  3117. +" a.pline_code,"
  3118. +" a.pline_name,"
  3119. +" a.lock_name,"
  3120. +" UNLOCK_TIME,"
  3121. +" a.lock_id,"
  3122. +" a.lock_time,"
  3123. +" a.psc_desc,"
  3124. +" a.prod_code,"
  3125. +" a.prod_name,"
  3126. +" a.steel_code,"
  3127. +" a.steel_name,"
  3128. +" a.std_code,"
  3129. +" decode(a.lock_type_code,"
  3130. +" 'F',"
  3131. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  3132. +" '') sf_type,"
  3133. +" a.std_name,"
  3134. +" (select decode(max(a.Smp_Type_Code),"
  3135. +" '3',"
  3136. +" '件件取样',"
  3137. +" '1',"
  3138. +" '复样',"
  3139. +" '0',"
  3140. +" '初样')"
  3141. +" from qcm_jhy_sample_consign_d a"
  3142. +" where a.specimen_no in"
  3143. +" (SELECT z.specimen_no"
  3144. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  3145. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  3146. +" ((SELECT z.cert_inst_name"
  3147. +" FROM qcm_judge_physical Z"
  3148. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  3149. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  3150. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  3151. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time "
  3152. +" from qcm_judge_locking a, qcm_judge_surface b,c_tbl02_coil_comm c"
  3153. +" where 1 = 1"
  3154. +" and a.lock_id = b.surface_id(+)"
  3155. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  3156. +" union all"
  3157. +" select a.material_no,"
  3158. +" lock_type_desc,"
  3159. +" lock_memo,"
  3160. +" UNLOCK_TYPE_CODE,"
  3161. +" UNLOCK_TYPE_DESC,"
  3162. +" a.lock_seq,"
  3163. +" a.lock_type_code,"
  3164. +" a.lock_type_desc,"
  3165. +" a.lock_memo,"
  3166. +" UNLOCK_MEMO,"
  3167. +" TARGET_DESIGN_KEY,"
  3168. +" TARGET_PSC,"
  3169. +" UNLOCK_NAME,"
  3170. +" a.heat_no,"
  3171. +" a.batch_no,"
  3172. +" a.board_no,"
  3173. +" a.plan_no,"
  3174. +" a.ht_no,"
  3175. +" a.design_key,"
  3176. +" a.psc,"
  3177. +" a.pline_code,"
  3178. +" a.pline_name,"
  3179. +" a.lock_name,"
  3180. +" UNLOCK_TIME,"
  3181. +" a.lock_id,"
  3182. +" a.lock_time,"
  3183. +" a.psc_desc,"
  3184. +" a.prod_code,"
  3185. +" a.prod_name,"
  3186. +" a.steel_code,"
  3187. +" a.steel_name,"
  3188. +" a.std_code,"
  3189. +" decode(a.lock_type_code,"
  3190. +" 'F',"
  3191. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  3192. +" '') sf_type,"
  3193. +" a.std_name,"
  3194. +" (select decode(max(a.Smp_Type_Code),"
  3195. +" '3',"
  3196. +" '件件取样',"
  3197. +" '1',"
  3198. +" '复样',"
  3199. +" '0',"
  3200. +" '初样')"
  3201. +" from qcm_jhy_sample_consign_d a"
  3202. +" where a.specimen_no in"
  3203. +" (SELECT z.specimen_no"
  3204. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  3205. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  3206. +" ((SELECT z.cert_inst_name"
  3207. +" FROM qcm_judge_physical Z"
  3208. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  3209. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  3210. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select b.psc from qcm_ord_design_std_cic b where b.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  3211. +" from qcm_judge_locking a, qcm_judge_surface b,c_tbc02_coil_comm c"
  3212. +" where 1 = 1"
  3213. +" and a.lock_id = b.surface_id(+)"
  3214. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+"";
  3215. System.out.print(sql);
  3216. List<HashMap> listqjb = mapper.query(sql);
  3217. cro.setResult(listqjb);
  3218. } catch (Exception e) {
  3219. cro.setV_errCode(-1);
  3220. cro.setV_errMsg("查询失败!"+e.getMessage());
  3221. logger.info(e.getMessage());
  3222. }
  3223. SqlSession.close();
  3224. return cro;
  3225. }
  3226. /**
  3227. * 异常材处理:处置记录查询
  3228. * @param sum
  3229. * @return
  3230. */
  3231. @SuppressWarnings({ "rawtypes", "unchecked" })
  3232. public CoreReturnObject getAbnormalRecordInfo2JS(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String judge_type,String lock_type_desc) {
  3233. String conn="unlock_type_code is not null";
  3234. String swhere = "";
  3235. try {
  3236. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  3237. String sky=StrSky(begintime,endtime);
  3238. if(!sky.equals("TRUE")){
  3239. SqlSession.close();
  3240. cro.setV_errCode(-1);
  3241. cro.setV_errMsg(sky);
  3242. return cro;
  3243. }
  3244. }
  3245. if (!SqlJoint.IsNullOrSpace(design_key)) {
  3246. conn+=" and a.design_key like '%"+design_key+"%'";
  3247. }
  3248. if (!SqlJoint.IsNullOrSpace(psc)) {
  3249. conn+=" and psc like '%"+psc+"%'";
  3250. }
  3251. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  3252. conn+=" and to_date(to_char(unlock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  3253. }
  3254. if(type.equals("5")){
  3255. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  3256. conn += " and a.material_no like '%"+sbatchno+"%'";
  3257. }
  3258. if(!SqlJoint.IsNullOrSpace(ebatchno)){
  3259. if(ebatchno.equals("4mm分条机组")){
  3260. swhere += " and MACHINE_CODE = 'M0001'";
  3261. }else if(ebatchno.equals("12mm分条机组")){
  3262. swhere += " and MACHINE_CODE = 'M0002'";
  3263. }else if(ebatchno.equals("3mm横剪机组")){
  3264. swhere += " and MACHINE_CODE = 'M0003'";
  3265. }else if(ebatchno.equals("退火炉宝信")){
  3266. swhere += " and MACHINE_CODE = 'M0004'";
  3267. }else if(ebatchno.equals("退火炉南方D")){
  3268. swhere += " and MACHINE_CODE = 'M0005'";
  3269. }else if(ebatchno.equals("退火炉艾伯纳")){
  3270. swhere += " and MACHINE_CODE = 'M0006'";
  3271. }else if(ebatchno.equals("平整机组")){
  3272. swhere += " and MACHINE_CODE = 'M0007'";
  3273. }else if(ebatchno.equals("轧机机组")){
  3274. swhere += " and MACHINE_CODE = 'M0008'";
  3275. }else if(ebatchno.equals("退火炉南方G")){
  3276. swhere += " and MACHINE_CODE = 'M0009'";
  3277. }else if(ebatchno.equals("酸洗机组")){
  3278. swhere += " and MACHINE_CODE = 'M0010'";
  3279. }
  3280. }
  3281. }else{
  3282. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  3283. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  3284. }
  3285. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  3286. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  3287. }
  3288. }
  3289. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  3290. if(lock_type_desc.equals("成分判定")){
  3291. conn += " and a.lock_type_code = 'C'";
  3292. }else if(lock_type_desc.equals("材质判定")){
  3293. conn += " and a.lock_type_code = 'P'";
  3294. }else if(lock_type_desc.equals("表面检验")){
  3295. conn += " and a.lock_type_code = 'F'";
  3296. }else if(lock_type_desc.equals("公差检验")){
  3297. conn += " and a.lock_type_code = 'S'";
  3298. }else if(lock_type_desc.equals("工艺检验")){
  3299. conn += " and a.lock_type_code = 'T'";
  3300. }
  3301. else
  3302. {
  3303. conn+= " and a.lock_type_code = 'D'";
  3304. }
  3305. }
  3306. conn += " and status in ('2') ";
  3307. if(!SqlJoint.IsNullOrSpace(type)){
  3308. //卷板
  3309. if(type.equals("0")){
  3310. conn += " and a.pline_code in ('LT1','SZ1','RZ1')";
  3311. }
  3312. //中厚板
  3313. else if(type.equals("1")){
  3314. conn += " and a.pline_code in ('ZB1','HB1')";
  3315. }
  3316. //线棒
  3317. else if(type.equals("2")){
  3318. conn += " and a.pline_code in ('GX1','BC1','BC2','GX2','4001GX1','4001GX2','4001BC2')";
  3319. }
  3320. else if(type.equals("3")){
  3321. conn += " and a.pline_code in ('4001LG0')";
  3322. }
  3323. else if(type.equals("4")){
  3324. conn += " and a.pline_code in ('4001LGX')";
  3325. }
  3326. else if(type.equals("5")){
  3327. conn += " and a.pline_code in ('YT1')";
  3328. }
  3329. }
  3330. if(prodline.equals("中板线")){
  3331. conn += " and a.pline_code in ('ZB1') ";
  3332. }else if(prodline.equals("厚板线")){
  3333. conn += " and a.pline_code in ('HB1') ";
  3334. }else if(prodline.equals("热连轧")){
  3335. conn += " and a.pline_code in ('RZ1') ";
  3336. }else if(prodline.equals("酸轧")){
  3337. conn += " and a.pline_code in ('SZ1') ";
  3338. }else if(prodline.equals("连退")){
  3339. conn += " and a.pline_code in ('LT1') ";
  3340. }else if(prodline.equals("高棒")){
  3341. conn += " and a.pline_code in ('GX1','4001GX1') ";
  3342. }else if(prodline.equals("棒二")){
  3343. conn += " and a.pline_code in ('BC2','4001BC2') ";
  3344. }else if(prodline.equals("高线")){
  3345. conn += " and a.pline_code in ('GX2','4001GX2') ";
  3346. }else if(prodline.equals("优特")){
  3347. conn += " and a.pline_code in ('YT1') ";
  3348. }
  3349. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  3350. if(StringUtils.isNotEmpty(judge_type)){
  3351. if("1".equals(judge_type)) {
  3352. conn += " and a.lock_type_code in ('C','P','D') ";
  3353. } else if("2".equals(judge_type)) {
  3354. conn += " and a.lock_type_code in ('S','F') ";
  3355. }
  3356. }
  3357. //conn += "order by unlock_time desc";
  3358. /*String sql = "select a.material_no,lock_type_desc,lock_memo,UNLOCK_TYPE_CODE,UNLOCK_TYPE_DESC, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,"
  3359. + " UNLOCK_MEMO,TARGET_DESIGN_KEY,TARGET_PSC,UNLOCK_NAME,a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  3360. + " a.psc, a.pline_code, a.pline_name, a.lock_name,UNLOCK_TIME, "
  3361. + " a.lock_id,a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, decode(a.lock_type_code, 'F', decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''), '') sf_type, "
  3362. + " a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  3363. + " where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  3364. + " ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name from qcm_judge_locking a, qcm_judge_surface b where 1 = 1 and a.lock_id = b.surface_id(+) and "+conn+"";*/
  3365. String sql = "select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no,"
  3366. +" lock_type_desc,a.check_name,a.check_time,"
  3367. +" lock_memo,"
  3368. +" UNLOCK_TYPE_CODE,"
  3369. +" UNLOCK_TYPE_DESC,"
  3370. +" a.lock_seq,"
  3371. +" a.lock_type_code,"
  3372. +" a.lock_type_desc,"
  3373. +" a.lock_memo,"
  3374. +" UNLOCK_MEMO,"
  3375. +" TARGET_DESIGN_KEY,"
  3376. +" TARGET_PSC,"
  3377. +" UNLOCK_NAME,"
  3378. +" a.heat_no,"
  3379. +" a.batch_no,"
  3380. +" a.board_no,"
  3381. +" a.plan_no,"
  3382. +" a.ht_no,"
  3383. +" a.design_key,"
  3384. +" a.psc,"
  3385. +" a.pline_code,"
  3386. +" a.pline_name,"
  3387. +" a.lock_name,"
  3388. +" UNLOCK_TIME,"
  3389. +" a.lock_id,"
  3390. +" a.lock_time,"
  3391. +" a.psc_desc,"
  3392. +" a.prod_code,"
  3393. +" a.prod_name,"
  3394. +" a.steel_code,"
  3395. +" a.steel_name,"
  3396. +" a.std_code,"
  3397. +" decode(a.lock_type_code,"
  3398. +" 'F',"
  3399. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  3400. +" '') sf_type,"
  3401. +" a.std_name,"
  3402. +" (select decode(max(a.Smp_Type_Code),"
  3403. +" '3',"
  3404. +" '件件取样',"
  3405. +" '1',"
  3406. +" '复样',"
  3407. +" '0',"
  3408. +" '初样')"
  3409. +" from qcm_jhy_sample_consign_d a"
  3410. +" where a.specimen_no in"
  3411. +" (SELECT z.specimen_no"
  3412. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  3413. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  3414. +" ((SELECT z.cert_inst_name"
  3415. +" FROM qcm_judge_physical Z"
  3416. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  3417. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  3418. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  3419. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time "
  3420. +" from qcm_judge_locking a, qcm_judge_surface b,tbh02_coil_comm c"
  3421. +" where 1 = 1"
  3422. +" and a.lock_id = b.surface_id(+)"
  3423. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  3424. +" union all"
  3425. +" select a.material_no,"
  3426. +" lock_type_desc,a.check_name,a.check_time,"
  3427. +" lock_memo,"
  3428. +" UNLOCK_TYPE_CODE,"
  3429. +" UNLOCK_TYPE_DESC,"
  3430. +" a.lock_seq,"
  3431. +" a.lock_type_code,"
  3432. +" a.lock_type_desc,"
  3433. +" a.lock_memo,"
  3434. +" UNLOCK_MEMO,"
  3435. +" TARGET_DESIGN_KEY,"
  3436. +" TARGET_PSC,"
  3437. +" UNLOCK_NAME,"
  3438. +" a.heat_no,"
  3439. +" a.batch_no,"
  3440. +" a.board_no,"
  3441. +" a.plan_no,"
  3442. +" a.ht_no,"
  3443. +" a.design_key,"
  3444. +" a.psc,"
  3445. +" a.pline_code,"
  3446. +" a.pline_name,"
  3447. +" a.lock_name,"
  3448. +" UNLOCK_TIME,"
  3449. +" a.lock_id,"
  3450. +" a.lock_time,"
  3451. +" a.psc_desc,"
  3452. +" a.prod_code,"
  3453. +" a.prod_name,"
  3454. +" a.steel_code,"
  3455. +" a.steel_name,"
  3456. +" a.std_code,"
  3457. +" decode(a.lock_type_code,"
  3458. +" 'F',"
  3459. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  3460. +" '') sf_type,"
  3461. +" a.std_name,"
  3462. +" (select decode(max(a.Smp_Type_Code),"
  3463. +" '3',"
  3464. +" '件件取样',"
  3465. +" '1',"
  3466. +" '复样',"
  3467. +" '0',"
  3468. +" '初样')"
  3469. +" from qcm_jhy_sample_consign_d a"
  3470. +" where a.specimen_no in"
  3471. +" (SELECT z.specimen_no"
  3472. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  3473. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  3474. +" ((SELECT z.cert_inst_name"
  3475. +" FROM qcm_judge_physical Z"
  3476. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  3477. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  3478. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  3479. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time "
  3480. +" from qcm_judge_locking a, qcm_judge_surface b,c_tbl02_coil_comm c"
  3481. +" where 1 = 1"
  3482. +" and a.lock_id = b.surface_id(+)"
  3483. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  3484. +" union all"
  3485. +" select a.material_no,"
  3486. +" lock_type_desc,a.check_name,a.check_time,"
  3487. +" lock_memo,"
  3488. +" UNLOCK_TYPE_CODE,"
  3489. +" UNLOCK_TYPE_DESC,"
  3490. +" a.lock_seq,"
  3491. +" a.lock_type_code,"
  3492. +" a.lock_type_desc,"
  3493. +" a.lock_memo,"
  3494. +" UNLOCK_MEMO,"
  3495. +" TARGET_DESIGN_KEY,"
  3496. +" TARGET_PSC,"
  3497. +" UNLOCK_NAME,"
  3498. +" a.heat_no,"
  3499. +" a.batch_no,"
  3500. +" a.board_no,"
  3501. +" a.plan_no,"
  3502. +" a.ht_no,"
  3503. +" a.design_key,"
  3504. +" a.psc,"
  3505. +" a.pline_code,"
  3506. +" a.pline_name,"
  3507. +" a.lock_name,"
  3508. +" UNLOCK_TIME,"
  3509. +" a.lock_id,"
  3510. +" a.lock_time,"
  3511. +" a.psc_desc,"
  3512. +" a.prod_code,"
  3513. +" a.prod_name,"
  3514. +" a.steel_code,"
  3515. +" a.steel_name,"
  3516. +" a.std_code,"
  3517. +" decode(a.lock_type_code,"
  3518. +" 'F',"
  3519. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  3520. +" '') sf_type,"
  3521. +" a.std_name,"
  3522. +" (select decode(max(a.Smp_Type_Code),"
  3523. +" '3',"
  3524. +" '件件取样',"
  3525. +" '1',"
  3526. +" '复样',"
  3527. +" '0',"
  3528. +" '初样')"
  3529. +" from qcm_jhy_sample_consign_d a"
  3530. +" where a.specimen_no in"
  3531. +" (SELECT z.specimen_no"
  3532. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  3533. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  3534. +" ((SELECT z.cert_inst_name"
  3535. +" FROM qcm_judge_physical Z"
  3536. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  3537. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  3538. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select b.psc from qcm_ord_design_std_cic b where b.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX "
  3539. +" from qcm_judge_locking a, qcm_judge_surface b,c_tbc02_coil_comm c"
  3540. +" where 1 = 1"
  3541. +" and a.lock_id = b.surface_id(+)"
  3542. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+"";
  3543. System.out.print(sql);
  3544. List<HashMap> listqjb = mapper.query(sql);
  3545. cro.setResult(listqjb);
  3546. } catch (Exception e) {
  3547. cro.setV_errCode(-1);
  3548. cro.setV_errMsg("查询失败!"+e.getMessage());
  3549. logger.info(e.getMessage());
  3550. }
  3551. SqlSession.close();
  3552. return cro;
  3553. }
  3554. /**
  3555. * 异常材处理:处置记录查询
  3556. * @param sum
  3557. * @return
  3558. */
  3559. @SuppressWarnings({ "rawtypes", "unchecked" })
  3560. public CoreReturnObject getAbnormalRecordInfoJ(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String lock_type_desc) {
  3561. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  3562. String sky=StrSky(begintime,endtime);
  3563. if(!sky.equals("TRUE")){
  3564. SqlSession.close();
  3565. cro.setV_errCode(-1);
  3566. cro.setV_errMsg(sky);
  3567. return cro;
  3568. }
  3569. }
  3570. String conn="unlock_type_code is not null";
  3571. String swhere = "";
  3572. try {
  3573. if (!SqlJoint.IsNullOrSpace(design_key)) {
  3574. conn+=" and a.design_key like '%"+design_key+"%'";
  3575. }
  3576. if (!SqlJoint.IsNullOrSpace(psc)) {
  3577. conn+=" and psc like '%"+psc+"%'";
  3578. }
  3579. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  3580. conn+=" and to_date(to_char(unlock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  3581. }
  3582. if(type.equals("5")){
  3583. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  3584. conn += " and a.material_no like '%"+sbatchno+"%'";
  3585. }
  3586. if(!SqlJoint.IsNullOrSpace(ebatchno)){
  3587. if(ebatchno.equals("4mm分条机组")){
  3588. swhere += " and MACHINE_CODE = 'M0001'";
  3589. }else if(ebatchno.equals("12mm分条机组")){
  3590. swhere += " and MACHINE_CODE = 'M0002'";
  3591. }else if(ebatchno.equals("3mm横剪机组")){
  3592. swhere += " and MACHINE_CODE = 'M0003'";
  3593. }else if(ebatchno.equals("退火炉宝信")){
  3594. swhere += " and MACHINE_CODE = 'M0004'";
  3595. }else if(ebatchno.equals("退火炉南方D")){
  3596. swhere += " and MACHINE_CODE = 'M0005'";
  3597. }else if(ebatchno.equals("退火炉艾伯纳")){
  3598. swhere += " and MACHINE_CODE = 'M0006'";
  3599. }else if(ebatchno.equals("平整机组")){
  3600. swhere += " and MACHINE_CODE = 'M0007'";
  3601. }else if(ebatchno.equals("轧机机组")){
  3602. swhere += " and MACHINE_CODE = 'M0008'";
  3603. }else if(ebatchno.equals("退火炉南方G")){
  3604. swhere += " and MACHINE_CODE = 'M0009'";
  3605. }else if(ebatchno.equals("酸洗机组")){
  3606. swhere += " and MACHINE_CODE = 'M0010'";
  3607. }
  3608. }
  3609. }else{
  3610. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  3611. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  3612. }
  3613. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  3614. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  3615. }
  3616. }
  3617. conn += " and status in ('0','1','2','3') ";
  3618. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  3619. if(lock_type_desc.equals("成分判定")){
  3620. conn += " and a.lock_type_code = 'C'";
  3621. }else if(lock_type_desc.equals("材质判定")){
  3622. conn += " and a.lock_type_code = 'P'";
  3623. }else if(lock_type_desc.equals("表面检验")){
  3624. conn += " and a.lock_type_code = 'F'";
  3625. }else if(lock_type_desc.equals("公差检验")){
  3626. conn += " and a.lock_type_code = 'S'";
  3627. }else if(lock_type_desc.equals("工艺检验")){
  3628. conn += " and a.lock_type_code = 'T'";
  3629. }
  3630. else
  3631. {
  3632. conn+= " and a.lock_type_code = 'D'";
  3633. }
  3634. }
  3635. if(!SqlJoint.IsNullOrSpace(type)){
  3636. //卷板
  3637. if(type.equals("0")){
  3638. conn += " and a.pline_code in ('LT1','SZ1','RZ1')";
  3639. }
  3640. //中厚板
  3641. else if(type.equals("1")){
  3642. conn += " and a.pline_code in ('ZB1','HB1')";
  3643. }
  3644. //线棒
  3645. else if(type.equals("2")){
  3646. conn += " and a.pline_code in ('GX1','BC1','BC2','GX2','4001GX1','4001GX2','4001BC2')";
  3647. }
  3648. else if(type.equals("3")){
  3649. conn += " and a.pline_code in ('4001LG0')";
  3650. }
  3651. else if(type.equals("4")){
  3652. conn += " and a.pline_code in ('4001LGX')";
  3653. }
  3654. else if(type.equals("5")){
  3655. conn += " and a.pline_code in ('YT1')";
  3656. }
  3657. }
  3658. if(prodline.equals("中板线")){
  3659. conn += " and a.pline_code in ('ZB1') ";
  3660. }else if(prodline.equals("厚板线")){
  3661. conn += " and a.pline_code in ('HB1') ";
  3662. }else if(prodline.equals("热连轧")){
  3663. conn += " and a.pline_code in ('RZ1') ";
  3664. }else if(prodline.equals("酸轧")){
  3665. conn += " and a.pline_code in ('SZ1') ";
  3666. }else if(prodline.equals("连退")){
  3667. conn += " and a.pline_code in ('LT1') ";
  3668. }else if(prodline.equals("高棒")){
  3669. conn += " and a.pline_code in ('GX1','4001GX1') ";
  3670. }else if(prodline.equals("棒二")){
  3671. conn += " and a.pline_code in ('BC2','4001BC2') ";
  3672. }else if(prodline.equals("高线")){
  3673. conn += " and a.pline_code in ('GX2','4001GX2') ";
  3674. }else if(prodline.equals("优特")){
  3675. conn += " and a.pline_code in ('YT1') ";
  3676. }
  3677. //conn += "order by unlock_time desc";
  3678. /*String sql = "select a.material_no,lock_type_desc,lock_memo,UNLOCK_TYPE_CODE,UNLOCK_TYPE_DESC, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,"
  3679. + " UNLOCK_MEMO,TARGET_DESIGN_KEY,TARGET_PSC,UNLOCK_NAME,a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  3680. + " a.psc, a.pline_code, a.pline_name, a.lock_name,UNLOCK_TIME, "
  3681. + " a.lock_id,a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, decode(a.lock_type_code, 'F', decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''), '') sf_type, "
  3682. + " a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  3683. + " where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  3684. + " ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name from qcm_judge_locking a, qcm_judge_surface b where 1 = 1 and a.lock_id = b.surface_id(+) and "+conn+"";*/
  3685. String sql ="";
  3686. if(!type.equals("5")){//241216 分优特
  3687. sql = "select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no,"
  3688. +" lock_type_desc,"
  3689. +" lock_memo,"
  3690. +" UNLOCK_TYPE_CODE,"
  3691. +" UNLOCK_TYPE_DESC,"
  3692. +" a.lock_seq,"
  3693. +" a.lock_type_code,"
  3694. +" a.lock_type_desc,"
  3695. +" a.lock_memo,"
  3696. +" UNLOCK_MEMO,"
  3697. +" TARGET_DESIGN_KEY,"
  3698. +" TARGET_PSC,"
  3699. +" UNLOCK_NAME,"
  3700. +" a.heat_no,"
  3701. +" a.batch_no,"
  3702. +" a.board_no,"
  3703. +" a.plan_no,"
  3704. +" a.ht_no,"
  3705. +" a.design_key,"
  3706. +" a.psc,"
  3707. +" a.pline_code,"
  3708. +" a.pline_name,"
  3709. +" a.lock_name,"
  3710. +" UNLOCK_TIME,"
  3711. +" a.lock_id,"
  3712. +" a.lock_time,"
  3713. +" a.psc_desc,"
  3714. +" a.prod_code,"
  3715. +" a.prod_name,"
  3716. +" a.steel_code,"
  3717. +" a.steel_name,"
  3718. +" a.std_code,"
  3719. +" decode(a.lock_type_code,"
  3720. +" 'F',"
  3721. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  3722. +" '') sf_type,"
  3723. +" a.std_name,"
  3724. +" (select decode(max(a.Smp_Type_Code),"
  3725. +" '3',"
  3726. +" '件件取样',"
  3727. +" '1',"
  3728. +" '复样',"
  3729. +" '0',"
  3730. +" '初样')"
  3731. +" from qcm_jhy_sample_consign_d a"
  3732. +" where a.specimen_no in"
  3733. +" (SELECT z.specimen_no"
  3734. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  3735. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  3736. +" ((SELECT z.cert_inst_name"
  3737. +" FROM qcm_judge_physical Z"
  3738. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  3739. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  3740. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  3741. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time "
  3742. +" from qcm_judge_locking a, qcm_judge_surface b,tbh02_coil_comm c"
  3743. +" where 1 = 1"
  3744. +" and a.lock_id = b.surface_id(+)"
  3745. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  3746. +" union all"
  3747. +" select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no,"
  3748. +" lock_type_desc,"
  3749. +" lock_memo,"
  3750. +" UNLOCK_TYPE_CODE,"
  3751. +" UNLOCK_TYPE_DESC,"
  3752. +" a.lock_seq,"
  3753. +" a.lock_type_code,"
  3754. +" a.lock_type_desc,"
  3755. +" a.lock_memo,"
  3756. +" UNLOCK_MEMO,"
  3757. +" TARGET_DESIGN_KEY,"
  3758. +" TARGET_PSC,"
  3759. +" UNLOCK_NAME,"
  3760. +" a.heat_no,"
  3761. +" a.batch_no,"
  3762. +" a.board_no,"
  3763. +" a.plan_no,"
  3764. +" a.ht_no,"
  3765. +" a.design_key,"
  3766. +" a.psc,"
  3767. +" a.pline_code,"
  3768. +" a.pline_name,"
  3769. +" a.lock_name,"
  3770. +" UNLOCK_TIME,"
  3771. +" a.lock_id,"
  3772. +" a.lock_time,"
  3773. +" a.psc_desc,"
  3774. +" a.prod_code,"
  3775. +" a.prod_name,"
  3776. +" a.steel_code,"
  3777. +" a.steel_name,"
  3778. +" a.std_code,"
  3779. +" decode(a.lock_type_code,"
  3780. +" 'F',"
  3781. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  3782. +" '') sf_type,"
  3783. +" a.std_name,"
  3784. +" (select decode(max(a.Smp_Type_Code),"
  3785. +" '3',"
  3786. +" '件件取样',"
  3787. +" '1',"
  3788. +" '复样',"
  3789. +" '0',"
  3790. +" '初样')"
  3791. +" from qcm_jhy_sample_consign_d a"
  3792. +" where a.specimen_no in"
  3793. +" (SELECT z.specimen_no"
  3794. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  3795. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  3796. +" ((SELECT z.cert_inst_name"
  3797. +" FROM qcm_judge_physical Z"
  3798. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  3799. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  3800. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  3801. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time "
  3802. +" from qcm_judge_locking a, qcm_judge_surface b,c_tbl02_coil_comm c"
  3803. +" where 1 = 1"
  3804. +" and a.lock_id = b.surface_id(+)"
  3805. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  3806. +" union all"
  3807. +" select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no,"
  3808. +" lock_type_desc,"
  3809. +" lock_memo,"
  3810. +" UNLOCK_TYPE_CODE,"
  3811. +" UNLOCK_TYPE_DESC,"
  3812. +" a.lock_seq,"
  3813. +" a.lock_type_code,"
  3814. +" a.lock_type_desc,"
  3815. +" a.lock_memo,"
  3816. +" UNLOCK_MEMO,"
  3817. +" TARGET_DESIGN_KEY,"
  3818. +" TARGET_PSC,"
  3819. +" UNLOCK_NAME,"
  3820. +" a.heat_no,"
  3821. +" a.batch_no,"
  3822. +" a.board_no,"
  3823. +" a.plan_no,"
  3824. +" a.ht_no,"
  3825. +" a.design_key,"
  3826. +" a.psc,"
  3827. +" a.pline_code,"
  3828. +" a.pline_name,"
  3829. +" a.lock_name,"
  3830. +" UNLOCK_TIME,"
  3831. +" a.lock_id,"
  3832. +" a.lock_time,"
  3833. +" a.psc_desc,"
  3834. +" a.prod_code,"
  3835. +" a.prod_name,"
  3836. +" a.steel_code,"
  3837. +" a.steel_name,"
  3838. +" a.std_code,"
  3839. +" decode(a.lock_type_code,"
  3840. +" 'F',"
  3841. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  3842. +" '') sf_type,"
  3843. +" a.std_name,"
  3844. +" (select decode(max(a.Smp_Type_Code),"
  3845. +" '3',"
  3846. +" '件件取样',"
  3847. +" '1',"
  3848. +" '复样',"
  3849. +" '0',"
  3850. +" '初样')"
  3851. +" from qcm_jhy_sample_consign_d a"
  3852. +" where a.specimen_no in"
  3853. +" (SELECT z.specimen_no"
  3854. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  3855. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  3856. +" ((SELECT z.cert_inst_name"
  3857. +" FROM qcm_judge_physical Z"
  3858. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  3859. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  3860. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  3861. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time "
  3862. +" from qcm_judge_locking a, qcm_judge_surface b,c_tbc02_coil_comm c"
  3863. +" where 1 = 1"
  3864. +" and a.lock_id = b.surface_id(+)"
  3865. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+"";
  3866. //+" union all"
  3867. }else{
  3868. sql =" select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no,"
  3869. +" lock_type_desc,"
  3870. +" lock_memo,"
  3871. +" UNLOCK_TYPE_CODE,"
  3872. +" UNLOCK_TYPE_DESC,"
  3873. +" a.lock_seq,"
  3874. +" a.lock_type_code,"
  3875. +" a.lock_type_desc,"
  3876. +" a.lock_memo,"
  3877. +" UNLOCK_MEMO,"
  3878. +" TARGET_DESIGN_KEY,"
  3879. +" TARGET_PSC,"
  3880. +" UNLOCK_NAME,"
  3881. +" a.heat_no,"
  3882. +" a.batch_no,"
  3883. +" a.board_no,"
  3884. +" a.plan_no,"
  3885. +" a.ht_no,"
  3886. +" a.design_key,"
  3887. +" a.psc,"
  3888. +" a.pline_code,"
  3889. +" a.pline_name,"
  3890. +" a.lock_name,"
  3891. +" UNLOCK_TIME,"
  3892. +" a.lock_id,"
  3893. +" a.lock_time,"
  3894. +" a.psc_desc,"
  3895. +" a.prod_code,"
  3896. +" a.prod_name,"
  3897. +" a.steel_code,"
  3898. +" a.steel_name,"
  3899. +" a.std_code,"
  3900. +" decode(a.lock_type_code,"
  3901. +" 'F',"
  3902. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  3903. +" '') sf_type,"
  3904. +" a.std_name,"
  3905. +" (select decode(max(a.Smp_Type_Code),"
  3906. +" '3',"
  3907. +" '件件取样',"
  3908. +" '1',"
  3909. +" '复样',"
  3910. +" '0',"
  3911. +" '初样')"
  3912. +" from qcm_jhy_sample_consign_d a"
  3913. +" where a.specimen_no in"
  3914. +" (SELECT z.specimen_no"
  3915. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  3916. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  3917. +" ((SELECT z.cert_inst_name"
  3918. +" FROM qcm_judge_physical Z"
  3919. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  3920. +" c.thick,c.width,c.length,c.DELIVERY_STATE_DESC,c.FACTWEIGHT/1000 weight,"
  3921. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  3922. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time "
  3923. +" from qcm_judge_locking a, qcm_judge_surface b,YDM_PRODUCT_DETAIL@LINK_YTG c"
  3924. +" where 1 = 1"
  3925. +" and a.lock_id = b.surface_id(+)"
  3926. +" and a.material_no = c.COILNO AND " +conn+swhere+"";
  3927. }
  3928. System.out.print(sql);
  3929. List<HashMap> listqjb = mapper.query(sql);
  3930. cro.setResult(listqjb);
  3931. } catch (Exception e) {
  3932. cro.setV_errCode(-1);
  3933. cro.setV_errMsg("查询失败!"+e.getMessage());
  3934. logger.info(e.getMessage());
  3935. }
  3936. SqlSession.close();
  3937. return cro;
  3938. }
  3939. /**
  3940. * 异常材处理:处置记录查询
  3941. * @param sum
  3942. * @return
  3943. */
  3944. @SuppressWarnings({ "rawtypes", "unchecked" })
  3945. public CoreReturnObject getAbnormalRecordInfoJS(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String lock_type_desc) {
  3946. String conn="status <> '0' and a.VALID_FLAG = '1' ";
  3947. String swhere = "";
  3948. try {
  3949. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  3950. String sky=StrSky(begintime,endtime);
  3951. if(!sky.equals("TRUE")){
  3952. SqlSession.close();
  3953. cro.setV_errCode(-1);
  3954. cro.setV_errMsg(sky);
  3955. return cro;
  3956. }
  3957. }
  3958. if (!SqlJoint.IsNullOrSpace(design_key)) {
  3959. conn+=" and a.design_key like '%"+design_key+"%'";
  3960. }
  3961. if (!SqlJoint.IsNullOrSpace(psc)) {
  3962. conn+=" and psc like '%"+psc+"%'";
  3963. }
  3964. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  3965. conn+=" and to_date(to_char(check_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  3966. }
  3967. if(type.equals("5")){
  3968. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  3969. conn += " and a.material_no like '%"+sbatchno+"%'";
  3970. }
  3971. if(!SqlJoint.IsNullOrSpace(ebatchno)){
  3972. if(ebatchno.equals("4mm分条机组")){
  3973. swhere += " and MACHINE_CODE = 'M0001'";
  3974. }else if(ebatchno.equals("12mm分条机组")){
  3975. swhere += " and MACHINE_CODE = 'M0002'";
  3976. }else if(ebatchno.equals("3mm横剪机组")){
  3977. swhere += " and MACHINE_CODE = 'M0003'";
  3978. }else if(ebatchno.equals("退火炉宝信")){
  3979. swhere += " and MACHINE_CODE = 'M0004'";
  3980. }else if(ebatchno.equals("退火炉南方D")){
  3981. swhere += " and MACHINE_CODE = 'M0005'";
  3982. }else if(ebatchno.equals("退火炉艾伯纳")){
  3983. swhere += " and MACHINE_CODE = 'M0006'";
  3984. }else if(ebatchno.equals("平整机组")){
  3985. swhere += " and MACHINE_CODE = 'M0007'";
  3986. }else if(ebatchno.equals("轧机机组")){
  3987. swhere += " and MACHINE_CODE = 'M0008'";
  3988. }else if(ebatchno.equals("退火炉南方G")){
  3989. swhere += " and MACHINE_CODE = 'M0009'";
  3990. }else if(ebatchno.equals("酸洗机组")){
  3991. swhere += " and MACHINE_CODE = 'M0010'";
  3992. }
  3993. }
  3994. }else{
  3995. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  3996. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  3997. }
  3998. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  3999. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  4000. }
  4001. }
  4002. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  4003. if(lock_type_desc.equals("成分判定")){
  4004. conn += " and a.lock_type_code = 'C'";
  4005. }else if(lock_type_desc.equals("材质判定")){
  4006. conn += " and a.lock_type_code = 'P'";
  4007. }else if(lock_type_desc.equals("表面检验")){
  4008. conn += " and a.lock_type_code = 'F'";
  4009. }else if(lock_type_desc.equals("公差检验")){
  4010. conn += " and a.lock_type_code = 'S'";
  4011. }else if(lock_type_desc.equals("工艺检验")){
  4012. conn += " and a.lock_type_code = 'T'";
  4013. }
  4014. else
  4015. {
  4016. conn+= " and a.lock_type_code = 'D'";
  4017. }
  4018. }
  4019. if(!SqlJoint.IsNullOrSpace(type)){
  4020. //卷板
  4021. if(type.equals("0")){
  4022. conn += " and a.pline_code in ('LT1','SZ1','RZ1')";
  4023. }
  4024. //中厚板
  4025. else if(type.equals("1")){
  4026. conn += " and a.pline_code in ('ZB1','HB1')";
  4027. }
  4028. //线棒
  4029. else if(type.equals("2")){
  4030. conn += " and a.pline_code in ('GX1','BC1','BC2','GX2','4001GX1','4001GX2','4001BC2')";
  4031. }
  4032. else if(type.equals("3")){
  4033. conn += " and a.pline_code in ('4001LG0')";
  4034. }
  4035. else if(type.equals("4")){
  4036. conn += " and a.pline_code in ('4001LGX')";
  4037. }
  4038. else if(type.equals("5")){
  4039. conn += " and a.pline_code in ('YT1')";
  4040. }
  4041. }
  4042. if(prodline.equals("中板线")){
  4043. conn += " and a.pline_code in ('ZB1') ";
  4044. }else if(prodline.equals("厚板线")){
  4045. conn += " and a.pline_code in ('HB1') ";
  4046. }else if(prodline.equals("热连轧")){
  4047. conn += " and a.pline_code in ('RZ1') ";
  4048. }else if(prodline.equals("酸轧")){
  4049. conn += " and a.pline_code in ('SZ1') ";
  4050. }else if(prodline.equals("连退")){
  4051. conn += " and a.pline_code in ('LT1') ";
  4052. }else if(prodline.equals("高棒")){
  4053. conn += " and a.pline_code in ('GX1','4001GX1') ";
  4054. }else if(prodline.equals("棒二")){
  4055. conn += " and a.pline_code in ('BC2','4001BC2') ";
  4056. }else if(prodline.equals("高线")){
  4057. conn += " and a.pline_code in ('GX2','4001GX2') ";
  4058. }else if(prodline.equals("优特")){
  4059. conn += " and a.pline_code in ('YT1') ";
  4060. }
  4061. //conn += "order by unlock_time desc";
  4062. /*String sql = "select a.material_no,lock_type_desc,lock_memo,UNLOCK_TYPE_CODE,UNLOCK_TYPE_DESC, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,"
  4063. + " UNLOCK_MEMO,TARGET_DESIGN_KEY,TARGET_PSC,UNLOCK_NAME,a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  4064. + " a.psc, a.pline_code, a.pline_name, a.lock_name,UNLOCK_TIME, "
  4065. + " a.lock_id,a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, decode(a.lock_type_code, 'F', decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''), '') sf_type, "
  4066. + " a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  4067. + " where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  4068. + " ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name from qcm_judge_locking a, qcm_judge_surface b where 1 = 1 and a.lock_id = b.surface_id(+) and "+conn+"";*/
  4069. String sql ="";
  4070. if(!type.equals("5")){//241216分优特
  4071. sql = "select apply_id,case when a.status = '1' then '审核通过' else '审核不通过' end status,a.material_no,"
  4072. +" lock_type_desc,a.check_name,a.check_time,"
  4073. +" lock_memo,"
  4074. +" UNLOCK_TYPE_CODE,"
  4075. +" UNLOCK_TYPE_DESC,"
  4076. +" a.lock_seq,"
  4077. +" a.lock_type_code,"
  4078. +" a.lock_type_desc,"
  4079. +" a.lock_memo,"
  4080. +" UNLOCK_MEMO,"
  4081. +" a.heat_no,"
  4082. +" a.batch_no,"
  4083. +" a.board_no,"
  4084. +" a.plan_no,"
  4085. +" a.ht_no,"
  4086. +" a.design_key,"
  4087. +" a.psc,"
  4088. +" a.pline_code,"
  4089. +" a.pline_name,"
  4090. +" a.create_name,"
  4091. +" a.lock_id,"
  4092. +" a.create_time,"
  4093. +" a.psc_desc,"
  4094. +" a.prod_code,"
  4095. +" a.prod_name,"
  4096. +" a.steel_code,"
  4097. +" a.steel_name,"
  4098. +" a.std_code,"
  4099. +" decode(a.lock_type_code,"
  4100. +" 'F',"
  4101. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  4102. +" '') sf_type,"
  4103. +" a.std_name,"
  4104. +" (select decode(max(a.Smp_Type_Code),"
  4105. +" '3',"
  4106. +" '件件取样',"
  4107. +" '1',"
  4108. +" '复样',"
  4109. +" '0',"
  4110. +" '初样')"
  4111. +" from qcm_jhy_sample_consign_d a"
  4112. +" where a.specimen_no in"
  4113. +" (SELECT z.specimen_no"
  4114. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  4115. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  4116. +" ((SELECT z.cert_inst_name"
  4117. +" FROM qcm_judge_physical Z"
  4118. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  4119. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  4120. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  4121. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time,a.HANDLE_MEMO "
  4122. +" from qcm_judge_locking_apply a, qcm_judge_surface b,tbh02_coil_comm c"
  4123. +" where 1 = 1"
  4124. +" and a.lock_id = b.surface_id(+)"
  4125. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  4126. +" union all"
  4127. +" select apply_id,case when a.status = '1' then '审核通过' else '审核不通过' end status,a.material_no,"
  4128. +" lock_type_desc,a.check_name,a.check_time,"
  4129. +" lock_memo,"
  4130. +" UNLOCK_TYPE_CODE,"
  4131. +" UNLOCK_TYPE_DESC,"
  4132. +" a.lock_seq,"
  4133. +" a.lock_type_code,"
  4134. +" a.lock_type_desc,"
  4135. +" a.lock_memo,"
  4136. +" UNLOCK_MEMO,"
  4137. +" a.heat_no,"
  4138. +" a.batch_no,"
  4139. +" a.board_no,"
  4140. +" a.plan_no,"
  4141. +" a.ht_no,"
  4142. +" a.design_key,"
  4143. +" a.psc,"
  4144. +" a.pline_code,"
  4145. +" a.pline_name,"
  4146. +" a.create_name,"
  4147. +" a.lock_id,"
  4148. +" a.create_time,"
  4149. +" a.psc_desc,"
  4150. +" a.prod_code,"
  4151. +" a.prod_name,"
  4152. +" a.steel_code,"
  4153. +" a.steel_name,"
  4154. +" a.std_code,"
  4155. +" decode(a.lock_type_code,"
  4156. +" 'F',"
  4157. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  4158. +" '') sf_type,"
  4159. +" a.std_name,"
  4160. +" (select decode(max(a.Smp_Type_Code),"
  4161. +" '3',"
  4162. +" '件件取样',"
  4163. +" '1',"
  4164. +" '复样',"
  4165. +" '0',"
  4166. +" '初样')"
  4167. +" from qcm_jhy_sample_consign_d a"
  4168. +" where a.specimen_no in"
  4169. +" (SELECT z.specimen_no"
  4170. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  4171. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  4172. +" ((SELECT z.cert_inst_name"
  4173. +" FROM qcm_judge_physical Z"
  4174. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  4175. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  4176. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  4177. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time,a.HANDLE_MEMO "
  4178. +" from qcm_judge_locking_apply a, qcm_judge_surface b,c_tbl02_coil_comm c"
  4179. +" where 1 = 1"
  4180. +" and a.lock_id = b.surface_id(+)"
  4181. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+""
  4182. +" union all"
  4183. +" select apply_id,case when a.status = '1' then '审核通过' else '审核不通过' end status,a.material_no,"
  4184. +" lock_type_desc,a.check_name,a.check_time,"
  4185. +" lock_memo,"
  4186. +" UNLOCK_TYPE_CODE,"
  4187. +" UNLOCK_TYPE_DESC,"
  4188. +" a.lock_seq,"
  4189. +" a.lock_type_code,"
  4190. +" a.lock_type_desc,"
  4191. +" a.lock_memo,"
  4192. +" UNLOCK_MEMO,"
  4193. +" a.heat_no,"
  4194. +" a.batch_no,"
  4195. +" a.board_no,"
  4196. +" a.plan_no,"
  4197. +" a.ht_no,"
  4198. +" a.design_key,"
  4199. +" a.psc,"
  4200. +" a.pline_code,"
  4201. +" a.pline_name,"
  4202. +" a.create_name,"
  4203. +" a.lock_id,"
  4204. +" a.create_time,"
  4205. +" a.psc_desc,"
  4206. +" a.prod_code,"
  4207. +" a.prod_name,"
  4208. +" a.steel_code,"
  4209. +" a.steel_name,"
  4210. +" a.std_code,"
  4211. +" decode(a.lock_type_code,"
  4212. +" 'F',"
  4213. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  4214. +" '') sf_type,"
  4215. +" a.std_name,"
  4216. +" (select decode(max(a.Smp_Type_Code),"
  4217. +" '3',"
  4218. +" '件件取样',"
  4219. +" '1',"
  4220. +" '复样',"
  4221. +" '0',"
  4222. +" '初样')"
  4223. +" from qcm_jhy_sample_consign_d a"
  4224. +" where a.specimen_no in"
  4225. +" (SELECT z.specimen_no"
  4226. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  4227. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  4228. +" ((SELECT z.cert_inst_name"
  4229. +" FROM qcm_judge_physical Z"
  4230. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  4231. +" c.INSTR_COIL_THK thick,c.INSTR_COIL_WTH width,c.INSTR_COIL_LEN length,c.PRODNM_CD DELIVERY_STATE_DESC,c.ACT_WGT/1000 weight,"
  4232. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  4233. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time,a.HANDLE_MEMO "
  4234. +" from qcm_judge_locking_apply a, qcm_judge_surface b,c_tbc02_coil_comm c"
  4235. +" where 1 = 1"
  4236. +" and a.lock_id = b.surface_id(+)"
  4237. +" and a.material_no = c.OLD_SAMPL_NO AND " +conn+"";
  4238. //+" union all"
  4239. }else{
  4240. sql=" select apply_id,case when a.status = '1' then '审核通过' else '审核不通过' end status,a.material_no,"
  4241. +" lock_type_desc,a.check_name,a.check_time,"
  4242. +" lock_memo,"
  4243. +" UNLOCK_TYPE_CODE,"
  4244. +" UNLOCK_TYPE_DESC,"
  4245. +" a.lock_seq,"
  4246. +" a.lock_type_code,"
  4247. +" a.lock_type_desc,"
  4248. +" a.lock_memo,"
  4249. +" UNLOCK_MEMO,"
  4250. +" a.heat_no,"
  4251. +" a.batch_no,"
  4252. +" a.board_no,"
  4253. +" a.plan_no,"
  4254. +" a.ht_no,"
  4255. +" a.design_key,"
  4256. +" a.psc,"
  4257. +" a.pline_code,"
  4258. +" a.pline_name,"
  4259. +" a.create_name,"
  4260. +" a.lock_id,"
  4261. +" a.create_time,"
  4262. +" a.psc_desc,"
  4263. +" a.prod_code,"
  4264. +" a.prod_name,"
  4265. +" a.steel_code,"
  4266. +" a.steel_name,"
  4267. +" a.std_code,"
  4268. +" decode(a.lock_type_code,"
  4269. +" 'F',"
  4270. +" decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  4271. +" '') sf_type,"
  4272. +" a.std_name,"
  4273. +" (select decode(max(a.Smp_Type_Code),"
  4274. +" '3',"
  4275. +" '件件取样',"
  4276. +" '1',"
  4277. +" '复样',"
  4278. +" '0',"
  4279. +" '初样')"
  4280. +" from qcm_jhy_sample_consign_d a"
  4281. +" where a.specimen_no in"
  4282. +" (SELECT z.specimen_no"
  4283. +" FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  4284. +" WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  4285. +" ((SELECT z.cert_inst_name"
  4286. +" FROM qcm_judge_physical Z"
  4287. +" WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  4288. +" c.thick,c.width,c.length,c.DELIVERY_STATE_DESC,c.FACTWEIGHT/1000 weight,"
  4289. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  4290. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time,a.HANDLE_MEMO "
  4291. +" from qcm_judge_locking_apply a, qcm_judge_surface b,YDM_PRODUCT_DETAIL@LINK_YTG c"
  4292. +" where 1 = 1"
  4293. +" and a.lock_id = b.surface_id(+)"
  4294. +" and a.material_no = c.COILNO AND " +conn+swhere+"";
  4295. }
  4296. System.out.print(sql);
  4297. List<HashMap> listqjb = mapper.query(sql);
  4298. cro.setResult(listqjb);
  4299. } catch (Exception e) {
  4300. cro.setV_errCode(-1);
  4301. cro.setV_errMsg("查询失败!"+e.getMessage());
  4302. logger.info(e.getMessage());
  4303. }
  4304. SqlSession.close();
  4305. return cro;
  4306. }
  4307. /**
  4308. * 异常材处理:处置记录查询
  4309. * @param sum
  4310. * @return
  4311. */
  4312. @SuppressWarnings({ "rawtypes", "unchecked" })
  4313. public CoreReturnObject getAbnormalRecordInfo2H(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String judge_type,String lock_type_desc,String heat_no,String type1) {
  4314. String conn="unlock_type_code is not null";
  4315. try {
  4316. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  4317. String sky=StrSky(begintime,endtime);
  4318. if(!sky.equals("TRUE")){
  4319. SqlSession.close();
  4320. cro.setV_errCode(-1);
  4321. cro.setV_errMsg(sky);
  4322. return cro;
  4323. }
  4324. }
  4325. if (!SqlJoint.IsNullOrSpace(design_key)) {
  4326. conn+=" and a.design_key like '%"+design_key+"%'";
  4327. }
  4328. if(type1.equals("1")){
  4329. conn+=" and a.design_key not like '19%'";
  4330. }else{
  4331. conn+=" and a.design_key like '19%'";
  4332. }
  4333. if (!SqlJoint.IsNullOrSpace(psc)) {
  4334. conn+=" and psc like '%"+psc+"%'";
  4335. }
  4336. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  4337. conn+=" and to_date(to_char(unlock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  4338. }
  4339. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  4340. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  4341. }
  4342. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  4343. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  4344. }
  4345. if(!SqlJoint.IsNullOrSpace(heat_no)){
  4346. conn += " and a.heat_no like '%"+heat_no+"%'";
  4347. }
  4348. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  4349. if(lock_type_desc.equals("成分判定")){
  4350. conn += " and a.lock_type_code = 'C'";
  4351. }else if(lock_type_desc.equals("材质判定")){
  4352. conn += " and a.lock_type_code = 'P'";
  4353. }else if(lock_type_desc.equals("表面检验")){
  4354. conn += " and a.lock_type_code = 'F'";
  4355. }else if(lock_type_desc.equals("公差检验")){
  4356. conn += " and a.lock_type_code = 'S'";
  4357. }else
  4358. {
  4359. conn+= " and a.lock_type_code = 'D'";
  4360. }
  4361. }
  4362. conn += " and status in ('0','1','3') ";
  4363. if(!SqlJoint.IsNullOrSpace(type)){
  4364. if(type.equals("1")){
  4365. conn += " and a.pline_code in ('ZB1','HB1')";
  4366. }
  4367. }
  4368. if(prodline.equals("中板线")){
  4369. conn += " and a.pline_code in ('ZB1') ";
  4370. }else if(prodline.equals("厚板线")){
  4371. conn += " and a.pline_code in ('HB1') ";
  4372. }
  4373. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  4374. if(StringUtils.isNotEmpty(judge_type)){
  4375. if("1".equals(judge_type)) {
  4376. conn += " and a.lock_type_code in ('C','P','D') ";
  4377. } else if("2".equals(judge_type)) {
  4378. conn += " and a.lock_type_code in ('S','F') ";
  4379. }
  4380. }
  4381. //conn += "order by unlock_time desc";
  4382. /*String sql = "select a.material_no,lock_type_desc,lock_memo,UNLOCK_TYPE_CODE,UNLOCK_TYPE_DESC, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,"
  4383. + " UNLOCK_MEMO,TARGET_DESIGN_KEY,TARGET_PSC,UNLOCK_NAME,a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  4384. + " a.psc, a.pline_code, a.pline_name, a.lock_name,UNLOCK_TIME, "
  4385. + " a.lock_id,a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, decode(a.lock_type_code, 'F', decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''), '') sf_type, "
  4386. + " a.std_name,(select decode(max(a.Smp_Type_Code),'3','件件取样','4','按母板取样', '1', '复样', '0', '初样') from qcm_jhy_sample_consign_d a "
  4387. + " where a.specimen_no in (SELECT z.specimen_no FROM QCM_JUDGE_PHYSICAL_RESULT Z WHERE Z.phy_id = A.LOCK_ID)) smp_type, "
  4388. + " ((SELECT z.cert_inst_name FROM qcm_judge_physical Z WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name from qcm_judge_locking a, qcm_judge_surface b where 1 = 1 and a.lock_id = b.surface_id(+) and "+conn+"";*/
  4389. String sql = "select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no, "
  4390. + " lock_type_desc, "
  4391. + " lock_memo,"
  4392. + " UNLOCK_TYPE_CODE,"
  4393. + " UNLOCK_TYPE_DESC,"
  4394. + " a.lock_seq,"
  4395. + " a.lock_type_code,"
  4396. + " a.lock_type_desc,"
  4397. + " a.lock_memo,"
  4398. + " UNLOCK_MEMO,"
  4399. + " TARGET_DESIGN_KEY,"
  4400. + " TARGET_PSC,"
  4401. + " UNLOCK_NAME,"
  4402. + " a.UNLOCK_RESULT,"
  4403. + " a.heat_no,"
  4404. + " a.batch_no,"
  4405. + " a.board_no,"
  4406. + " a.plan_no,"
  4407. + " A.ht_no,"
  4408. + " a.design_key,"
  4409. + " a.psc,"
  4410. + " a.pline_code,"
  4411. + " a.pline_name,"
  4412. + " a.lock_name,"
  4413. + " UNLOCK_TIME,"
  4414. + " a.lock_id,"
  4415. + " a.lock_time,"
  4416. + " a.psc_desc,"
  4417. + " a.prod_code,"
  4418. + " a.prod_name,"
  4419. + " a.steel_code,"
  4420. + " a.steel_name,"
  4421. + " a.std_code,"
  4422. + " decode(a.lock_type_code,"
  4423. + " 'F',"
  4424. + " decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  4425. + " '') sf_type,"
  4426. + " a.std_name,"
  4427. + " (select case when max(a.Smp_Type_Code) = '3' then '件件取样' when max(a.Smp_Type_Code) = '4' then '按母板取样' when max(a.Smp_Type_Code) = '1' then '复样' "
  4428. + " when max(a.Smp_Type_Code) = '0' and max(o.CERT_INST_CODE) in ('IC003', 'IC004','IC001', 'IC010', '5000') then "
  4429. + " '初样' when max(a.smp_no) is null then '' else '认证样' end from qcm_jhy_sample_consign_d a left join QCM_JHY_SAMPLE_R_ORD o on a.smp_no = o.smp_no"
  4430. + " where a.specimen_no in"
  4431. + " (SELECT z.specimen_no"
  4432. + " FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  4433. + " WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  4434. + " ((SELECT z.cert_inst_name"
  4435. + " FROM qcm_judge_physical Z"
  4436. + " WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  4437. + " c.ply thick,"
  4438. + " c.width,"
  4439. + " c.length,psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,"
  4440. + " c.PLANORDERNO,c.orderno,c.THEORYWEIGHT weight,"
  4441. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  4442. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time "
  4443. + " from qcm_judge_locking a, qcm_judge_surface b,kcz_turnofflist@xgcx c,sel_pactdetail@xgcx d"
  4444. + " where 1 = 1"
  4445. + " and a.lock_id = b.surface_id(+)"
  4446. + " and a.material_no = c.billetid(+)"
  4447. + " and d.orderno(+) = c.PLANORDERNO AND A.MATERIAL_NO LIKE 'Z%' AND "+conn+""
  4448. + " union all"
  4449. + " select a.material_no,"
  4450. + " lock_type_desc,"
  4451. + " lock_memo,"
  4452. + " UNLOCK_TYPE_CODE,"
  4453. + " UNLOCK_TYPE_DESC,"
  4454. + " a.lock_seq,"
  4455. + " a.lock_type_code,"
  4456. + " a.lock_type_desc,"
  4457. + " a.lock_memo,"
  4458. + " UNLOCK_MEMO,"
  4459. + " TARGET_DESIGN_KEY,"
  4460. + " TARGET_PSC,"
  4461. + " UNLOCK_NAME,"
  4462. + " a.UNLOCK_RESULT,"
  4463. + " a.heat_no,"
  4464. + " a.batch_no,"
  4465. + " a.board_no,"
  4466. + " a.plan_no,"
  4467. + " A.ht_no,"
  4468. + " a.design_key,"
  4469. + " a.psc,"
  4470. + " a.pline_code,"
  4471. + " a.pline_name,"
  4472. + " a.lock_name,"
  4473. + " UNLOCK_TIME,"
  4474. + " a.lock_id,"
  4475. + " a.lock_time,"
  4476. + " a.psc_desc,"
  4477. + " a.prod_code,"
  4478. + " a.prod_name,"
  4479. + " a.steel_code,"
  4480. + " a.steel_name,"
  4481. + " a.std_code,"
  4482. + " decode(a.lock_type_code,"
  4483. + " 'F',"
  4484. + " decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  4485. + " '') sf_type,"
  4486. + " a.std_name,"
  4487. + " (select case when max(a.Smp_Type_Code) = '3' then '件件取样' when max(a.Smp_Type_Code) = '4' then '按母板取样' when max(a.Smp_Type_Code) = '1' then '复样' "
  4488. + " when max(a.Smp_Type_Code) = '0' and max(o.CERT_INST_CODE) in ('IC003', 'IC004','IC001', 'IC010', '5000') then "
  4489. + " '初样' when max(a.smp_no) is null then '' else '认证样' end from qcm_jhy_sample_consign_d a left join QCM_JHY_SAMPLE_R_ORD o on a.smp_no = o.smp_no"
  4490. + " where a.specimen_no in"
  4491. + " (SELECT z.specimen_no"
  4492. + " FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  4493. + " WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  4494. + " ((SELECT z.cert_inst_name"
  4495. + " FROM qcm_judge_physical Z"
  4496. + " WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  4497. + " c.ply thick,"
  4498. + " c.width,"
  4499. + " c.length,psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,"
  4500. + " c.planorderform,c.allotorderform orderno,c.THEORYWEIGHT weight,"
  4501. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  4502. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time "
  4503. + " FROM qcm_judge_locking a, qcm_judge_surface b,kch_turnofflist@xgcx c,sel_pactdetail@xgcx d"
  4504. + " where 1 = 1"
  4505. + " and a.lock_id = b.surface_id(+)"
  4506. + " and a.material_no = c.billetid(+)"
  4507. + " and d.orderno(+) = c.planorderform AND A.MATERIAL_NO LIKE 'H%' AND "+conn+"";
  4508. System.out.print(sql);
  4509. List<HashMap> listqjb = mapper.query(sql);
  4510. cro.setResult(listqjb);
  4511. } catch (Exception e) {
  4512. cro.setV_errCode(-1);
  4513. cro.setV_errMsg("查询失败!"+e.getMessage());
  4514. logger.info(e.getMessage());
  4515. }
  4516. SqlSession.close();
  4517. return cro;
  4518. }
  4519. /**
  4520. * 异常材处理:处置记录查询
  4521. * @param sum
  4522. * @return
  4523. */
  4524. @SuppressWarnings({ "rawtypes", "unchecked" })
  4525. public CoreReturnObject getAbnormalRecordInfoH(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String lock_type_desc,String heat_no,String type1) {
  4526. String conn="unlock_type_code is not null";
  4527. try {
  4528. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  4529. String sky=StrSky(begintime,endtime);
  4530. if(!sky.equals("TRUE")){
  4531. SqlSession.close();
  4532. cro.setV_errCode(-1);
  4533. cro.setV_errMsg(sky);
  4534. return cro;
  4535. }
  4536. }
  4537. if (!SqlJoint.IsNullOrSpace(design_key)) {
  4538. conn+=" and a.design_key like '%"+design_key+"%'";
  4539. }
  4540. if(type1.equals("1")){
  4541. conn+=" and a.design_key not like '19%'";
  4542. }else{
  4543. conn+=" and a.design_key like '19%'";
  4544. }
  4545. if (!SqlJoint.IsNullOrSpace(psc)) {
  4546. conn+=" and psc like '%"+psc+"%'";
  4547. }
  4548. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  4549. conn+=" and to_date(to_char(unlock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  4550. }
  4551. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  4552. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  4553. }
  4554. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  4555. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  4556. }
  4557. if(!SqlJoint.IsNullOrSpace(heat_no)){
  4558. conn += " and a.heat_no like '%"+heat_no+"%'";
  4559. }
  4560. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  4561. if(lock_type_desc.equals("成分判定")){
  4562. conn += " and a.lock_type_code = 'C'";
  4563. }else if(lock_type_desc.equals("材质判定")){
  4564. conn += " and a.lock_type_code = 'P'";
  4565. }else if(lock_type_desc.equals("表面检验")){
  4566. conn += " and a.lock_type_code = 'F'";
  4567. }else if(lock_type_desc.equals("公差检验")){
  4568. conn += " and a.lock_type_code = 'S'";
  4569. }else
  4570. {
  4571. conn+= " and a.lock_type_code = 'D'";
  4572. }
  4573. }
  4574. if(!SqlJoint.IsNullOrSpace(type)){
  4575. if(type.equals("1")){
  4576. conn += " and a.pline_code in ('ZB1','HB1')";
  4577. }
  4578. }
  4579. conn += " and status in ('0','1','2','3') ";
  4580. if(prodline.equals("中板线")){
  4581. conn += " and a.pline_code in ('ZB1') ";
  4582. }else if(prodline.equals("厚板线")){
  4583. conn += " and a.pline_code in ('HB1') ";
  4584. }
  4585. //conn += "order by unlock_time desc";
  4586. String sql = "select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no, "
  4587. + " lock_type_desc, "
  4588. + " lock_memo,"
  4589. + " UNLOCK_TYPE_CODE,"
  4590. + " UNLOCK_TYPE_DESC,"
  4591. + " a.lock_seq,"
  4592. + " a.lock_type_code,"
  4593. + " a.lock_type_desc,"
  4594. + " a.lock_memo,"
  4595. + " UNLOCK_MEMO,"
  4596. + " TARGET_DESIGN_KEY,"
  4597. + " TARGET_PSC,"
  4598. + " UNLOCK_NAME,"
  4599. + " a.heat_no,"
  4600. + " a.batch_no,"
  4601. + " a.board_no,"
  4602. + " a.plan_no,"
  4603. + " A.ht_no,"
  4604. + " a.design_key,"
  4605. + " a.psc,"
  4606. + " a.pline_code,"
  4607. + " a.pline_name,"
  4608. + " a.lock_name,"
  4609. + " UNLOCK_TIME,"
  4610. + " a.lock_id,"
  4611. + " a.lock_time,"
  4612. + " a.UNLOCK_RESULT,"
  4613. + " a.psc_desc,"
  4614. + " a.prod_code,"
  4615. + " a.prod_name,"
  4616. + " a.steel_code,"
  4617. + " a.steel_name,"
  4618. + " a.std_code,"
  4619. + " decode(a.lock_type_code,"
  4620. + " 'F',"
  4621. + " decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  4622. + " '') sf_type,"
  4623. + " a.std_name,"
  4624. + " (select case when max(a.Smp_Type_Code) = '3' then '件件取样' when max(a.Smp_Type_Code) = '4' then '按母板取样' when max(a.Smp_Type_Code) = '1' then '复样' "
  4625. + " when max(a.Smp_Type_Code) = '0' and max(o.CERT_INST_CODE) in ('IC003', 'IC004','IC001', 'IC010', '5000') then "
  4626. + " '初样' when max(a.smp_no) is null then '' else '认证样' end from qcm_jhy_sample_consign_d a left join QCM_JHY_SAMPLE_R_ORD o on a.smp_no = o.smp_no"
  4627. + " where a.specimen_no in"
  4628. + " (SELECT z.specimen_no"
  4629. + " FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  4630. + " WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  4631. + " ((SELECT z.cert_inst_name"
  4632. + " FROM qcm_judge_physical Z"
  4633. + " WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  4634. + " c.ply thick,"
  4635. + " c.width,"
  4636. + " c.length,psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,"
  4637. + " c.PLANORDERNO,c.orderno,c.THEORYWEIGHT weight,"
  4638. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  4639. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time "
  4640. + " from qcm_judge_locking a, qcm_judge_surface b,kcz_turnofflist@xgcx c,sel_pactdetail@xgcx d"
  4641. + " where 1 = 1"
  4642. + " and a.lock_id = b.surface_id(+)"
  4643. + " and a.material_no = c.billetid(+)"
  4644. + " and d.orderno(+) = c.PLANORDERNO AND A.MATERIAL_NO LIKE 'Z%' AND " +conn+""
  4645. + " union all"
  4646. + " select case when a.status = '0' then '未申请' when a.status = '1' then '已申请' when a.status = '2' then '已审批' else '已回退' end status,a.material_no,"
  4647. + " lock_type_desc,"
  4648. + " lock_memo,"
  4649. + " UNLOCK_TYPE_CODE,"
  4650. + " UNLOCK_TYPE_DESC,"
  4651. + " a.lock_seq,"
  4652. + " a.lock_type_code,"
  4653. + " a.lock_type_desc,"
  4654. + " a.lock_memo,"
  4655. + " UNLOCK_MEMO,"
  4656. + " TARGET_DESIGN_KEY,"
  4657. + " TARGET_PSC,"
  4658. + " UNLOCK_NAME,"
  4659. + " a.heat_no,"
  4660. + " a.batch_no,"
  4661. + " a.board_no,"
  4662. + " a.plan_no,"
  4663. + " A.ht_no,"
  4664. + " a.design_key,"
  4665. + " a.psc,"
  4666. + " a.pline_code,"
  4667. + " a.pline_name,"
  4668. + " a.lock_name,"
  4669. + " UNLOCK_TIME,"
  4670. + " a.lock_id,"
  4671. + " a.lock_time,"
  4672. + " a.UNLOCK_RESULT,"
  4673. + " a.psc_desc,"
  4674. + " a.prod_code,"
  4675. + " a.prod_name,"
  4676. + " a.steel_code,"
  4677. + " a.steel_name,"
  4678. + " a.std_code,"
  4679. + " decode(a.lock_type_code,"
  4680. + " 'F',"
  4681. + " decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  4682. + " '') sf_type,"
  4683. + " a.std_name,"
  4684. + " (select case when max(a.Smp_Type_Code) = '3' then '件件取样' when max(a.Smp_Type_Code) = '4' then '按母板取样' when max(a.Smp_Type_Code) = '1' then '复样' "
  4685. + " when max(a.Smp_Type_Code) = '0' and max(o.CERT_INST_CODE) in ('IC003', 'IC004','IC001', 'IC010', '5000') then "
  4686. + " '初样' when max(a.smp_no) is null then '' else '认证样' end from qcm_jhy_sample_consign_d a left join QCM_JHY_SAMPLE_R_ORD o on a.smp_no = o.smp_no"
  4687. + " where a.specimen_no in"
  4688. + " (SELECT z.specimen_no"
  4689. + " FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  4690. + " WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  4691. + " ((SELECT z.cert_inst_name"
  4692. + " FROM qcm_judge_physical Z"
  4693. + " WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  4694. + " c.ply thick,"
  4695. + " c.width,"
  4696. + " c.length,psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,"
  4697. + " c.planorderform,c.allotorderform orderno,c.THEORYWEIGHT weight,"
  4698. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  4699. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time "
  4700. + " FROM qcm_judge_locking a, qcm_judge_surface b,kch_turnofflist@xgcx c,sel_pactdetail@xgcx d"
  4701. + " where 1 = 1"
  4702. + " and a.lock_id = b.surface_id(+)"
  4703. + " and a.material_no = c.billetid(+)"
  4704. + " and d.orderno(+) = c.planorderform AND A.MATERIAL_NO LIKE 'H%' AND "+conn+"";
  4705. System.out.print(sql);
  4706. List<HashMap> listqjb = mapper.query(sql);
  4707. cro.setResult(listqjb);
  4708. } catch (Exception e) {
  4709. cro.setV_errCode(-1);
  4710. cro.setV_errMsg("查询失败!"+e.getMessage());
  4711. logger.info(e.getMessage());
  4712. }
  4713. SqlSession.close();
  4714. return cro;
  4715. }
  4716. /**
  4717. * 异常材处理:处置记录查询
  4718. * @param sum
  4719. * @return
  4720. */
  4721. @SuppressWarnings({ "rawtypes", "unchecked" })
  4722. public CoreReturnObject getAbnormalRecordInfoHS(String begintime,String endtime,String sbatchno,String ebatchno,String design_key,String psc,String type,String prodline,String lock_type_desc,String heat_no,String type1) {
  4723. String conn="status <> '0'";
  4724. try {
  4725. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime) && SqlJoint.IsNullOrSpace(sbatchno)) {
  4726. String sky=StrSky(begintime,endtime);
  4727. if(!sky.equals("TRUE")){
  4728. SqlSession.close();
  4729. cro.setV_errCode(-1);
  4730. cro.setV_errMsg(sky);
  4731. return cro;
  4732. }
  4733. }
  4734. if (!SqlJoint.IsNullOrSpace(design_key)) {
  4735. conn+=" and a.design_key like '%"+design_key+"%'";
  4736. }
  4737. if(type1.equals("1")){
  4738. conn+=" and a.design_key not like '19%'";
  4739. }else{
  4740. conn+=" and a.design_key like '19%'";
  4741. }
  4742. if (!SqlJoint.IsNullOrSpace(psc)) {
  4743. conn+=" and psc like '%"+psc+"%'";
  4744. }
  4745. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  4746. conn+=" and to_date(to_char(check_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  4747. }
  4748. if (!SqlJoint.IsNullOrSpace(sbatchno)) {
  4749. conn += " and a.BATCH_NO >= '"+sbatchno+"'";
  4750. }
  4751. if (!SqlJoint.IsNullOrSpace(ebatchno)) {
  4752. conn += " and a.BATCH_NO <= '"+ebatchno+"'";
  4753. }
  4754. if(!SqlJoint.IsNullOrSpace(heat_no)){
  4755. conn += " and a.heat_no like '%"+heat_no+"%'";
  4756. }
  4757. if(!SqlJoint.IsNullOrSpace(lock_type_desc)){
  4758. if(lock_type_desc.equals("成分判定")){
  4759. conn += " and a.lock_type_code = 'C'";
  4760. }else if(lock_type_desc.equals("材质判定")){
  4761. conn += " and a.lock_type_code = 'P'";
  4762. }else if(lock_type_desc.equals("表面检验")){
  4763. conn += " and a.lock_type_code = 'F'";
  4764. }else if(lock_type_desc.equals("公差检验")){
  4765. conn += " and a.lock_type_code = 'S'";
  4766. }else
  4767. {
  4768. conn+= " and a.lock_type_code = 'D'";
  4769. }
  4770. }
  4771. if(!SqlJoint.IsNullOrSpace(type)){
  4772. if(type.equals("1")){
  4773. conn += " and a.pline_code in ('ZB1','HB1')";
  4774. }
  4775. }
  4776. if(prodline.equals("中板线")){
  4777. conn += " and a.pline_code in ('ZB1') ";
  4778. }else if(prodline.equals("厚板线")){
  4779. conn += " and a.pline_code in ('HB1') ";
  4780. }
  4781. //conn += "order by unlock_time desc";
  4782. String sql = "select a.apply_id,case when a.status = '1' then '审核通过' else '审核不通过' end status,a.material_no, "
  4783. + " lock_type_desc, "
  4784. + " lock_memo,"
  4785. + " UNLOCK_TYPE_CODE,"
  4786. + " UNLOCK_TYPE_DESC,"
  4787. + " a.lock_seq,"
  4788. + " a.lock_type_code,"
  4789. + " a.lock_type_desc,"
  4790. + " a.lock_memo,"
  4791. + " UNLOCK_MEMO,"
  4792. + " a.heat_no,"
  4793. + " a.batch_no,"
  4794. + " a.board_no,"
  4795. + " a.plan_no,"
  4796. + " A.ht_no,"
  4797. + " a.design_key,"
  4798. + " a.psc,"
  4799. + " a.pline_code,"
  4800. + " a.pline_name,"
  4801. + " a.create_name,"
  4802. + " a.check_name,"
  4803. + " check_time,"
  4804. + " a.lock_id,"
  4805. + " a.create_time,"
  4806. + " a.psc_desc,"
  4807. + " a.prod_code,"
  4808. + " a.prod_name,"
  4809. + " a.steel_code,"
  4810. + " a.steel_name,"
  4811. + " a.std_code,"
  4812. + " decode(a.lock_type_code,"
  4813. + " 'F',"
  4814. + " decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  4815. + " '') sf_type,"
  4816. + " a.std_name,"
  4817. + " (select case when max(a.Smp_Type_Code) = '3' then '件件取样' when max(a.Smp_Type_Code) = '4' then '按母板取样' when max(a.Smp_Type_Code) = '1' then '复样' "
  4818. + " when max(a.Smp_Type_Code) = '0' and max(o.CERT_INST_CODE) in ('IC003', 'IC004','IC001', 'IC010', '5000') then "
  4819. + " '初样' when max(a.smp_no) is null then '' else '认证样' end from qcm_jhy_sample_consign_d a left join QCM_JHY_SAMPLE_R_ORD o on a.smp_no = o.smp_no"
  4820. + " where a.specimen_no in"
  4821. + " (SELECT z.specimen_no"
  4822. + " FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  4823. + " WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  4824. + " ((SELECT z.cert_inst_name"
  4825. + " FROM qcm_judge_physical Z"
  4826. + " WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  4827. + " c.ply thick,"
  4828. + " c.width,"
  4829. + " c.length,psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,"
  4830. + " c.PLANORDERNO,c.orderno,c.THEORYWEIGHT weight,"
  4831. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  4832. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time,a.HANDLE_MEMO "
  4833. + " from qcm_judge_locking_apply a, qcm_judge_surface b,kcz_turnofflist@xgcx c,sel_pactdetail@xgcx d"
  4834. + " where 1 = 1"
  4835. + " and a.lock_id = b.surface_id(+)"
  4836. + " and a.material_no = c.billetid(+)"
  4837. + " and d.orderno(+) = c.PLANORDERNO AND A.MATERIAL_NO LIKE 'Z%' AND " +conn+""
  4838. + " union all"
  4839. + " select a.apply_id,case when a.status = '1' then '审核通过' else '审核不通过' end status,a.material_no,"
  4840. + " lock_type_desc,"
  4841. + " lock_memo,"
  4842. + " UNLOCK_TYPE_CODE,"
  4843. + " UNLOCK_TYPE_DESC,"
  4844. + " a.lock_seq,"
  4845. + " a.lock_type_code,"
  4846. + " a.lock_type_desc,"
  4847. + " a.lock_memo,"
  4848. + " UNLOCK_MEMO,"
  4849. + " a.heat_no,"
  4850. + " a.batch_no,"
  4851. + " a.board_no,"
  4852. + " a.plan_no,"
  4853. + " A.ht_no,"
  4854. + " a.design_key,"
  4855. + " a.psc,"
  4856. + " a.pline_code,"
  4857. + " a.pline_name,"
  4858. + " a.create_name,"
  4859. + " a.check_name,"
  4860. + " check_time,"
  4861. + " a.lock_id,"
  4862. + " a.create_time,"
  4863. + " a.psc_desc,"
  4864. + " a.prod_code,"
  4865. + " a.prod_name,"
  4866. + " a.steel_code,"
  4867. + " a.steel_name,"
  4868. + " a.std_code,"
  4869. + " decode(a.lock_type_code,"
  4870. + " 'F',"
  4871. + " decode(b.sf_type, 'U', '上表面', 'D', '下表面', ''),"
  4872. + " '') sf_type,"
  4873. + " a.std_name,"
  4874. + " (select case when max(a.Smp_Type_Code) = '3' then '件件取样' when max(a.Smp_Type_Code) = '4' then '按母板取样' when max(a.Smp_Type_Code) = '1' then '复样' "
  4875. + " when max(a.Smp_Type_Code) = '0' and max(o.CERT_INST_CODE) in ('IC003', 'IC004','IC001', 'IC010', '5000') then "
  4876. + " '初样' when max(a.smp_no) is null then '' else '认证样' end from qcm_jhy_sample_consign_d a left join QCM_JHY_SAMPLE_R_ORD o on a.smp_no = o.smp_no"
  4877. + " where a.specimen_no in"
  4878. + " (SELECT z.specimen_no"
  4879. + " FROM QCM_JUDGE_PHYSICAL_RESULT Z"
  4880. + " WHERE Z.phy_id = A.LOCK_ID)) smp_type,"
  4881. + " ((SELECT z.cert_inst_name"
  4882. + " FROM qcm_judge_physical Z"
  4883. + " WHERE Z.phy_id = A.LOCK_ID)) cert_inst_name,"
  4884. + " c.ply thick,"
  4885. + " c.width,"
  4886. + " c.length,psel_get_standroll@XGCX(d.STANDROLLER) DELIVERY_STATE_DESC,"
  4887. + " c.planorderform,c.allotorderform orderno,c.THEORYWEIGHT weight,"
  4888. + " (select x.unlock_name || x.unlock_type_desc from qcm_judge_locking x where x.material_no = a.board_no and x.design_key in ( select distinct z.design_key from qcm_ord_design_std_cic z where z.psc in (select y.psc from qcm_ord_design_std_cic y where y.design_key = a.design_key)) and a.lock_type_code = 'C' and x.unlock_type_code = '0' and rownum <=1) LG_FX, "
  4889. +" case when a.valid_flag = '1' then '有效' else '无效' end valid_flag,a.cancel_name,a.cancel_memo,TO_CHAR(A.cancel_time, 'yyyy-mm-dd hh24:mi:ss') cancel_time,a.HANDLE_MEMO "
  4890. + " FROM qcm_judge_locking_apply a, qcm_judge_surface b,kch_turnofflist@xgcx c,sel_pactdetail@xgcx d"
  4891. + " where 1 = 1"
  4892. + " and a.lock_id = b.surface_id(+)"
  4893. + " and a.material_no = c.billetid(+)"
  4894. + " and d.orderno(+) = c.planorderform AND A.MATERIAL_NO LIKE 'H%' AND "+conn+"";
  4895. System.out.print(sql);
  4896. List<HashMap> listqjb = mapper.query(sql);
  4897. cro.setResult(listqjb);
  4898. } catch (Exception e) {
  4899. cro.setV_errCode(-1);
  4900. cro.setV_errMsg("查询失败!"+e.getMessage());
  4901. logger.info(e.getMessage());
  4902. }
  4903. SqlSession.close();
  4904. return cro;
  4905. }
  4906. /**
  4907. * 炼钢异常审核记录
  4908. * @param sum
  4909. * @return
  4910. */
  4911. @SuppressWarnings({ "rawtypes", "unchecked" })
  4912. public CoreReturnObject getAbnormalRecordLgInfoS(String begintime,String endtime,String heatno,String material_no,String prod_name,String type) {
  4913. String conn="status <> '0'";
  4914. try {
  4915. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  4916. String sky=StrSky(begintime,endtime);
  4917. if(!sky.equals("TRUE")){
  4918. SqlSession.close();
  4919. cro.setV_errCode(-1);
  4920. cro.setV_errMsg(sky);
  4921. return cro;
  4922. }
  4923. }
  4924. if (!SqlJoint.IsNullOrSpace(heatno)) {
  4925. conn+=" and HEAT_NO like '%"+heatno+"%'";
  4926. }
  4927. if (!SqlJoint.IsNullOrSpace(material_no)) {
  4928. conn+=" and MATERIAL_NO like '%"+material_no+"%'";
  4929. }
  4930. if(!heatno.equals("") || !material_no.equals("")){
  4931. begintime = "";
  4932. endtime = "";
  4933. }
  4934. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  4935. conn+=" and to_date(to_char(check_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  4936. }
  4937. if (!SqlJoint.IsNullOrSpace(prod_name)) {
  4938. conn += " and PROD_NAME = '"+prod_name+"'";
  4939. }
  4940. conn += "order by check_time desc";
  4941. String sql = "select case when status = '1' then '审核通过' when status = '2' then '审核不通过' end status,apply_id, a.material_no,lock_type_desc,lock_memo,UNLOCK_TYPE_CODE,UNLOCK_TYPE_DESC, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,"
  4942. + " UNLOCK_MEMO,a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  4943. + " a.psc, a.pline_code, a.pline_name, a.create_name,to_char(check_time,'yyyy-mm-dd hh24:mi:ss') check_time, "
  4944. + " A.LOCK_ID,a.check_name, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  4945. + " a.std_name,a.HANDLE_MEMO from qcm_judge_locking_apply a where 1 = 1 and "+conn+"";
  4946. System.out.print(sql);
  4947. List<HashMap> listqjb = mapper.query(sql);
  4948. String material_no1 = "";
  4949. StringBuffer sqlucomm = new StringBuffer();
  4950. int j=0;
  4951. for(HashMap list1 : listqjb){
  4952. if(j>=900){
  4953. if(j% 900 == 0){
  4954. sqlucomm.append( ") or HEATNO in ('" + list1.get("MATERIAL_NO").toString()+"'") ;
  4955. }
  4956. else
  4957. {
  4958. if(sqlucomm.length() == 0){
  4959. sqlucomm.append( "('" + list1.get("MATERIAL_NO").toString()+"'");
  4960. }else{
  4961. sqlucomm.append( ",'"+ list1.get("MATERIAL_NO").toString()+"'");
  4962. }
  4963. }
  4964. j++;
  4965. }
  4966. else
  4967. {
  4968. if(sqlucomm.length() == 0){
  4969. sqlucomm.append( "('" + list1.get("MATERIAL_NO").toString()+"'");
  4970. }else{
  4971. sqlucomm.append(",'"+ list1.get("MATERIAL_NO").toString()+"'");
  4972. }
  4973. }
  4974. j++;
  4975. }
  4976. if(sqlucomm.length()==0)
  4977. sqlucomm.append("('')");
  4978. else
  4979. sqlucomm.append(")");
  4980. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  4981. List<HashMap> hashmap = (List<HashMap>) getLgjudgeInfobyMaterial_no1("", "", sqlucomm.toString(), type.equals("3")?"4001LG0":"4001LGX", prod_name, "").getResult();
  4982. for(HashMap list1 : listqjb){
  4983. if(hashmap.size() > 0){
  4984. int i = 0;
  4985. for(HashMap hs :hashmap){
  4986. if(list1.get("MATERIAL_NO").toString().equals(hs.get("material_no").toString())){
  4987. list1.put("THICK", hs.get("thick") == null ? "" :hs.get("thick").toString());
  4988. list1.put("WIDTH", hs.get("width") == null ? "" : hs.get("width").toString());
  4989. list1.put("LENGTH", hs.get("length") == null ? "" : hs.get("length").toString());
  4990. list1.put("PROD_THICK", hs.get("prod_thick") == null ? "" : hs.get("prod_thick").toString());
  4991. list1.put("PROD_WIDTH", hs.get("prod_width") == null ? "" : hs.get("prod_width").toString());
  4992. list1.put("DELIVERY_STATE_DESC", hs.get("delivery_state_desc") == null ? "" : hs.get("delivery_state_desc").toString());
  4993. list1.put("PLANSTEEL", hs.get("PLANSTEEL")==null?"":hs.get("PLANSTEEL").toString());
  4994. list1.put("MEMO", hs.get("MEMO")==null?"":hs.get("MEMO").toString());
  4995. list1.put("WEIGHT", hs.get("weight") == null ? "" : hs.get("weight").toString());
  4996. i++;
  4997. }
  4998. if(i==0){
  4999. list1.put("THICK", "");
  5000. list1.put("WIDTH", "");
  5001. list1.put("LENGTH", "");
  5002. list1.put("PROD_THICK", "");
  5003. list1.put("PROD_WIDTH", "");
  5004. list1.put("DELIVERY_STATE_DESC", "");
  5005. list1.put("PLANSTEEL", "");
  5006. list1.put("MEMO", "");
  5007. list1.put("WEIGHT", "");
  5008. }
  5009. }
  5010. }
  5011. }
  5012. cro.setResult(listqjb);
  5013. } catch (Exception e) {
  5014. cro.setV_errCode(-1);
  5015. cro.setV_errMsg("查询失败!"+e.getMessage());
  5016. logger.info(e.getMessage());
  5017. }
  5018. SqlSession.close();
  5019. return cro;
  5020. }
  5021. /**
  5022. * 异常材处理:处置记录查询
  5023. * @param sum
  5024. * @return
  5025. */
  5026. @SuppressWarnings({ "rawtypes", "unchecked" })
  5027. public CoreReturnObject getAbnormalRecordLgInfo(String begintime,String endtime,String heatno,String material_no,String prod_name,String type) {
  5028. String conn="unlock_type_code is not null";
  5029. try {
  5030. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  5031. String sky=StrSky(begintime,endtime);
  5032. if(!sky.equals("TRUE")){
  5033. SqlSession.close();
  5034. cro.setV_errCode(-1);
  5035. cro.setV_errMsg(sky);
  5036. return cro;
  5037. }
  5038. }
  5039. if (!SqlJoint.IsNullOrSpace(heatno)) {
  5040. conn+=" and HEAT_NO like '%"+heatno+"%'";
  5041. }
  5042. if (!SqlJoint.IsNullOrSpace(material_no)) {
  5043. conn+=" and MATERIAL_NO like '%"+material_no+"%'";
  5044. }
  5045. if(!heatno.equals("") || !material_no.equals("")){
  5046. begintime = "";
  5047. endtime = "";
  5048. }
  5049. if (!SqlJoint.IsNullOrSpace(begintime) && !SqlJoint.IsNullOrSpace(endtime)) {
  5050. conn+=" and to_date(to_char(unlock_time,'yyyy-mm-dd'), 'yyyy-mm-dd') between to_date('"+begintime+"','yyyy-mm-dd') and to_date('"+endtime+"','yyyy-mm-dd') ";
  5051. }
  5052. if (!SqlJoint.IsNullOrSpace(prod_name)) {
  5053. conn += " and PROD_NAME = '"+prod_name+"'";
  5054. }
  5055. if(!SqlJoint.IsNullOrSpace(type)){
  5056. if(type.equals("3")){
  5057. conn += " and a.pline_code in ('4001LG0')";
  5058. }
  5059. else if(type.equals("4")){
  5060. conn += " and a.pline_code in ('4001LGX')";
  5061. }
  5062. }
  5063. conn += "order by unlock_time desc";
  5064. String sql = "select a.material_no,lock_type_desc,lock_memo,UNLOCK_TYPE_CODE,UNLOCK_TYPE_DESC,a.CHECK_REMARKS,FIX_REMARKS, a.lock_seq, a.lock_type_code, a.lock_type_desc,a.lock_memo,"
  5065. + " UNLOCK_MEMO,TARGET_DESIGN_KEY,TARGET_PSC,UNLOCK_NAME,a.heat_no,a.batch_no,a.board_no,a.plan_no,a.ht_no,a.design_key, "
  5066. + " a.psc, a.pline_code, a.pline_name, a.lock_name,to_char(UNLOCK_TIME,'yyyy-mm-dd hh24:mi:ss') UNLOCK_TIME,unlock_result, "
  5067. + " A.LOCK_ID,a.lock_time, a.psc_desc,a.prod_code, a.prod_name,a.steel_code, a.steel_name,a.std_code, "
  5068. + " a.std_name from qcm_judge_locking a where 1 = 1 and "+conn+"";
  5069. System.out.print(sql);
  5070. List<HashMap> listqjb = mapper.query(sql);
  5071. String material_no1 = "";
  5072. StringBuffer sqlucomm = new StringBuffer();
  5073. int j=0;
  5074. for(HashMap list1 : listqjb){
  5075. if(j>=900){
  5076. if(j% 900 == 0){
  5077. sqlucomm.append( ") or HEATNO in ('" + list1.get("MATERIAL_NO").toString()+"'") ;
  5078. }
  5079. else
  5080. {
  5081. if(sqlucomm.length() == 0){
  5082. sqlucomm.append( "('" + list1.get("MATERIAL_NO").toString()+"'");
  5083. }else{
  5084. sqlucomm.append( ",'"+ list1.get("MATERIAL_NO").toString()+"'");
  5085. }
  5086. }
  5087. j++;
  5088. }
  5089. else
  5090. {
  5091. if(sqlucomm.length() == 0){
  5092. sqlucomm.append( "('" + list1.get("MATERIAL_NO").toString()+"'");
  5093. }else{
  5094. sqlucomm.append(",'"+ list1.get("MATERIAL_NO").toString()+"'");
  5095. }
  5096. }
  5097. j++;
  5098. }
  5099. if(sqlucomm.length()==0)
  5100. sqlucomm.append("('')");
  5101. else
  5102. sqlucomm.append(")");
  5103. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  5104. List<HashMap> hashmap = (List<HashMap>) getLgjudgeInfobyMaterial_no1("", "", sqlucomm.toString(), type.equals("3")?"4001LG0":"4001LGX", prod_name, "").getResult();
  5105. for(HashMap list1 : listqjb){
  5106. if(hashmap.size() > 0){
  5107. int i = 0;
  5108. for(HashMap hs :hashmap){
  5109. if(list1.get("MATERIAL_NO").toString().equals(hs.get("material_no").toString())){
  5110. list1.put("THICK", hs.get("thick") == null ? "" :hs.get("thick").toString());
  5111. list1.put("WIDTH", hs.get("width") == null ? "" : hs.get("width").toString());
  5112. list1.put("LENGTH", hs.get("length") == null ? "" : hs.get("length").toString());
  5113. list1.put("PROD_THICK", hs.get("prod_thick") == null ? "" : hs.get("prod_thick").toString());
  5114. list1.put("PROD_WIDTH", hs.get("prod_width") == null ? "" : hs.get("prod_width").toString());
  5115. list1.put("DELIVERY_STATE_DESC", hs.get("delivery_state_desc") == null ? "" : hs.get("delivery_state_desc").toString());
  5116. list1.put("PLANSTEEL", hs.get("PLANSTEEL")==null?"":hs.get("PLANSTEEL").toString());
  5117. list1.put("MEMO", hs.get("MEMO")==null?"":hs.get("MEMO").toString());
  5118. list1.put("WEIGHT", hs.get("weight") == null ? "" : hs.get("weight").toString());
  5119. list1.put("SC_MEMO", hs.get("SC_MEMO")==null?"":hs.get("SC_MEMO").toString());
  5120. i++;
  5121. }
  5122. if(i==0){
  5123. list1.put("THICK", "");
  5124. list1.put("WIDTH", "");
  5125. list1.put("LENGTH", "");
  5126. list1.put("PROD_THICK", "");
  5127. list1.put("PROD_WIDTH", "");
  5128. list1.put("DELIVERY_STATE_DESC", "");
  5129. list1.put("PLANSTEEL", "");
  5130. list1.put("MEMO", "");
  5131. list1.put("WEIGHT", "");
  5132. list1.put("SC_MEMO", "");
  5133. }
  5134. }
  5135. }
  5136. }
  5137. cro.setResult(listqjb);
  5138. } catch (Exception e) {
  5139. cro.setV_errCode(-1);
  5140. cro.setV_errMsg("查询失败!"+e.getMessage());
  5141. logger.info(e.getMessage());
  5142. }
  5143. SqlSession.close();
  5144. return cro;
  5145. }
  5146. @SuppressWarnings({ "unused", "unchecked", "static-access", "rawtypes" })
  5147. public CoreReturnObject GetGpSteel(String prodline,String steelname){
  5148. try{
  5149. String pl = "";
  5150. List<HashMap> list = mapper.query("select distinct a.grade_desc from qcm_ord_design_grade_chem a where grade_desc like '%"+steelname+"%' order by grade_desc asc ");
  5151. List<HashMap> listqjb = new ArrayList<HashMap>();
  5152. for(int i = 0; i<list.size();i++){
  5153. HashMap lists = new HashMap();
  5154. lists.put("STEELNAME", list.get(i).get("GRADE_DESC").toString());
  5155. listqjb.add(lists);
  5156. }
  5157. cro.setResult(listqjb);
  5158. /*JSONObject jsobj2 = new JSONObject();
  5159. JSONArray ttmaps = new JSONArray();
  5160. JSONObject jsobj1 = new JSONObject();
  5161. jsobj1.put("PROD_LINE",prodline);
  5162. jsobj1.put("STEELNAME",steelname);
  5163. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  5164. String result = qjes.callWebserviceASMX(url,"getSteel",JSON.toJSONString(jsobj1));
  5165. if(result.contains("data")){
  5166. JSONObject jo = JSONObject.parseObject(result);
  5167. JSONArray ja = jo.getJSONArray("data");
  5168. List<HashMap> listqjb = new ArrayList<HashMap>();
  5169. for(int i = 0;i<ja.size();i++){
  5170. HashMap lists = new HashMap();
  5171. lists.put("STEELNAME", ja.getJSONObject(i).getString("STEELNAME"));
  5172. listqjb.add(lists);
  5173. }
  5174. cro.setResult(listqjb);
  5175. }*/
  5176. }catch(Exception ex){
  5177. cro.setV_errCode(-1);
  5178. cro.setV_errMsg("获取成分待判信息错误"+ex.getMessage());
  5179. SqlSession.rollback();
  5180. }
  5181. SqlSession.close();
  5182. return cro;
  5183. }
  5184. /**
  5185. * 取消复样操作
  5186. */
  5187. public CoreReturnObject CancelFy(String batch_no,String material_no,String lock_seq,String username,String memo) throws Exception{
  5188. try{
  5189. String sql = "select * from qcm_judge_locking where material_no = '"+material_no+"' and lock_seq = '"+lock_seq+"'";
  5190. List<QCMJudgeLocking> qjl = mapper.queryQCMJudgeLockings(sql);
  5191. if(!qjl.get(0).getUnlock_type_code().equals("1")){
  5192. throw new Exception("只允许对复样操作进行取消复样!");
  5193. }
  5194. sql = "select * from qcm_judge_physical where phy_id = '"+qjl.get(0).getLock_id()+"'";
  5195. List<QcmJudgePhysical> qjp = mapper.queryQcmJudgePhysical(sql);
  5196. if(qjp.size() == 0){
  5197. throw new Exception("找不到试样号!");
  5198. }
  5199. UpdateInfo upd = new UpdateInfo();
  5200. //取消复样
  5201. try {
  5202. CoreReturnObject result = upd.DoDeleteFY(batch_no,qjl.get(0).getDesign_key(),qjp.get(0).getSmp_no(),username,qjp.get(0).getSteel_name(),qjp.get(0).getThick());
  5203. if(result.getV_errCode().equals(-1)){
  5204. throw new Exception(result.getV_errMsg());
  5205. }
  5206. } catch (Exception e) {
  5207. // TODO Auto-generated catch block
  5208. throw new Exception(e.getMessage());
  5209. }
  5210. sql = "select * from qcm_judge_locking where batch_no = '"+batch_no+"' and unlock_type_code = '1'";
  5211. List<QCMJudgeLocking> qjlt = mapper.queryQCMJudgeLockings(sql);
  5212. for(QCMJudgeLocking qjls : qjlt){
  5213. qjls.setValid_flag("0");;
  5214. qjls.setCancel_memo(memo);
  5215. qjls.setCancel_name(username);
  5216. mapper.UpdateQcmJudgeLocking9(qjls);
  5217. int count = 0;
  5218. //and lock_type_code = '"+qjls.getLock_type_code()+"' 240730去掉 LOCK_SEQ 流水号自增 E2404531出了问题 如果加上Lock_Type_Code 自增违反唯一约束
  5219. //所以去掉这个字段拿取最大流水号
  5220. String condition = " and MATERIAL_NO = '"+qjls.getMaterial_no()+"' order by LOCK_SEQ desc ";
  5221. List<QCMJudgeLocking> qjlk = mapper.queryQCMJudgeLocking(condition);
  5222. if(qjlk.size() > 0){
  5223. count=qjlk.get(0).getLock_seq();
  5224. }
  5225. count++;
  5226. //System.out.println(count+":"+qjls.getMaterial_no() +":"+ qjls.getLock_type_code()+"/n");
  5227. //锁定记录号
  5228. int lock_seq1=count;
  5229. qjls.setLock_seq(lock_seq1);
  5230. qjls.setUnlock_type_code("");
  5231. qjls.setUnlock_type_desc("");
  5232. qjls.setLock_memo("待判");
  5233. qjls.setTarget_design_key("");
  5234. qjls.setUnlock_name("");
  5235. mapper.insertQCMJudgeLocking(qjls);
  5236. }
  5237. sql = "select * from zj_result_all@xgcx where BILLETID = '"+material_no+"'";
  5238. List<HashMap> list1 = mapper.query(sql);
  5239. sql = "select * from QCM_JUDGE_COIL_RESULT where coil_no = '"+material_no+"'";
  5240. List<HashMap> list2 = mapper.query(sql);
  5241. sql = "select * from QCM_JUDGE_YT_COIL_RESULT where coil_no = '"+material_no+"'";
  5242. List<HashMap> list3 = mapper.query(sql);
  5243. if(list1.size() > 0 || list2.size() >0 || list3.size() >0){
  5244. if(list1.size() > 0){
  5245. ZjResultAll zra = new ZjResultAll();
  5246. zra.setPhysresult("2");
  5247. zra.setPhysresult_desc("不合格");
  5248. zra.setPic_is_lock("1");
  5249. zra.setBilletid(material_no);
  5250. mapper.UpdateJugeResultB(zra);
  5251. }else if(list2.size() > 0){
  5252. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  5253. zra.setPhysresult("2");
  5254. zra.setPhysresult_desc("不合格");
  5255. zra.setPic_is_lock("1");
  5256. zra.setCoil_no(material_no);
  5257. mapper.UpdateJugeResultJ(zra);
  5258. }else{
  5259. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  5260. zra.setPhysresult("2");
  5261. zra.setPhysresult_desc("不合格");
  5262. zra.setPic_is_lock("1");
  5263. zra.setCoil_no(material_no);
  5264. mapper.UpdateJugeResultY(zra);
  5265. }
  5266. }
  5267. SqlSession.commit();
  5268. }catch(Exception e){
  5269. cro.setV_errCode(-1);
  5270. cro.setV_errMsg(e.getMessage());
  5271. SqlSession.rollback();
  5272. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.CancelFy:【"+batch_no+"," + material_no + ","+lock_seq+","+username+"】" + e);
  5273. }
  5274. SqlSession.close();
  5275. return cro;
  5276. }
  5277. /**
  5278. * 炼钢成分审批
  5279. */
  5280. public CoreReturnObject doApply(String apply_id,String username,String status) throws Exception{
  5281. try{
  5282. mapper.doApply(apply_id, username, status);
  5283. if(status.equals("1")){
  5284. List<QcmJudgeLockingApply> qjlp = mapper.QcmJudgeLockingApply("select * from qcm_judge_locking_apply where apply_id = '"+apply_id+"'");
  5285. String sql = "select * from qcm_judge_locking a where a.heat_no = '"+qjlp.get(0).getHeat_no()+"' and a.lock_type_code = 'C' AND A.UNLOCK_TYPE_CODE IS NULL AND A.PLINE_CODE IN ('ZB1','HB1','RZ1','SZ1','LT1','YT1','BC2','GX1','GX2') AND A.LOCK_ID LIKE 'R%'";
  5286. List<QCMJudgeLocking> qcj = mapper.queryQCMJudgeLockings(sql);
  5287. for(QCMJudgeLocking qjl :qcj){
  5288. qjl.setUnlock_type_code("9");
  5289. qjl.setUnlock_type_desc("解除");
  5290. qjl.setUnlock_memo("成分重新判定");
  5291. qjl.setLock_type_code("C");
  5292. qjl.setUnlock_name(username);
  5293. mapper.UpdateQcmJudgeLocking3(qjl);
  5294. if(qjl.getPline_code().equals("RZ1") || qjl.getPline_code().equals("LT1") || qjl.getPline_code().equals("SZ1")){
  5295. QcmJudgeCoilResult q= new QcmJudgeCoilResult();
  5296. q.setCoil_no(qjl.getMaterial_no().toString());
  5297. q.setR_cic_is_lock("0");
  5298. q.setR_chemid("");
  5299. q.setR_chemresult("0");
  5300. q.setR_chemresult_desc("");
  5301. mapper.UpdateJugeResultJ(q);
  5302. }else{
  5303. ZjResultAll zra = new ZjResultAll();
  5304. zra.setBilletid(qjl.getMaterial_no().toString());
  5305. zra.setR_cic_is_lock("0");
  5306. zra.setR_chemid("");
  5307. zra.setR_chemresult("0");
  5308. zra.setR_chemresult_desc("");
  5309. mapper.UpdateJugeResultB(zra);
  5310. }
  5311. //自动判定
  5312. QcmJudgeLog qjlt = new QcmJudgeLog();
  5313. qjlt.setJudge_type("R");
  5314. qjlt.setMaterial_no(qjl.getMaterial_no().toString());
  5315. qjlt.setCreate_name("system");
  5316. qjlt.setProd_line(qjl.getPline_code());
  5317. mapper.insertQcmJudgeLog(qjlt);
  5318. }
  5319. }
  5320. SqlSession.commit();
  5321. }catch(Exception e){
  5322. cro.setV_errCode(-1);
  5323. cro.setV_errMsg(e.getMessage());
  5324. SqlSession.rollback();
  5325. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.doApply:【"+ apply_id + ","+username+"】" + e);
  5326. }
  5327. SqlSession.close();
  5328. return cro;
  5329. }
  5330. /**
  5331. * 审批处理备注
  5332. */
  5333. public CoreReturnObject updatememo(String apply_id,String handle_memo) throws Exception{
  5334. try{
  5335. String upsql = "update QCM_JUDGE_LOCKING_APPLY t set t.handle_memo = '"+handle_memo+"' where t.apply_id = '"+apply_id+"' ";
  5336. mapper.updateJudgeStatus(upsql.toString());
  5337. SqlSession.commit();
  5338. }catch(Exception e){
  5339. cro.setV_errCode(-1);
  5340. cro.setV_errMsg(e.getMessage());
  5341. SqlSession.rollback();
  5342. }
  5343. SqlSession.close();
  5344. return cro;
  5345. }
  5346. /**
  5347. * 审批不通过
  5348. */
  5349. public CoreReturnObject ApplyBack(String username,String apply_id) throws Exception{
  5350. try{
  5351. mapper.ApplyBack(apply_id,username);
  5352. mapper.doApply(apply_id, username, "2");
  5353. SqlSession.commit();
  5354. }catch(Exception e){
  5355. cro.setV_errCode(-1);
  5356. cro.setV_errMsg(e.getMessage());
  5357. SqlSession.rollback();
  5358. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.ApplyBack:【"+ apply_id + ","+username+"】" + e);
  5359. }
  5360. SqlSession.close();
  5361. return cro;
  5362. }
  5363. /**
  5364. * 取消放行操作
  5365. */
  5366. public CoreReturnObject CancelFx(String material_no,String lock_type_code,String lock_seq,String username,String memo) throws Exception{
  5367. try{
  5368. String sql = "select * from qcm_judge_locking where material_no = '"+material_no+"' and lock_seq = '"+lock_seq+"'";
  5369. List<QCMJudgeLocking> qjl = mapper.queryQCMJudgeLockings(sql);
  5370. if(!qjl.get(0).getUnlock_type_code().equals("0")){
  5371. throw new Exception("只允许对放行操作进行取消放行!");
  5372. }
  5373. sql = "select * from qcm_judge_locking where material_no = '"+material_no+"' and unlock_type_code = '0'";
  5374. List<QCMJudgeLocking> qjlt = mapper.queryQCMJudgeLockings(sql);
  5375. for(QCMJudgeLocking qjls : qjlt){
  5376. qjls.setValid_flag("0");;
  5377. qjls.setCancel_memo(memo);
  5378. qjls.setCancel_name(username);
  5379. mapper.UpdateQcmJudgeLocking9(qjls);
  5380. int count = 0;
  5381. String condition = " and MATERIAL_NO = '"+qjls.getMaterial_no()+"' and lock_type_code = '"+qjls.getLock_type_code()+"' order by LOCK_SEQ desc ";
  5382. List<QCMJudgeLocking> qjlk = mapper.queryQCMJudgeLocking(condition);
  5383. if(qjlk.size() > 0){
  5384. count=qjlk.get(0).getLock_seq();
  5385. }
  5386. count++;
  5387. //锁定记录号
  5388. int lock_seq1=count;
  5389. qjls.setLock_seq(lock_seq1);
  5390. qjls.setUnlock_type_code("");
  5391. qjls.setUnlock_type_desc("");
  5392. qjls.setLock_memo("待判");
  5393. qjls.setTarget_design_key("");
  5394. qjls.setUnlock_name("");
  5395. mapper.insertQCMJudgeLocking(qjls);
  5396. }
  5397. sql = "select * from zj_result_all@xgcx where BILLETID = '"+material_no+"'";
  5398. List<HashMap> list1 = mapper.query(sql);
  5399. sql = "select * from QCM_JUDGE_COIL_RESULT where coil_no = '"+material_no+"'";
  5400. List<HashMap> list2 = mapper.query(sql);
  5401. if(list1.size() > 0 || list2.size() >0){
  5402. if(list1.size() > 0){
  5403. if(!list1.get(0).get("JUDGERESULT").equals("0")){
  5404. throw new Exception("该物料号已经综判,不能取消放行!");
  5405. }
  5406. ZjResultAll zra = new ZjResultAll();
  5407. if(lock_type_code.equals("P")){
  5408. zra.setPhysresult("2");
  5409. zra.setPhysresult_desc("不合格");
  5410. zra.setPic_is_lock("1");
  5411. }else if(lock_type_code.equals("C") && qjlt.get(0).getLock_id().equals(list1.get(0).get("R_CHEMID"))){
  5412. zra.setR_chemresult("2");
  5413. zra.setR_chemresult_desc("不合格");
  5414. zra.setR_cic_is_lock("1");
  5415. }else if(lock_type_code.equals("C") && qjlt.get(0).getLock_id().equals(list1.get(0).get("CHEMID"))){
  5416. zra.setChemresult("2");
  5417. zra.setChemresult_desc("不合格");
  5418. zra.setCic_is_lock("1");
  5419. }
  5420. zra.setBilletid(material_no);
  5421. mapper.UpdateJugeResultB(zra);
  5422. }else{
  5423. if(list1.get(0).get("JUDGERESULT").equals("1")){
  5424. throw new Exception("该物料号已经综判,不能取消放行!");
  5425. }
  5426. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  5427. if(lock_type_code.equals("P")){
  5428. zra.setPhysresult("2");
  5429. zra.setPhysresult_desc("不合格");
  5430. zra.setPic_is_lock("1");
  5431. }else if(lock_type_code.equals("C")&& qjlt.get(0).getLock_id().equals(list1.get(0).get("R_CHEMID"))){
  5432. zra.setR_chemresult("2");
  5433. zra.setR_chemresult_desc("不合格");
  5434. zra.setR_cic_is_lock("1");
  5435. }else if(lock_type_code.equals("C") && qjlt.get(0).getLock_id().equals(list1.get(0).get("CHEMID"))){
  5436. zra.setChemresult("2");
  5437. zra.setChemresult_desc("不合格");
  5438. zra.setCic_is_lock("1");
  5439. }
  5440. mapper.UpdateJugeResultJ(zra);
  5441. }
  5442. }
  5443. SqlSession.commit();
  5444. }catch(Exception e){
  5445. cro.setV_errCode(-1);
  5446. cro.setV_errMsg(e.getMessage());
  5447. SqlSession.rollback();
  5448. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.CancelFx:【"+ material_no + "," +lock_type_code+","+lock_seq+","+username+"】" + e);
  5449. }
  5450. SqlSession.close();
  5451. return cro;
  5452. }
  5453. /**
  5454. * 取消判废操作
  5455. */
  5456. public CoreReturnObject CancelPf(String material_no,String lock_type_code,String lock_seq,String username,String memo) throws Exception{
  5457. try{
  5458. String sql = "select * from qcm_judge_locking where material_no = '"+material_no+"' and lock_seq = '"+lock_seq+"'";
  5459. List<QCMJudgeLocking> qjl = mapper.queryQCMJudgeLockings(sql);
  5460. if(!qjl.get(0).getUnlock_type_desc().equals("判废")){
  5461. throw new Exception("只允许对判废操作进行取消判废!");
  5462. }
  5463. sql = "select * from qcm_judge_locking where material_no = '"+material_no+"' and unlock_type_desc = '判废'";
  5464. List<QCMJudgeLocking> qjlt = mapper.queryQCMJudgeLockings(sql);
  5465. for(QCMJudgeLocking qjls : qjlt){
  5466. qjls.setValid_flag("0");;
  5467. qjls.setCancel_memo(memo);
  5468. qjls.setCancel_name(username);
  5469. mapper.UpdateQcmJudgeLocking9(qjls);
  5470. int count = 0;
  5471. String condition = " and MATERIAL_NO = '"+qjls.getMaterial_no()+"' and lock_type_code = '"+qjls.getLock_type_code()+"' order by LOCK_SEQ desc ";
  5472. List<QCMJudgeLocking> qjlk = mapper.queryQCMJudgeLocking(condition);
  5473. if(qjlk.size() > 0){
  5474. count=qjlk.get(0).getLock_seq();
  5475. }
  5476. count++;
  5477. //锁定记录号
  5478. int lock_seq1=count;
  5479. qjls.setLock_seq(lock_seq1);
  5480. qjls.setUnlock_type_code("");
  5481. qjls.setUnlock_type_desc("");
  5482. qjls.setLock_memo("待判");
  5483. qjls.setTarget_design_key("");
  5484. qjls.setUnlock_name("");
  5485. mapper.insertQCMJudgeLocking(qjls);
  5486. }
  5487. sql = "select * from zj_result_all@xgcx where BILLETID = '"+material_no+"'";
  5488. List<HashMap> list1 = mapper.query(sql);
  5489. sql = "select * from QCM_JUDGE_COIL_RESULT where coil_no = '"+material_no+"'";
  5490. List<HashMap> list2 = mapper.query(sql);
  5491. if(list1.size() > 0 || list2.size() >0){
  5492. if(list1.size() > 0){
  5493. if(!list1.get(0).get("JUDGERESULT").equals("0")){
  5494. throw new Exception("该物料号已经综判,不能取消判废!");
  5495. }
  5496. ZjResultAll zra = new ZjResultAll();
  5497. if(lock_type_code.equals("P")){
  5498. zra.setPhysresult("2");
  5499. zra.setPhysresult_desc("不合格");
  5500. zra.setPic_is_lock("1");
  5501. }else if(lock_type_code.equals("C") && qjlt.get(0).getLock_id().equals(list1.get(0).get("R_CHEMID"))){
  5502. zra.setR_chemresult("2");
  5503. zra.setR_chemresult_desc("不合格");
  5504. zra.setR_cic_is_lock("1");
  5505. }else if(lock_type_code.equals("C") && qjlt.get(0).getLock_id().equals(list1.get(0).get("CHEMID"))){
  5506. zra.setChemresult("2");
  5507. zra.setChemresult_desc("不合格");
  5508. zra.setCic_is_lock("1");
  5509. }
  5510. zra.setBilletid(material_no);
  5511. mapper.UpdateJugeResultB(zra);
  5512. }else{
  5513. if(list1.get(0).get("JUDGERESULT").equals("1")){
  5514. throw new Exception("该物料号已经综判,不能取消判废!");
  5515. }
  5516. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  5517. if(lock_type_code.equals("P")){
  5518. zra.setPhysresult("2");
  5519. zra.setPhysresult_desc("不合格");
  5520. zra.setPic_is_lock("1");
  5521. }else if(lock_type_code.equals("C")&& qjlt.get(0).getLock_id().equals(list1.get(0).get("R_CHEMID"))){
  5522. zra.setR_chemresult("2");
  5523. zra.setR_chemresult_desc("不合格");
  5524. zra.setR_cic_is_lock("1");
  5525. }else if(lock_type_code.equals("C") && qjlt.get(0).getLock_id().equals(list1.get(0).get("CHEMID"))){
  5526. zra.setChemresult("2");
  5527. zra.setChemresult_desc("不合格");
  5528. zra.setCic_is_lock("1");
  5529. }
  5530. mapper.UpdateJugeResultJ(zra);
  5531. }
  5532. }
  5533. SqlSession.commit();
  5534. }catch(Exception e){
  5535. cro.setV_errCode(-1);
  5536. cro.setV_errMsg(e.getMessage());
  5537. SqlSession.rollback();
  5538. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.CancelPf:【"+ material_no + "," +lock_type_code+","+lock_seq+","+username+"】" + e);
  5539. }
  5540. SqlSession.close();
  5541. return cro;
  5542. }
  5543. /**
  5544. * 炼钢关闭退回
  5545. */
  5546. public CoreReturnObject Reback(String material_no,String lock_seq) throws Exception{
  5547. try{
  5548. String sql = "select * from qcm_judge_locking where material_no = '"+material_no+"' and lock_seq = '"+lock_seq+"'";
  5549. List<QCMJudgeLocking> qjl = mapper.queryQCMJudgeLockings(sql);
  5550. if(!qjl.get(0).getUnlock_type_code().equals("11")){
  5551. throw new Exception("只允许对关闭操作进行退回!");
  5552. }
  5553. QCMJudgeLocking qjls = qjl.get(0);
  5554. qjls.setUnlock_type_code("");
  5555. qjls.setUnlock_type_desc("");
  5556. mapper.UpdateQcmJudgeLocking5(qjls);
  5557. SqlSession.commit();
  5558. }catch(Exception e){
  5559. cro.setV_errCode(-1);
  5560. cro.setV_errMsg(e.getMessage());
  5561. SqlSession.rollback();
  5562. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.Reback:【" + material_no + ","+lock_seq+"】" + e);
  5563. }
  5564. SqlSession.close();
  5565. return cro;
  5566. }
  5567. /**
  5568. * 材质异常材处置
  5569. */
  5570. public CoreReturnObject JudgeLocking(String material_no,String username){
  5571. try{
  5572. //判断是否进行了综合判定
  5573. String sql = "select * from zj_result_all@xgcx where BILLETID = '"+material_no+"'";
  5574. List<HashMap> list1 = mapper.query(sql);
  5575. sql = "select * from QCM_JUDGE_COIL_RESULT where coil_no = '"+material_no+"'";
  5576. //List<QcmJudgePhy>
  5577. List<HashMap> list2 = mapper.query(sql);
  5578. if(list1.size() >0 || list2.size() >0){
  5579. if(list1.size()>0){
  5580. for(HashMap list:list1){
  5581. if(!list.get("JUDGERESULT").toString().equals("0")){
  5582. throw new Exception("该物料号做了综合判定,不能异常材锁定!");
  5583. }
  5584. }
  5585. }else{
  5586. for(HashMap list:list2){
  5587. if(!list.get("JUDGERESULT").toString().equals("0")){
  5588. throw new Exception("该物料号做了材质最终判定,不能异常材锁定!");
  5589. }
  5590. }
  5591. }
  5592. }
  5593. sql = "select * from qcm_judge_locking where material_no = '"+material_no+"' and lock_type_code = 'P' order by lock_seq desc ";
  5594. List<QCMJudgeLocking> qjls = mapper.queryQCMJudgeLockings(sql);
  5595. QCMJudgeLocking qjl = qjls.get(0);
  5596. int count = 0;
  5597. if(qjls.size() > 0){
  5598. count=qjls.get(0).getLock_seq();
  5599. }
  5600. count++;
  5601. //锁定记录号
  5602. int lock_seq=count;
  5603. qjl.setLock_seq(lock_seq);
  5604. qjl.setUnlock_type_code("");
  5605. qjl.setUnlock_type_desc("");
  5606. qjl.setLock_memo("待判");
  5607. qjl.setUnlock_memo("");
  5608. qjl.setTarget_design_key("");
  5609. qjl.setUnlock_name("");
  5610. mapper.insertQCMJudgeLocking(qjl);
  5611. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  5612. qjog.setOperate_name(username);
  5613. qjog.setOperate_type("异常材锁定");
  5614. qjog.setParams(material_no);
  5615. qjog.setProd_line(qjl.getPline_code());
  5616. qjog.setBatchno(qjl.getBatch_no());
  5617. mapper.insertQcmJudgeOperateLog(qjog);
  5618. SqlSession.commit();
  5619. }catch(Exception e){
  5620. cro.setV_errCode(-1);
  5621. cro.setV_errMsg(e.getMessage());
  5622. SqlSession.rollback();
  5623. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.JudgeLocking:【" + material_no + ","+username+"】" + e);
  5624. }
  5625. SqlSession.close();
  5626. return cro;
  5627. }
  5628. /**查询改判信息
  5629. *
  5630. */
  5631. @SuppressWarnings({ "unchecked", "rawtypes" })
  5632. public CoreReturnObject getGpInfo(String material_no,String STD_CODE,String STEELCODE,String HEIGHT,String DELIVERY_STATE_CODE,String PSC,String WIDTH,String LENGTH,String PRODLINE){
  5633. try{
  5634. String url = "http://172.16.0.169:82/CxzcCBDY/http/GPDD";
  5635. if(PRODLINE.equals("GX1") || PRODLINE.equals("GX2") || PRODLINE.equals("BC2") ||
  5636. PRODLINE.equals("4001GX1") || PRODLINE.equals("4001GX2") || PRODLINE.equals("4001BC2")){
  5637. url = "http://172.16.4.136:14008/slpdi/getChaOrdScopeXB";//增加代码 240527
  5638. }
  5639. Map<String ,String> Mapm = new HashMap();
  5640. if(PSC == null || PSC.equals("")){
  5641. List<QCMJudgeLocking> qjj = mapper.queryQCMJudgeLockings("select * from qcm_judge_locking a where material_no = '"+material_no+"' and lock_memo like '%拉力分层%' and a.unlock_type_code is null ");
  5642. if(qjj.size() >0 && qjj.get(0).getDesign_key() != null){
  5643. List<HashMap> hashmap = mapper.query("select * from qcm_ord_design_std_pic where design_key = '"+qjj.get(0).getDesign_key()+"'");
  5644. PSC = hashmap.get(0).get("PSC").toString();
  5645. }
  5646. }
  5647. Mapm.put("queueid", "AddChangeOrdSL");
  5648. Mapm.put("MATERIAL_NO", material_no);
  5649. Mapm.put("STD_CODE", STD_CODE);
  5650. Mapm.put("STEELCODE",STEELCODE);
  5651. Mapm.put("HEIGHT", HEIGHT);
  5652. Mapm.put("DELIVERY_STATE_CODE", DELIVERY_STATE_CODE);
  5653. Mapm.put("PSC", PSC);
  5654. Mapm.put("WIDTH",WIDTH);
  5655. Mapm.put("LENGTH",LENGTH);
  5656. Mapm.put("PROD_LINE",PRODLINE);
  5657. String result = doPost(url,Mapm);
  5658. if(result.equals("")){
  5659. return cro;
  5660. }
  5661. JSONObject jo = JSONObject.parseObject(result);
  5662. if(jo.get("status").toString().equals("200")){
  5663. JSONArray ja = jo.getJSONArray("GP_DETAL");
  5664. List<HashMap> listqjb = new ArrayList<HashMap>();
  5665. for(int i = 0;i<ja.size();i++){
  5666. HashMap lists = new HashMap();
  5667. lists.put("GP_SEQNO", ja.getJSONObject(i).getString("GP_SEQNO"));
  5668. lists.put("GP_TRADENO", ja.getJSONObject(i).getString("GP_TRADENO"));
  5669. lists.put("GP_STDCLASS", ja.getJSONObject(i).getString("GP_STDCLASS"));
  5670. lists.put("GP_STDNUM", ja.getJSONObject(i).getString("GP_STDNUM"));
  5671. lists.put("GP_STDYEAR", ja.getJSONObject(i).getString("GP_STDYEAR"));
  5672. lists.put("GP_PACTNO", ja.getJSONObject(i).getString("GP_PACTNO"));
  5673. lists.put("GP_HEIGHT", ja.getJSONObject(i).getString("GP_HEIGHT"));
  5674. lists.put("GP_WIDTH", ja.getJSONObject(i).getString("GP_WIDTH"));
  5675. lists.put("GP_LENGTH", ja.getJSONObject(i).getString("GP_LENGTH"));
  5676. lists.put("GP_ORDNO", ja.getJSONObject(i).getString("GP_ORDNO"));
  5677. listqjb.add(lists);
  5678. }
  5679. cro.setResult(listqjb);
  5680. }else{
  5681. cro.setV_errCode(-1);
  5682. cro.setV_errMsg(result);
  5683. }
  5684. }catch (Exception e) {
  5685. cro.setV_errCode(-1);
  5686. cro.setV_errMsg("查询失败!"+e.getMessage());
  5687. logger.info(e.getMessage());
  5688. }
  5689. SqlSession.close();
  5690. return cro;
  5691. }
  5692. public static String doPost(String url, Map<String, String> param) {
  5693. // 创建Httpclient对象
  5694. CloseableHttpClient httpClient = HttpClients.createDefault();
  5695. CloseableHttpResponse response = null;
  5696. String resultString = "";
  5697. try {
  5698. // 创建Http Post请求
  5699. HttpPost httpPost = new HttpPost(url);
  5700. // 创建参数列表
  5701. if (param != null) {
  5702. List<NameValuePair> paramList = new ArrayList<NameValuePair>();
  5703. for (String key : param.keySet()) {
  5704. paramList.add(new BasicNameValuePair(key, param.get(key)));
  5705. }
  5706. // 模拟表单
  5707. UrlEncodedFormEntity entity = new UrlEncodedFormEntity(paramList,"utf-8");
  5708. httpPost.setEntity(entity);
  5709. }
  5710. // 执行http请求
  5711. response = httpClient.execute(httpPost);
  5712. resultString = EntityUtils.toString(response.getEntity(), "utf-8");
  5713. System.out.println( resultString);
  5714. } catch (Exception e) {
  5715. e.printStackTrace();
  5716. } finally {
  5717. try {
  5718. response.close();
  5719. } catch (IOException e) {
  5720. // TODO Auto-generated catch block
  5721. e.printStackTrace();
  5722. }
  5723. }
  5724. return resultString;
  5725. }
  5726. /**
  5727. * 炼钢改判 产品序号、锁定记录号、封锁来源、处置去向、处置去向说明、操作人,单项判定记录号、改判牌号、去向
  5728. */
  5729. @SuppressWarnings("rawtypes")
  5730. public CoreReturnObject doInformationLgGp(ArrayList param1) throws Exception{
  5731. try{
  5732. if(param1 == null || param1.size() <= 0){
  5733. throw new Exception("请传入参数!");
  5734. }
  5735. String sql = "select * from qcm_judge_locking where material_no = '"+param1.get(0).toString()+"' and lock_seq = '"+param1.get(1).toString()+"'";
  5736. QCMJudgeLocking qjl = mapper.queryQCMJudgeLockings(sql).get(0);
  5737. /*QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  5738. List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(param1.get(0).toString());
  5739. if(hashmap.size() == 0){
  5740. hashmap = qjms.doQueryMaterialInfoJ(param1.get(0).toString());
  5741. }
  5742. if(hashmap.size()==0){
  5743. hashmap = mapper.doQueryMaterialInfoY(param1.get(0).toString());
  5744. }*/
  5745. if(param1.get(3).toString().equals("7")){
  5746. qjl.setUnlock_type_code("7");
  5747. qjl.setUnlock_type_desc("改判");
  5748. }else{
  5749. qjl.setUnlock_type_code("15");
  5750. qjl.setUnlock_type_desc("改判+放行");
  5751. }
  5752. qjl.setUnlock_memo(param1.get(4).toString());
  5753. qjl.setTarget_design_key(param1.get(7).toString());
  5754. qjl.setUnlock_name(param1.get(5).toString());
  5755. mapper.UpdateQcmJudgeLocking(qjl);
  5756. if(param1.get(2).toString().equals("F")){
  5757. int count = 0;
  5758. String condition = " and MATERIAL_NO = '"+param1.get(0).toString()+"' order by LOCK_SEQ desc ";
  5759. List<QCMJudgeLocking> qjlk = mapper.queryQCMJudgeLocking(condition);
  5760. if(qjlk.size() > 0){
  5761. count=qjlk.get(0).getLock_seq();
  5762. }
  5763. count++;
  5764. //锁定记录号
  5765. int lock_seq=count;
  5766. qjl.setLock_seq(lock_seq);
  5767. qjl.setUnlock_type_code("");
  5768. qjl.setUnlock_type_desc("");
  5769. qjl.setUnlock_memo("");
  5770. qjl.setTarget_design_key("");
  5771. qjl.setUnlock_name("");
  5772. mapper.insertQCMJudgeLocking(qjl);
  5773. }
  5774. //调用改判接口
  5775. //调用综合判定接口
  5776. String qx = "";
  5777. if(param1.get(8).toString().equals("厚板")){
  5778. qx = "P";
  5779. }else if(param1.get(8).toString().equals("中板")){
  5780. qx = "Z";
  5781. }else if(param1.get(8).toString().equals("热轧")){
  5782. qx = "H";
  5783. }
  5784. sql = "select * from qcm_judge_locking where material_no = '"+param1.get(0).toString()+"' and unlock_type_code is null";
  5785. List<QCMJudgeLocking> qjlt = mapper.queryQCMJudgeLockings(sql);
  5786. for(QCMJudgeLocking qjls : qjlt){
  5787. qjls.setSteel_code(param1.get(7).toString());
  5788. qjls.setSteel_name(param1.get(7).toString());
  5789. mapper.UpdateQcmJudgeLocking4(qjls);
  5790. }
  5791. JSONObject jsobj2 = new JSONObject();
  5792. JSONArray ttmaps = new JSONArray();
  5793. JSONObject jsobj1 = new JSONObject();
  5794. jsobj1.put("PROD_LINE", qjl.getPline_code());
  5795. jsobj1.put("STEELCODE",param1.get(7).toString());
  5796. jsobj1.put("PROD_TYPE",qjl.getProd_name());
  5797. jsobj1.put("SLAB_NO",qjl.getMaterial_no());
  5798. jsobj1.put("OPTMAN", param1.get(5).toString());
  5799. jsobj1.put("SLAB_RT", qx);
  5800. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  5801. String result = callWebserviceASMX(url,"JudgeChange",JSON.toJSONString(jsobj1));
  5802. JSONObject jo = JSONObject.parseObject(result);
  5803. if(jo.get("code").toString().equals("1")){
  5804. throw new Exception("改判失败!"+jo.get("message").toString());
  5805. }
  5806. SqlSession.commit();
  5807. //LGRlChemJudgeBySystem(qjl.getHeat_no(), param1.get(0).toString(), "", param1.get(5).toString(), param1.get(7).toString(), qjl.getProd_name(), qjl.getPline_code(),param1.get(3).toString().equals("7")?"3":"4");
  5808. }catch(Exception e){
  5809. cro.setV_errCode(-1);
  5810. cro.setV_errMsg(e.getMessage());
  5811. SqlSession.rollback();
  5812. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.doInformationLgGp:【" + param1.toString() + "】" + e);
  5813. }
  5814. SqlSession.close();
  5815. return cro;
  5816. }
  5817. /**
  5818. * 改判 产品序号、锁定记录号、封锁来源、处置去向、处置去向说明、操作人,单项判定记录号、改判订单号,缺陷编码,改判牌号
  5819. */
  5820. @SuppressWarnings("rawtypes")
  5821. public CoreReturnObject doInformationGp(ArrayList param1) throws Exception{
  5822. try{
  5823. if(param1 == null || param1.size() <= 0){
  5824. throw new Exception("请传入参数!");
  5825. }
  5826. String sql = "select * from qcm_judge_locking where material_no = '"+param1.get(0).toString()+"' and lock_seq = '"+param1.get(1).toString()+"'";
  5827. QCMJudgeLocking qjl = mapper.queryQCMJudgeLockings(sql).get(0);
  5828. sql = "select * from zj_result_all@xgcx where BILLETID = '"+param1.get(0).toString()+"'";
  5829. List<HashMap> list1 = mapper.query(sql);
  5830. sql = "select * from QCM_JUDGE_COIL_RESULT where coil_no = '"+param1.get(0).toString()+"'";
  5831. List<HashMap> list2 = mapper.query(sql);
  5832. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  5833. QcmJudgeSurfaceServiceImpl qjf = new QcmJudgeSurfaceServiceImpl();
  5834. List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(param1.get(0).toString());//中厚板
  5835. if(hashmap.size() == 0){
  5836. hashmap = qjms.doQueryMaterialInfoJ(param1.get(0).toString());//卷板
  5837. }
  5838. if(hashmap.size()==0){
  5839. hashmap = mapper.doQueryMaterialInfoY(param1.get(0).toString());//优特
  5840. }
  5841. qjl.setUnlock_type_code("7");
  5842. qjl.setUnlock_type_desc("改判");
  5843. qjl.setUnlock_memo(param1.get(4).toString());
  5844. qjl.setUnlock_result(param1.get(9).toString());
  5845. qjl.setTarget_design_key(param1.get(7).toString());
  5846. qjl.setReason_code(param1.get(8).toString());
  5847. List<HashMap> listsu = qjf.finddefecttype(param1.get(8).toString());
  5848. if(listsu.size() >0)
  5849. {
  5850. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  5851. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  5852. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  5853. }
  5854. if(list1.size() >0 || list2.size() >0){
  5855. if (list1.size() > 0) {
  5856. //发起改判
  5857. updateorderno(param1.get(7).toString(),param1.get(9).toString(),param1.get(5).toString(),param1.get(0).toString());
  5858. ZjResultAll zra = new ZjResultAll();
  5859. zra.setBilletid(param1.get(0).toString());
  5860. //更改库存订单
  5861. if(!param1.get(7).toString().startsWith("19")){
  5862. String INSPECTION_LOT = SendGenerationSampleInfo1(hashmap, param1, "2", "1");
  5863. zra.setNew_inspection_lot(INSPECTION_LOT);
  5864. }
  5865. /*zra.setChemresult("0");
  5866. zra.setSizeresult("0");
  5867. zra.setJudgeresult("0");*/
  5868. zra.setPhysresult("0");
  5869. zra.setPhyfstsresult("0");
  5870. /*zra.setSpyresult("0");
  5871. zra.setSurfaceresult("0");
  5872. zra.setUp_surface_result("0");
  5873. zra.setUd_surface_result("0");
  5874. zra.setMarginal_result("0");
  5875. zra.setChemresult_desc("待判");
  5876. zra.setSizeresult_desc("待判");
  5877. zra.setJudgeresult_desc("待判");*/
  5878. zra.setPhysresult_desc("");
  5879. zra.setPhyfstsresult_desc("");
  5880. /*zra.setSpyresult_desc("待判");
  5881. zra.setSurfaceresult_desc("待判");
  5882. zra.setUp_surface_result_desc("待判");
  5883. zra.setUd_surface_result_desc("待判");
  5884. zra.setMarginal_result_desc("待判");
  5885. zra.setUp_surface_result_id_desc("");
  5886. zra.setUd_surface_result_id_desc("");
  5887. zra.setMarginal_result_id_desc("");*/
  5888. //zra.setChemid("");
  5889. zra.setPhysid("");
  5890. zra.setPhyfstsid("");
  5891. /*zra.setSurfaceid("");
  5892. zra.setSpyid("");
  5893. zra.setSizeid("");
  5894. zra.setJudgeid("");
  5895. zra.setCic_is_lock("0");*/
  5896. zra.setPic_is_lock("0");
  5897. /*zra.setSic_is_lock("0");
  5898. zra.setDic_is_lock("0");
  5899. zra.setSfu_is_lock("0");
  5900. zra.setSfd_is_lock("0");
  5901. zra.setSfe_is_lock("0");*/
  5902. /*zra.setR_chemid("");
  5903. zra.setR_chemresult("0");
  5904. zra.setR_chemresult_desc("待判");
  5905. zra.setR_cic_is_lock("0");*/
  5906. /*zra.setFst_judgeresult("0");
  5907. zra.setFst_judgeresult_desc("待判");*/
  5908. mapper.UpdateJugeResultB(zra);
  5909. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  5910. qjog.setOperate_name(param1.get(5).toString());
  5911. qjog.setOperate_type("改判");
  5912. qjog.setParams(param1.get(0).toString());
  5913. qjog.setBatchno(qjl.getBatch_no());
  5914. qjog.setProd_line(qjl.getPline_code());
  5915. mapper.insertQcmJudgeOperateLog(qjog);
  5916. } else {
  5917. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  5918. //更改库存订单
  5919. String INSPECTION_LOT = SendGenerationSampleInfo1(hashmap, param1, "2", "1");
  5920. zra.setNew_inspection_lot(INSPECTION_LOT);
  5921. zra.setCoil_no(param1.get(0).toString());
  5922. zra.setChemresult("0");
  5923. zra.setSizeresult("0");
  5924. zra.setJudgeresult("0");
  5925. zra.setPhysresult("0");
  5926. zra.setPhyfstsresult("0");
  5927. zra.setSpyresult("0");
  5928. zra.setSurfaceresult("0");
  5929. zra.setUp_surface_result("0");
  5930. zra.setUd_surface_result("0");
  5931. zra.setMarginal_result("0");
  5932. zra.setChemresult_desc("待判");
  5933. zra.setSizeresult_desc("待判");
  5934. zra.setJudgeresult_desc("待判");
  5935. zra.setPhysresult_desc("");
  5936. zra.setPhyfstsresult_desc("");
  5937. zra.setSpyresult_desc("待判");
  5938. zra.setSurfaceresult_desc("待判");
  5939. zra.setUp_surface_result_desc("待判");
  5940. zra.setUd_surface_result_desc("待判");
  5941. zra.setMarginal_result_desc("待判");
  5942. zra.setUp_surface_result_id_desc("");
  5943. zra.setUd_surface_result_id_desc("");
  5944. zra.setMarginal_result_id_desc("");
  5945. zra.setChemid("");
  5946. zra.setPhysid("");
  5947. zra.setPhyfstsid("");
  5948. zra.setSurfaceid("");
  5949. zra.setSpyid("");
  5950. zra.setSizeid("");
  5951. zra.setJudgeid("");
  5952. zra.setCic_is_lock("0");
  5953. zra.setPic_is_lock("0");
  5954. zra.setSic_is_lock("0");
  5955. zra.setDic_is_lock("0");
  5956. zra.setSfu_is_lock("0");
  5957. zra.setSfd_is_lock("0");
  5958. zra.setSfe_is_lock("0");
  5959. zra.setR_chemid("");
  5960. zra.setR_chemresult("0");
  5961. zra.setR_chemresult_desc("待判");
  5962. zra.setR_cic_is_lock("0");
  5963. mapper.UpdateJugeResultJ(zra);
  5964. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  5965. qjog.setOperate_name(param1.get(5).toString());
  5966. qjog.setOperate_type("改判");
  5967. qjog.setParams(param1.get(0).toString());
  5968. qjog.setBatchno(qjl.getBatch_no());
  5969. qjog.setProd_line(qjl.getPline_code());
  5970. mapper.insertQcmJudgeOperateLog(qjog);
  5971. }
  5972. }else{
  5973. throw new Exception("未找到库存信息!");
  5974. }
  5975. qjl.setUnlock_name(param1.get(5).toString());
  5976. mapper.UpdateQcmJudgeLocking(qjl);
  5977. SqlSession.commit();
  5978. }catch(Exception e){
  5979. cro.setV_errCode(-1);
  5980. cro.setV_errMsg(e.getMessage());
  5981. SqlSession.rollback();
  5982. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.doInformationGp:【" + param1.toString() + e);
  5983. }
  5984. SqlSession.close();
  5985. return cro;
  5986. }
  5987. /**
  5988. * 线棒改判 产品序号、锁定记录号、封锁来源、处置去向、处置去向说明、操作人,单项判定记录号、改判订单号,缺陷编码,改判牌号
  5989. */
  5990. @SuppressWarnings("rawtypes")
  5991. public CoreReturnObject doInformationGpXB(ArrayList param1) throws Exception{
  5992. try{
  5993. if(param1 == null || param1.size() <= 0){
  5994. throw new Exception("请传入参数!");
  5995. }
  5996. String sql = "select * from qcm_judge_locking where material_no = '"+param1.get(0).toString()+"' and lock_seq = '"+param1.get(1).toString()+"'";
  5997. QCMJudgeLocking qjl = mapper.queryQCMJudgeLockings(sql).get(0);
  5998. sql = "select * from zj_result_all@xgcx where BILLETID = '"+param1.get(0).toString()+"'";
  5999. List<HashMap> list1 = mapper.query(sql);
  6000. QcmJudgeSurfaceServiceImpl qjf = new QcmJudgeSurfaceServiceImpl();
  6001. List<HashMap> hashmap = doQueryMaterialInfoXB(param1.get(0).toString(),param1.get(7).toString());//线棒
  6002. if(hashmap == null || hashmap.size() <= 0){
  6003. throw new Exception("未找到相应订单标准!");
  6004. }
  6005. qjl.setUnlock_type_code("7");
  6006. qjl.setUnlock_type_desc("改判");
  6007. qjl.setUnlock_memo(param1.get(4).toString());
  6008. qjl.setUnlock_result(param1.get(9).toString());
  6009. qjl.setTarget_design_key(param1.get(7).toString());
  6010. qjl.setReason_code(param1.get(8).toString());
  6011. List<HashMap> listsu = qjf.finddefecttype(param1.get(8).toString());
  6012. if(listsu.size() >0)
  6013. {
  6014. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  6015. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  6016. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  6017. }
  6018. if(list1.size() >0){
  6019. if (list1.size() > 0) {
  6020. //发起改判
  6021. //查询订单标准
  6022. String sqlpicsmp= "select t.* from QCM_ORD_DESIGN_STD_PIC_SMP t "
  6023. +" where t.design_key = '"+param1.get(7).toString()+"' and rownum=1 ";
  6024. List<HashMap> hmpicsmp = mapper.query(sqlpicsmp);
  6025. if(hmpicsmp == null || hmpicsmp.size() <= 0){
  6026. throw new Exception("未找到相应订单标准!!");
  6027. }
  6028. //查询原信息
  6029. String sqlkcx= "select t.* from KCX_TURNOFFLIST@xgcx t where BILLETID = '"+param1.get(0).toString()+"' ";
  6030. List<HashMap> hmkcx = mapper.query(sqlkcx);
  6031. if(hmkcx == null || hmkcx.size() <= 0){
  6032. throw new Exception("未找到库存信息:"+param1.get(0).toString());
  6033. }
  6034. String kcxmemo = "改判订单:"+param1.get(7).toString()+",改判牌号:"+param1.get(9).toString()
  6035. +",原订单:"+hmkcx.get(0).get("ORDERNO")+",原入库牌号:"+hmkcx.get(0).get("INSTEEL")
  6036. +",原判定牌号"+hmkcx.get(0).get("DETERMINANTCARDNUMBER")+",原标准号:"+hmkcx.get(0).get("STANDARNO");
  6037. //更改库存信息
  6038. String upsql = " UPDATE KCX_TURNOFFLIST@xgcx T "
  6039. +" SET T.ORDERNO = '"+param1.get(7).toString()+"', "
  6040. +" T.INSTEEL = '"+param1.get(9).toString()+"', "
  6041. +" T.DETERMINANTCARDNUMBER = '"+param1.get(9).toString()+"', "
  6042. +" T.STANDARNO = '"+hmpicsmp.get(0).get("STD_NAME").toString()+"' "
  6043. +" WHERE BILLETID = '"+param1.get(0).toString()+"' ";
  6044. mapper.updateJudgeStatus(upsql.toString());
  6045. ZjResultAll zra = new ZjResultAll();
  6046. zra.setBilletid(param1.get(0).toString());
  6047. String sqllot="select t.* from qcm_jhy_sample_consign_d t,qcm_jhy_sample_r_ord r "
  6048. +" where t.smp_no = r.smp_no and r.design_key = '"+param1.get(7).toString()+"' and r.batch_no ='"+param1.get(11).toString()+"' "
  6049. +" and t.Smp_Type_Code = '0' and t.pline_code in ('GX1','GX2','BC2') and rownum=1 ";
  6050. List<HashMap> listlot = mapper.query(sqllot);
  6051. if(listlot ==null || listlot.size()<=0){
  6052. String INSPECTION_LOT = SendGenerationSampleInfo1XB(hashmap, param1, "2", "1");
  6053. zra.setNew_inspection_lot(INSPECTION_LOT);
  6054. }else{
  6055. zra.setNew_inspection_lot(listlot.get(0).get("INSPECTION_LOT").toString());
  6056. }
  6057. zra.setPhysresult("0");
  6058. zra.setPhyfstsresult("0");
  6059. zra.setPhysresult_desc("");
  6060. zra.setPhyfstsresult_desc("");
  6061. zra.setPhysid("");
  6062. zra.setPhyfstsid("");
  6063. zra.setPic_is_lock("0");
  6064. mapper.UpdateJugeResultB(zra);
  6065. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  6066. qjog.setOperate_name(param1.get(5).toString());
  6067. qjog.setOperate_type("改判");
  6068. qjog.setParams(param1.get(0).toString());
  6069. qjog.setBatchno(qjl.getBatch_no());
  6070. qjog.setProd_line(qjl.getPline_code());
  6071. qjog.setMemo(kcxmemo);
  6072. mapper.insertQcmJudgeOperateLog(qjog);
  6073. }
  6074. }else{
  6075. throw new Exception("未找到库存信息!");
  6076. }
  6077. qjl.setUnlock_name(param1.get(5).toString());
  6078. mapper.UpdateQcmJudgeLocking(qjl);
  6079. SqlSession.commit();
  6080. }catch(Exception e){
  6081. cro.setV_errCode(-1);
  6082. cro.setV_errMsg(e.getMessage());
  6083. SqlSession.rollback();
  6084. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.doInformationGpXB:【" + param1.toString() + e);
  6085. }
  6086. SqlSession.close();
  6087. return cro;
  6088. }
  6089. @SuppressWarnings("rawtypes")
  6090. public List<HashMap> doQueryMaterialInfoXB(String material_no,String design_key) {
  6091. String swhere = "";
  6092. String swhere1 = "";
  6093. String sql = "SELECT * FROM (SELECT T.ORDERNO DESIGN_KEY,A.PSRNO PSC,T.STOVENO HEAT_NO,T.ROLLNUMBER BATCH_NO, "
  6094. +" T.ROLLNUMBER BOARD_NO,T.DETERMINANTCARDNUMBER GRADE_CODE,T.DETERMINANTCARDNUMBER GRADE_NAME, "
  6095. +" T.BILLETID MATERIAL_NO,'L-HPT-00005872' MSC_PLINE,substr(T.PLD, 5, 3) PLINE_CODE,C2N@xgcx(T.PLD) PLINE_NAME, "
  6096. +" A.STANDROLLER DELIVERY_STATE_CODE,A.STANDSTATUS DELIVERY_STATE_DESC,'HR' PROCESS_CODE, A.HEIGHT THICK, "
  6097. +" A.WIDTH WIDTH,A.LENGTH LENGTH,nvl(T.BILLETID_SY, T.ROLLNUMBER || '0001') INSPECTION_LOT, "
  6098. +" (select CASE WHEN COUNT(1) > 0 THEN '1' ELSE '0' END from QCM_ORD_DESIGN_SAMPLE_M where design_key = '"+design_key+"') IS_QTLY, "
  6099. +" (select CASE WHEN COUNT(1) > 0 THEN '1' ELSE '0' END from QCM_ORD_DESIGN_STD_CIC where design_key = '"+design_key+"' "
  6100. +" and std_type_code = 'C') IS_CHEM, '0' TYPE,' ' MEMO, nvl(A.XB_BATCHWEIGHT_MAX, '0') WEIGHT_STD, "
  6101. +" nvl((select sum(WEIGHT) from kcx_stuffoutstorage@xgcx where ROLLNO = t.rollnumber AND ISVALID = '1'), "
  6102. +" (select sum(THEORYWEIGHT) from kcx_turnofflist where ROLLNUMBER = t.rollnumber)) WEIGHT, "
  6103. +" nvl(A.ADDFREQNUM, '0') WEIGHT_SFD "
  6104. +" FROM KCX_TURNOFFLIST@xgcx T, SEL_PACTDETAIL_NEW@xgcx A "
  6105. +" WHERE T.ORDERNO = A.ORDERNO "
  6106. +" and T.BILLETID = '"+material_no+"' "
  6107. +" order by t.intime desc) "
  6108. +" WHERE (IS_QTLY <> 0 OR IS_CHEM > 0) ";
  6109. try {
  6110. System.out.print(sql);
  6111. List<HashMap> list = mapper.query(sql);
  6112. return list;
  6113. } catch (Exception ex) {
  6114. ex.printStackTrace();
  6115. }
  6116. SqlSession.close();
  6117. return null;
  6118. }
  6119. public String SendGenerationSampleInfo1XB(List<HashMap> hashmap,ArrayList param1,String type,String type2)throws Exception{
  6120. JSONObject jsobj1 = new JSONObject();
  6121. JSONObject jsobj2 = new JSONObject();
  6122. JSONArray ttmaps = new JSONArray();
  6123. if(hashmap.size() == 0){
  6124. throw new Exception("找不到库存!");
  6125. }
  6126. String smp_no = "";
  6127. String psc = "";
  6128. //QcmJhySampleROrd qjsp = mapper.queryQcmJhySampleROrd(hashmap.get(0).get("DESIGN_KEY").toString());
  6129. String jyh=hashmap.get(0).get("INSPECTION_LOT").toString().substring(0,hashmap.get(0).get("INSPECTION_LOT").toString().length()-4);
  6130. String sql = "select max(billetid_jy) INSPECTION_LOT from (select billetid_jy from zj_result_all@xgcx where billetid like '"+jyh+"%')";
  6131. List<HashMap> t = mapper.query(sql);
  6132. String s = t.get(0).get("INSPECTION_LOT") == null?"": t.get(0).get("INSPECTION_LOT").toString();
  6133. int count=Integer.parseInt(s.substring(s.length()-4, s.length()));
  6134. count++;
  6135. String INSPECTION_LOT=s.substring(0,s.length()-4)+String.format("%04d",count);
  6136. jsobj2.put("INSPECTION_LOT", INSPECTION_LOT);
  6137. jsobj2.put("DESIGN_KEY", param1.get(7).toString());
  6138. jsobj2.put("PSC", hashmap.get(0).get("PSC")==null?"":hashmap.get(0).get("PSC").toString());//qjsp.getPsc()
  6139. jsobj2.put("HEAT_NO", hashmap.get(0).get("HEAT_NO")==null?"":hashmap.get(0).get("HEAT_NO").toString());
  6140. jsobj2.put("BATCH_NO", hashmap.get(0).get("BATCHNO")==null?"":hashmap.get(0).get("BATCHNO").toString());
  6141. jsobj2.put("BOARD_NO", hashmap.get(0).get("BOARD_NO")==null?"":hashmap.get(0).get("BOARD_NO").toString());
  6142. jsobj2.put("GRADE_CODE", hashmap.get(0).get("GRADE_CODE")==null?"":hashmap.get(0).get("GRADE_CODE").toString());
  6143. jsobj2.put("GRADE_NAME", hashmap.get(0).get("GRADE_NAME")==null?"":hashmap.get(0).get("GRADE_NAME").toString());
  6144. jsobj2.put("PLINE_ABBR", hashmap.get(0).get("PLINE_ABBR")==null?"":hashmap.get(0).get("PLINE_ABBR").toString());
  6145. jsobj2.put("MATERIAL_NO", hashmap.get(0).get("MATERIAL_NO")==null?"":hashmap.get(0).get("MATERIAL_NO").toString());
  6146. jsobj2.put("MSC_PLINE", hashmap.get(0).get("MSC_PLINE")==null?"":hashmap.get(0).get("MSC_PLINE").toString());//qjsp.getMsc_pline()==null?"12345":qjsp.getMsc_pline()
  6147. jsobj2.put("PLINE_CODE", hashmap.get(0).get("PLINE_CODE")==null?"":hashmap.get(0).get("PLINE_CODE").toString());
  6148. jsobj2.put("PLINE_NAME", hashmap.get(0).get("PLINE_NAME")==null?"":hashmap.get(0).get("PLINE_NAME").toString());
  6149. jsobj2.put("DELIVERY_STATE_CODE", hashmap.get(0).get("DELIVERY_STATE_CODE")==null?"":hashmap.get(0).get("DELIVERY_STATE_CODE").toString());
  6150. jsobj2.put("DELIVERY_STATE_DESC", hashmap.get(0).get("DELIVERY_STATE_DESC")==null?"":hashmap.get(0).get("DELIVERY_STATE_DESC").toString());
  6151. jsobj2.put("PROCESS_CODE", "");
  6152. jsobj2.put("THICK", hashmap.get(0).get("THICK")==null?"": hashmap.get(0).get("THICK").toString());
  6153. jsobj2.put("WIDTH", hashmap.get(0).get("WIDTH")==null?"":hashmap.get(0).get("WIDTH").toString());
  6154. jsobj2.put("LENGTH", hashmap.get(0).get("LENGTH")==null?"": hashmap.get(0).get("LENGTH").toString());
  6155. jsobj2.put("IS_QTLY", "1");
  6156. jsobj2.put("IS_CHEM", "0");
  6157. jsobj2.put("TYPE", type);
  6158. jsobj2.put("MEMO", param1.get(12).toString());
  6159. jsobj2.put("QLTY_SMP_NO", "");
  6160. jsobj2.put("WEIGHT_STD", hashmap.get(0).get("WEIGHT_STD")==null?"":hashmap.get(0).get("WEIGHT_STD").toString());
  6161. jsobj2.put("WEIGHT", hashmap.get(0).get("WEIGHT")==null?"":hashmap.get(0).get("WEIGHT").toString());
  6162. jsobj2.put("WEIGHT_SFD", hashmap.get(0).get("WEIGHT_SFD")==null?"":hashmap.get(0).get("WEIGHT_SFD").toString());
  6163. ttmaps.add(jsobj2);
  6164. jsobj1.put("KEY", ttmaps);
  6165. WebService1Impl web = new WebService1Impl();
  6166. //委托
  6167. try {
  6168. String result = web.autoGenerationSampleInfo(jsobj1.toString());
  6169. if(!result.equals("1")){
  6170. throw new Exception(result);
  6171. }
  6172. } catch (Exception e) {
  6173. // TODO Auto-generated catch block
  6174. throw new Exception(e.getMessage());
  6175. }
  6176. return INSPECTION_LOT;
  6177. }
  6178. /**param1 改判除外的异常材处置
  6179. * 产品序号、锁定记录号、封锁来源、处置去向、处置去向说明、操作人,单项判定记录号,成分处置类型,抽查备注、修磨备注、放行化验号
  6180. * @param param1
  6181. * @return
  6182. * @throws Exception
  6183. */
  6184. @SuppressWarnings({ "rawtypes", "static-access" })
  6185. public CoreReturnObject doInformationLgSure(final ArrayList param1) throws Exception{
  6186. try{
  6187. if(param1 == null || param1.size() <= 0){
  6188. throw new Exception("请传入参数!");
  6189. }
  6190. String sql = "select * from qcm_judge_locking where material_no = '"+param1.get(0).toString()+"' and lock_seq = '"+param1.get(1).toString()+"' and unlock_type_code is null";
  6191. List<QCMJudgeLocking> qjls = mapper.queryQCMJudgeLockings(sql);
  6192. if(qjls.size() == 0){
  6193. throw new Exception("该处置信息已被处置,未找到信息!");
  6194. }
  6195. final QCMJudgeLocking qjl = mapper.queryQCMJudgeLockings(sql).get(0);
  6196. //放行
  6197. if(param1.get(3).toString().equals("0")){
  6198. qjl.setUnlock_type_code("0");
  6199. qjl.setUnlock_type_desc("放行");
  6200. qjl.setUnlock_memo(param1.get(4).toString());
  6201. qjl.setUnlock_result(param1.get(7).toString());
  6202. //表面放行
  6203. if(param1.get(2).toString().equals("F")){
  6204. qjl.setFic_locking("0");
  6205. sql = "select * from qcm_judge_surface where material_no = '"+param1.get(0).toString()+"' order by JUDGE_TIME desc";
  6206. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  6207. QcmJudgeSurface qjsf = new QcmJudgeSurface();
  6208. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  6209. qjsf.setSfd_is_lock("2");
  6210. qjsf.setSfe_is_lock("2");
  6211. qjsf.setSfu_is_lock("2");
  6212. mapper.UpdateQcmJudgeSurface(qjsf);
  6213. qjl.setUnlock_name(param1.get(5).toString());
  6214. qjl.setLock_type_code("F");
  6215. mapper.UpdateQcmJudgeLocking2(qjl);
  6216. //调用单项判定
  6217. JSONObject jsobj2 = new JSONObject();
  6218. JSONArray ttmaps = new JSONArray();
  6219. JSONObject jsobj1 = new JSONObject();
  6220. jsobj1.put("CHEMRESULT_LK","");
  6221. jsobj1.put("FACERESULT","5");
  6222. jsobj1.put("COMPREHENSIVERESULT","");
  6223. jsobj1.put("CHEMJUDGEID","");
  6224. jsobj1.put("FACECHECKID",qjl.getLock_id());
  6225. jsobj1.put("COMPREHENSIVEID","");
  6226. jsobj1.put("JUDGE_TYPE","S");
  6227. jsobj1.put("PROD_LINE",qjl.getPline_code());
  6228. jsobj1.put("ISJUDGE","1");
  6229. jsobj1.put("PROD_TYPE",qjl.getProd_name());
  6230. jsobj1.put("SLAB_NO",qjl.getMaterial_no());
  6231. jsobj1.put("CHECKNO","");
  6232. jsobj1.put("OPTMAN", param1.get(5).toString());
  6233. jsobj1.put("ISFX", "0");
  6234. jsobj1.put("CHEMRESULT_FX", "");
  6235. jsobj1.put("REMARK", param1.get(4).toString());
  6236. ttmaps.add(jsobj1);
  6237. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  6238. String result = callWebserviceASMX(url,"ChemJudge",JSON.toJSONString(ttmaps));
  6239. JSONObject jo = JSONObject.parseObject(result);
  6240. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  6241. qjog.setOperate_name(param1.get(5).toString());
  6242. qjog.setOperate_type("表面放行");
  6243. qjog.setParams(param1.get(0).toString());
  6244. qjog.setBatchno(qjl.getBatch_no());
  6245. qjog.setProd_line(qjl.getPline_code());
  6246. mapper.insertQcmJudgeOperateLog(qjog);
  6247. if(jo.get("code").toString().equals("1")){
  6248. throw new Exception("表面放行失败!"+jo.get("message").toString());
  6249. }
  6250. //LgultimateJudgeAutoBySystem(qjl.getMaterial_no(),param1.get(5).toString(),qjl.getPline_code(),qjl.getProd_name());
  6251. SqlSession.commit();
  6252. }
  6253. if(param1.get(2).toString().equals("C")){
  6254. qjl.setCic_locking("0");
  6255. qjl.setUnlock_name(param1.get(5).toString());
  6256. qjl.setLock_type_code("C");
  6257. sql = "select * from QCM_JUDGE_CHEMICAL where CIC_ID = '"+param1.get(6).toString()+"'";
  6258. List<QcmJudgeChemical> qjf = mapper.queryQcmJudgeChemical(sql);
  6259. Date now = new Date();
  6260. String opr_time = new SimpleDateFormat("yyyyMMddHHmmss").format(now); //操作时间
  6261. SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
  6262. String date=sdf.format(now);
  6263. int count=0;
  6264. String type1 = "";
  6265. type1 = "AP";
  6266. sql ="select * from (select * from qcm_judge_locking_apply where apply_id like '"+type1+date+"%' order by apply_id desc) where rownum <= 1";
  6267. List<QcmJudgeLockingApply> listUl=mapper.QcmJudgeLockingApply(sql);
  6268. if (listUl!=null&&listUl.size()>0) {
  6269. String s=listUl.get(0).getApply_id();
  6270. count=Integer.parseInt(s.substring(s.length()-4,s.length()));
  6271. }
  6272. count++;
  6273. String APPLY_ID=type1+sdf.format(now)+String.format("%04d",count);
  6274. qjl.setApply_id(APPLY_ID);
  6275. //if(param1.get(10).toString().equals(qjf.get(0).getAssay_no_rl()) || param1.get(10).toString().equals("")){
  6276. mapper.UpdateQcmJudgeLocking2(qjl);
  6277. //调用单项判定
  6278. JSONObject jsobj2 = new JSONObject();
  6279. JSONArray ttmaps = new JSONArray();
  6280. JSONObject jsobj1 = new JSONObject();
  6281. jsobj1.put("CHEMRESULT_LK","2");
  6282. jsobj1.put("FACERESULT","");
  6283. jsobj1.put("COMPREHENSIVERESULT","");
  6284. jsobj1.put("CHEMJUDGEID",qjl.getLock_id());
  6285. jsobj1.put("FACECHECKID","");
  6286. jsobj1.put("COMPREHENSIVEID","");
  6287. jsobj1.put("JUDGE_TYPE","C");
  6288. jsobj1.put("PROD_LINE",qjl.getPline_code());
  6289. jsobj1.put("ISJUDGE","1");
  6290. jsobj1.put("PROD_TYPE",qjl.getProd_name());
  6291. jsobj1.put("SLAB_NO",qjl.getMaterial_no());
  6292. jsobj1.put("CHECKNO",qjf.get(0).getAssay_no_rl());
  6293. jsobj1.put("OPTMAN", param1.get(5).toString());
  6294. jsobj1.put("ISFX", "1");
  6295. jsobj1.put("CHEMRESULT_FX", "5");
  6296. jsobj1.put("REMARK", param1.get(4).toString());
  6297. ttmaps.add(jsobj1);
  6298. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  6299. String result = callWebserviceASMX(url,"ChemJudge",JSON.toJSONString(ttmaps));
  6300. JSONObject jo = JSONObject.parseObject(result);
  6301. if(jo.get("code").toString().equals("1")){
  6302. throw new Exception("成分放行失败!"+jo.get("message").toString());
  6303. }
  6304. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  6305. qjog.setOperate_name(param1.get(5).toString());
  6306. qjog.setOperate_type("成分放行");
  6307. qjog.setParams(param1.get(0).toString());
  6308. qjog.setBatchno(qjl.getBatch_no());
  6309. qjog.setProd_line(qjl.getPline_code());
  6310. mapper.insertQcmJudgeOperateLog(qjog);
  6311. QcmJudgeLockingApply qjla = new QcmJudgeLockingApply();
  6312. qjla.setApply_id(APPLY_ID);
  6313. qjla.setMaterial_no(qjl.getMaterial_no());
  6314. qjla.setLock_seq(qjl.getLock_seq());
  6315. qjla.setLock_type_code(qjl.getLock_type_code());
  6316. qjla.setLock_type_desc(qjl.getLock_type_desc());
  6317. qjla.setLock_memo(qjl.getLock_memo());
  6318. qjla.setUnlock_type_code(qjl.getUnlock_type_code());
  6319. qjla.setUnlock_type_desc(qjl.getUnlock_type_desc());
  6320. qjla.setUnlock_memo(qjl.getUnlock_memo());
  6321. qjla.setHeat_no(qjl.getHeat_no());
  6322. qjla.setBatch_no(qjl.getBatch_no());
  6323. qjla.setBoard_no(qjl.getBoard_no());
  6324. qjla.setPlan_no(qjl.getPlan_no());
  6325. qjla.setHt_no(qjl.getHt_no());
  6326. qjla.setDesign_key(qjl.getDesign_key());
  6327. qjla.setPsc(qjl.getPsc());
  6328. qjla.setPsc_desc(qjl.getPsc_desc());
  6329. qjla.setPline_code(qjl.getPline_code());
  6330. qjla.setPline_name(qjl.getPline_name());
  6331. qjla.setProd_code(qjl.getProd_code());
  6332. qjla.setProd_name(qjl.getProd_name());
  6333. qjla.setSteel_code(qjl.getSteel_code());
  6334. qjla.setSteel_name(qjl.getSteel_name());
  6335. qjla.setStd_code(qjl.getStd_code());
  6336. qjla.setStd_name(qjl.getStd_name());
  6337. qjla.setLock_id(qjl.getLock_id());
  6338. qjla.setCreate_id("");
  6339. qjla.setCreate_name(qjl.getUnlock_name());
  6340. qjla.setHeight(qjl.getHeight());
  6341. mapper.insertQCMJudgeLockingApply(qjla);
  6342. JSONArray ttmaps1 = new JSONArray();
  6343. JSONObject jsobj3 = new JSONObject();
  6344. jsobj3.put("PROD_LINE", qjl.getPline_code());
  6345. jsobj3.put("SLAB_NO",qjl.getMaterial_no());
  6346. jsobj3.put("PROD_TYPE",qjl.getProd_name());
  6347. jsobj3.put("REMARK",param1.get(4).toString());
  6348. if(qjl.getPline_code().equals("4001LGX")){
  6349. jsobj3.put("P_NO_HOT_REASON", "");
  6350. jsobj3.put("P_NO_DIRECT_REASON","");
  6351. jsobj3.put("P_NO_CRAFT_STEELNAME","");
  6352. jsobj3.put("REMARK",param1.get(4).toString());
  6353. jsobj3.put("P_REG_NM",param1.get(5).toString());
  6354. }
  6355. ttmaps1.add(jsobj3);
  6356. result = QcmJhyElementsServiceImpl.callWebserviceASMX(url,"SlabDetailInput",JSON.toJSONString(ttmaps1));
  6357. JSONObject jo1 = JSONObject.parseObject(result);
  6358. if(jo1.get("code").toString().equals("1")){
  6359. throw new Exception("备注录入失败!"+jo.get("message").toString());
  6360. }
  6361. SqlSession.commit();
  6362. //订单号为空直接放行
  6363. if(StringUtils.isBlank(qjl.getDesign_key())){
  6364. doApply(APPLY_ID,"默认放行","1");
  6365. }
  6366. /*}else{
  6367. qjl.setCic_locking("0");
  6368. qjl.setLock_type_code("C");
  6369. qjl.setUnlock_type_code("1");
  6370. qjl.setUnlock_type_desc("复样");
  6371. mapper.UpdateQcmJudgeLocking2(qjl);
  6372. JSONObject jsobj2 = new JSONObject();
  6373. JSONArray ttmaps = new JSONArray();
  6374. JSONObject jsobj1 = new JSONObject();
  6375. jsobj1.put("CHEMRESULT_LK", "");
  6376. jsobj1.put("FACERESULT","");
  6377. jsobj1.put("COMPREHENSIVERESULT","");
  6378. jsobj1.put("CHEMJUDGEID",qjl.getLock_id());
  6379. jsobj1.put("FACECHECKID","");
  6380. jsobj1.put("COMPREHENSIVEID","");
  6381. jsobj1.put("JUDGE_TYPE","C");
  6382. jsobj1.put("PROD_LINE",qjl.getPline_code());
  6383. jsobj1.put("ISJUDGE","2");
  6384. jsobj1.put("PROD_TYPE",qjl.getProd_name());
  6385. jsobj1.put("SLAB_NO",qjl.getMaterial_no());
  6386. jsobj1.put("CHECKNO","");
  6387. jsobj1.put("OPTMAN", param1.get(5).toString());
  6388. jsobj1.put("ISFX", "0");
  6389. jsobj1.put("CHEMRESULT_FX", "");
  6390. jsobj1.put("REMARK", param1.get(4).toString());
  6391. ttmaps.add(jsobj1);
  6392. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  6393. String result = callWebserviceASMX(url,"ChemJudge",JSON.toJSONString(ttmaps));
  6394. JSONObject jo = JSONObject.parseObject(result);
  6395. if(jo.get("code").toString().equals("1")){
  6396. throw new Exception("成分复样失败!"+jo.get("message").toString());
  6397. }
  6398. SqlSession.commit();
  6399. LGRlChemJudgeBySystem1(qjl.getHeat_no(), qjl.getMaterial_no(), qjl.getDesign_key(), param1.get(5).toString(), qjl.getSteel_name(), qjl.getProd_name(), qjl.getPline_code(),param1.get(10).toString());
  6400. }*/
  6401. //LgultimateJudgeAutoBySystem(qjl.getMaterial_no(),param1.get(5).toString(),qjl.getPline_code(),qjl.getProd_name());
  6402. }
  6403. }
  6404. //复样
  6405. if(param1.get(3).toString().equals("1")){
  6406. //重新
  6407. //质量锁定解锁
  6408. qjl.setUnlock_type_code("1");
  6409. qjl.setUnlock_type_desc("复样");
  6410. qjl.setUnlock_memo(param1.get(4).toString());
  6411. qjl.setUnlock_name(param1.get(5).toString());
  6412. /*QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  6413. List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(param1.get(0).toString());
  6414. if(hashmap.size() == 0){
  6415. hashmap = qjms.doQueryMaterialInfoJ(param1.get(0).toString());
  6416. }*/
  6417. if(param1.get(2).toString().equals("C")){
  6418. qjl.setCic_locking("0");
  6419. qjl.setLock_type_code("C");
  6420. JSONObject jsobj2 = new JSONObject();
  6421. JSONArray ttmaps = new JSONArray();
  6422. JSONObject jsobj1 = new JSONObject();
  6423. jsobj1.put("CHEMRESULT_LK", "");
  6424. jsobj1.put("FACERESULT","");
  6425. jsobj1.put("COMPREHENSIVERESULT","");
  6426. jsobj1.put("CHEMJUDGEID",qjl.getLock_id()==null?"":qjl.getLock_id());
  6427. jsobj1.put("FACECHECKID","");
  6428. jsobj1.put("COMPREHENSIVEID","");
  6429. jsobj1.put("JUDGE_TYPE","C");
  6430. jsobj1.put("PROD_LINE",qjl.getPline_code());
  6431. jsobj1.put("ISJUDGE","2");
  6432. jsobj1.put("PROD_TYPE",qjl.getProd_name());
  6433. jsobj1.put("SLAB_NO",qjl.getMaterial_no());
  6434. jsobj1.put("CHECKNO","");
  6435. jsobj1.put("OPTMAN", param1.get(5).toString());
  6436. jsobj1.put("ISFX", "0");
  6437. jsobj1.put("CHEMRESULT_FX", "");
  6438. jsobj1.put("REMARK", param1.get(4).toString());
  6439. ttmaps.add(jsobj1);
  6440. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  6441. String result = callWebserviceASMX(url,"ChemJudge",JSON.toJSONString(ttmaps));
  6442. JSONObject jo = JSONObject.parseObject(result);
  6443. if(jo.get("code").toString().equals("1")){
  6444. throw new Exception("成分复样失败!"+jo.get("message").toString());
  6445. }
  6446. //调用单项判定
  6447. }else{
  6448. throw new Exception("封锁来源与所选的异常材处置操作不一致,请重新选择处置操作!");
  6449. }
  6450. mapper.UpdateQcmJudgeLocking2(qjl);
  6451. SqlSession.commit();
  6452. LGRlChemJudgeBySystem(qjl.getHeat_no(), qjl.getMaterial_no(), qjl.getDesign_key(), param1.get(5).toString(), qjl.getSteel_name(), qjl.getProd_name(), qjl.getPline_code(),"0");
  6453. }
  6454. //修磨
  6455. if(param1.get(3).toString().equals("2")){
  6456. //查询最新的修磨备注,抽查备注,跟后面的修磨备注,抽查备注拼接起来
  6457. String sql1 = "select * from (select t.*\r\n" +
  6458. " from qcm_judge_locking t\r\n" +
  6459. " where t.material_no = '"+param1.get(0).toString()+"'"+"\r\n" +
  6460. " and t.unlock_type_code = '3'\r\n" +
  6461. " and (t.fix_remarks is not null or t.check_remarks is not null)\r\n" +
  6462. " order by t.unlock_time desc) where rownum = 1";
  6463. List<QCMJudgeLocking> qj2 = mapper.queryQCMJudgeLockings(sql1);
  6464. QCMJudgeLocking qj3 = new QCMJudgeLocking();
  6465. String Fix_remarks = "";
  6466. String Check_remarks = "";
  6467. if(qj2.size() >0){
  6468. qj3 = qj2.get(0);
  6469. Fix_remarks = qj3.getFix_remarks();
  6470. Check_remarks = qj3.getCheck_remarks();
  6471. }
  6472. if(!param1.get(2).toString().equals("F")){
  6473. throw new Exception("封锁来源与所选的异常材处置操作不一致,请重新选择处置操作!");
  6474. }
  6475. qjl.setUnlock_type_code("3");
  6476. qjl.setUnlock_type_desc("修磨");
  6477. qjl.setUnlock_memo(param1.get(4).toString());
  6478. qjl.setFic_locking("0");
  6479. qjl.setUnlock_name(param1.get(5).toString());
  6480. qjl.setLock_type_code("F");
  6481. qjl.setCheck_remarks(Fix_remarks+""+param1.get(8).toString());
  6482. qjl.setFix_remarks(Check_remarks+""+param1.get(9).toString());
  6483. //质量锁定解锁
  6484. mapper.UpdateQcmJudgeLocking2(qjl);
  6485. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  6486. qjog.setOperate_name(param1.get(5).toString());
  6487. qjog.setOperate_type("修磨");
  6488. qjog.setParams(param1.get(0).toString());
  6489. qjog.setBatchno(qjl.getBatch_no());
  6490. qjog.setProd_line(qjl.getPline_code());
  6491. mapper.insertQcmJudgeOperateLog(qjog);
  6492. sql = "select * from qcm_judge_surface where material_no = '"+param1.get(0).toString()+"' and surface_id = '"+param1.get(6).toString()+"' order by JUDGE_TIME desc";
  6493. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  6494. QcmJudgeSurface qjsf = qjf.get(0);
  6495. qjsf.setSfd_is_lock("0");
  6496. qjsf.setSfe_is_lock("0");
  6497. qjsf.setSfu_is_lock("0");
  6498. qjsf.setSf_result_code("1");
  6499. qjsf.setSf_result_desc("合格");
  6500. qjsf.setLevel_code("512601");
  6501. qjsf.setLevel_desc("正品");
  6502. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  6503. //表面锁定解锁
  6504. mapper.UpdateQcmJudgeSurface1(qjsf);
  6505. sql = "select * from qcm_judge_surface_flaw a where a.surface_id = '"+param1.get(6).toString()+"' ";
  6506. List<QcmJudgeSurfaceFlaw> qjsfl = mapper.queryQcmJudgeSurfaceFlaw(sql);
  6507. for(QcmJudgeSurfaceFlaw qjs : qjsfl){
  6508. mapper.UpdateSurfaceFlaw(qjs.getSurface_id().toString(),qjs.getFlaw_seq().toString(),"1");
  6509. }
  6510. //库存解锁
  6511. //调用单项判定
  6512. //修磨完成后表面默认合格
  6513. JSONObject jsobj2 = new JSONObject();
  6514. JSONArray ttmaps = new JSONArray();
  6515. JSONArray ttmaps1 = new JSONArray();
  6516. JSONObject jsobj1 = new JSONObject();
  6517. jsobj1.put("CHEMRESULT_LK","");
  6518. jsobj1.put("FACERESULT","1");
  6519. jsobj1.put("COMPREHENSIVERESULT","");
  6520. jsobj1.put("CHEMJUDGEID","");
  6521. jsobj1.put("FACECHECKID",qjl.getLock_id());
  6522. jsobj1.put("COMPREHENSIVEID","");
  6523. jsobj1.put("JUDGE_TYPE","S");
  6524. jsobj1.put("PROD_LINE",qjl.getPline_code());
  6525. jsobj1.put("ISJUDGE","1");
  6526. jsobj1.put("PROD_TYPE",qjl.getProd_name());
  6527. jsobj1.put("SLAB_NO",qjl.getMaterial_no());
  6528. jsobj1.put("CHECKNO","");
  6529. jsobj1.put("OPTMAN", param1.get(5).toString());
  6530. jsobj1.put("ISFX", "0");
  6531. jsobj1.put("CHEMRESULT_FX", "");
  6532. jsobj1.put("REMARK", param1.get(4).toString());
  6533. ttmaps.add(jsobj1);
  6534. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  6535. String result = callWebserviceASMX(url,"ChemJudge",JSON.toJSONString(ttmaps));
  6536. JSONObject jo = JSONObject.parseObject(result);
  6537. if(jo.get("code").toString().equals("1")){
  6538. throw new Exception("修磨失败!"+jo.get("message").toString());
  6539. }
  6540. if(qjl.getPline_code().equals("4001LGX")){
  6541. JSONObject jsobj3 = new JSONObject();
  6542. jsobj3.put("PROD_LINE", qjl.getPline_code());
  6543. jsobj3.put("SLAB_NO",qjl.getMaterial_no());
  6544. jsobj3.put("PROD_TYPE",qjl.getProd_name());
  6545. jsobj3.put("REMARK","1");
  6546. jsobj3.put("P_NO_HOT_REASON", "");
  6547. jsobj3.put("P_NO_DIRECT_REASON","");
  6548. jsobj3.put("P_NO_CRAFT_STEELNAME","");
  6549. jsobj3.put("REMARK","");
  6550. jsobj3.put("P_REG_NM",param1.get(5).toString());
  6551. jsobj3.put("SPOTING_REMARK", param1.get(8).toString());
  6552. jsobj3.put("COPING_REMARK", param1.get(9).toString());
  6553. ttmaps1.add(jsobj3);
  6554. result = QcmJhyElementsServiceImpl.callWebserviceASMX(url,"SlabDetailInput",JSON.toJSONString(ttmaps1));
  6555. jo = JSONObject.parseObject(result);
  6556. if(jo.get("code").toString().equals("1")){
  6557. throw new Exception("备注录入失败!"+jo.get("message").toString());
  6558. }
  6559. }
  6560. LgultimateJudgeAutoBySystem(qjl.getMaterial_no(),param1.get(5).toString(),qjl.getPline_code(),qjl.getProd_name());
  6561. SqlSession.commit();
  6562. }
  6563. //判次
  6564. if(param1.get(3).toString().equals("4")){
  6565. qjl.setUnlock_type_code("5");
  6566. qjl.setUnlock_type_desc("判次");
  6567. qjl.setUnlock_memo(param1.get(4).toString());
  6568. if(param1.get(2).toString().equals("F")){
  6569. qjl.setFic_locking("0");
  6570. qjl.setLock_type_code("F");
  6571. sql = "select * from qcm_judge_surface where material_no = '"+param1.get(0).toString()+"' order by JUDGE_TIME desc";
  6572. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  6573. String s = mapper.query("SELECT to_char(wmsys.wm_concat(distinct FLAW_DESC)) memo FROM QCM_JUDGE_SURFACE_FLAW A WHERE A.SURFACE_ID = '"+qjl.getLock_id()+"'").get(0).get("MEMO").toString();
  6574. QcmJudgeSurface qjsf = new QcmJudgeSurface();
  6575. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  6576. qjsf.setSfd_is_lock("0");
  6577. qjsf.setSfe_is_lock("0");
  6578. qjsf.setSfu_is_lock("0");
  6579. mapper.UpdateQcmJudgeSurface(qjsf);
  6580. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  6581. qjog.setOperate_name(param1.get(5).toString());
  6582. qjog.setOperate_type("表面判次");
  6583. qjog.setParams(param1.get(0).toString());
  6584. qjog.setBatchno(qjl.getBatch_no());
  6585. qjog.setProd_line(qjl.getPline_code());
  6586. mapper.insertQcmJudgeOperateLog(qjog);
  6587. //修改库存锁定
  6588. JSONObject jsobj2 = new JSONObject();
  6589. JSONArray ttmaps = new JSONArray();
  6590. JSONObject jsobj1 = new JSONObject();
  6591. jsobj1.put("CHEMRESULT_LK", "");
  6592. jsobj1.put("FACERESULT","3");
  6593. jsobj1.put("COMPREHENSIVERESULT","");
  6594. jsobj1.put("CHEMJUDGEID","");
  6595. jsobj1.put("FACECHECKID",qjl.getLock_id());
  6596. jsobj1.put("COMPREHENSIVEID","");
  6597. jsobj1.put("JUDGE_TYPE","S");
  6598. jsobj1.put("PROD_LINE",qjl.getPline_code());
  6599. jsobj1.put("ISJUDGE","1");
  6600. jsobj1.put("PROD_TYPE",qjl.getProd_name());
  6601. jsobj1.put("SLAB_NO",qjl.getMaterial_no());
  6602. jsobj1.put("CHECKNO","");
  6603. jsobj1.put("OPTMAN", param1.get(5).toString());
  6604. jsobj1.put("ISFX", "0");
  6605. jsobj1.put("CHEMRESULT_FX", "");
  6606. jsobj1.put("REMARK", param1.get(4).toString());
  6607. jsobj1.put("XXREASON", s);
  6608. ttmaps.add(jsobj1);
  6609. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  6610. String result= callWebserviceASMX(url,"ChemJudge",JSON.toJSONString(ttmaps));
  6611. JSONObject jo = JSONObject.parseObject(result);
  6612. if(jo.get("code").toString().equals("1")){
  6613. throw new Exception("表面判次失败!"+jo.get("message").toString());
  6614. }
  6615. }
  6616. if(param1.get(2).toString().equals("C")){
  6617. qjl.setCic_locking("0");
  6618. qjl.setLock_type_code("C");
  6619. sql = "select * from QCM_JUDGE_CHEMICAL where CIC_ID = '"+param1.get(6).toString()+"'";
  6620. List<QcmJudgeChemical> qjf = mapper.queryQcmJudgeChemical(sql);
  6621. //修改库存锁定
  6622. //更改合同试样表
  6623. JSONObject jsobj2 = new JSONObject();
  6624. JSONArray ttmaps = new JSONArray();
  6625. JSONObject jsobj1 = new JSONObject();
  6626. jsobj1.put("CHEMRESULT_LK", "");
  6627. jsobj1.put("FACERESULT","");
  6628. jsobj1.put("COMPREHENSIVERESULT","");
  6629. jsobj1.put("CHEMJUDGEID",qjl.getLock_id());
  6630. jsobj1.put("FACECHECKID","");
  6631. jsobj1.put("COMPREHENSIVEID","");
  6632. jsobj1.put("JUDGE_TYPE","C");
  6633. jsobj1.put("PROD_LINE",qjl.getPline_code());
  6634. jsobj1.put("ISJUDGE","1");
  6635. jsobj1.put("PROD_TYPE",qjl.getProd_name());
  6636. jsobj1.put("SLAB_NO",qjl.getMaterial_no());
  6637. jsobj1.put("CHECKNO",qjf.get(0).getAssay_no_rl());
  6638. jsobj1.put("OPTMAN", param1.get(5).toString());
  6639. jsobj1.put("ISFX", "0");
  6640. jsobj1.put("CHEMRESULT_FX", "3");
  6641. jsobj1.put("REMARK", param1.get(4).toString());
  6642. ttmaps.add(jsobj1);
  6643. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  6644. String result = callWebserviceASMX(url,"ChemJudge",JSON.toJSONString(ttmaps));
  6645. JSONObject jo = JSONObject.parseObject(result);
  6646. if(jo.get("code").toString().equals("1")){
  6647. throw new Exception("成分判次失败!"+jo.get("message").toString());
  6648. }
  6649. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  6650. qjog.setOperate_name(param1.get(5).toString());
  6651. qjog.setOperate_type("成分判次");
  6652. qjog.setParams(param1.get(0).toString());
  6653. qjog.setBatchno(qjl.getBatch_no());
  6654. qjog.setProd_line(qjl.getPline_code());
  6655. mapper.insertQcmJudgeOperateLog(qjog);
  6656. }
  6657. qjl.setUnlock_name(param1.get(5).toString());
  6658. mapper.UpdateQcmJudgeLocking2(qjl);
  6659. LgultimateJudgeAutoBySystem(qjl.getMaterial_no(),param1.get(5).toString(),qjl.getPline_code(),qjl.getProd_name());
  6660. SqlSession.commit();
  6661. }
  6662. //判废
  6663. if(param1.get(3).toString().equals("5")){
  6664. qjl.setUnlock_type_code("6");
  6665. qjl.setUnlock_type_desc("判废");
  6666. qjl.setUnlock_memo(param1.get(4).toString());
  6667. if(param1.get(2).toString().equals("F")){
  6668. qjl.setFic_locking("0");
  6669. qjl.setLock_type_code("F");
  6670. sql = "select * from qcm_judge_surface where material_no = '"+param1.get(0).toString()+"' order by JUDGE_TIME desc";
  6671. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  6672. String s = mapper.query("SELECT to_char(wmsys.wm_concat(distinct FLAW_DESC)) memo FROM QCM_JUDGE_SURFACE_FLAW A WHERE A.SURFACE_ID = '"+qjl.getLock_id()+"'").get(0).get("MEMO").toString();
  6673. QcmJudgeSurface qjsf = new QcmJudgeSurface();
  6674. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  6675. qjsf.setSfd_is_lock("0");
  6676. qjsf.setSfe_is_lock("0");
  6677. qjsf.setSfu_is_lock("0");
  6678. mapper.UpdateQcmJudgeSurface(qjsf);
  6679. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  6680. qjog.setOperate_name(param1.get(5).toString());
  6681. qjog.setOperate_type("表面判废");
  6682. qjog.setParams(param1.get(0).toString());
  6683. qjog.setBatchno(qjl.getBatch_no());
  6684. qjog.setProd_line(qjl.getPline_code());
  6685. mapper.insertQcmJudgeOperateLog(qjog);
  6686. JSONObject jsobj2 = new JSONObject();
  6687. JSONArray ttmaps = new JSONArray();
  6688. JSONObject jsobj1 = new JSONObject();
  6689. jsobj1.put("CHEMRESULT_LK", "");
  6690. jsobj1.put("FACERESULT","4");
  6691. jsobj1.put("COMPREHENSIVERESULT","");
  6692. jsobj1.put("CHEMJUDGEID","");
  6693. jsobj1.put("FACECHECKID",qjl.getLock_id());
  6694. jsobj1.put("COMPREHENSIVEID","");
  6695. jsobj1.put("JUDGE_TYPE","S");
  6696. jsobj1.put("PROD_LINE",qjl.getPline_code());
  6697. jsobj1.put("ISJUDGE","1");
  6698. jsobj1.put("PROD_TYPE",qjl.getProd_name());
  6699. jsobj1.put("SLAB_NO",qjl.getMaterial_no());
  6700. jsobj1.put("CHECKNO","");
  6701. jsobj1.put("OPTMAN", param1.get(5).toString());
  6702. jsobj1.put("ISFX", "0");
  6703. jsobj1.put("CHEMRESULT_FX", "");
  6704. jsobj1.put("REMARK", param1.get(4).toString());
  6705. jsobj1.put("XXREASON", s);
  6706. ttmaps.add(jsobj1);
  6707. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  6708. String result = callWebserviceASMX(url,"ChemJudge",JSON.toJSONString(ttmaps));
  6709. JSONObject jo = JSONObject.parseObject(result);
  6710. if(jo.get("code").toString().equals("1")){
  6711. throw new Exception("表面判废失败!"+jo.get("message").toString());
  6712. }
  6713. //修改库存锁定
  6714. }
  6715. if(param1.get(2).toString().equals("C")){
  6716. qjl.setCic_locking("0");
  6717. qjl.setLock_type_code("C");
  6718. sql = "select * from QCM_JUDGE_CHEMICAL where CIC_ID = '"+param1.get(6).toString()+"'";
  6719. List<QcmJudgeChemical> qjf = mapper.queryQcmJudgeChemical(sql);
  6720. //修改库存锁定
  6721. //更改合同试样表
  6722. JSONObject jsobj2 = new JSONObject();
  6723. JSONArray ttmaps = new JSONArray();
  6724. JSONObject jsobj1 = new JSONObject();
  6725. jsobj1.put("CHEMRESULT_LK", "");
  6726. jsobj1.put("FACERESULT","");
  6727. jsobj1.put("COMPREHENSIVERESULT","");
  6728. jsobj1.put("CHEMJUDGEID",qjl.getLock_id());
  6729. jsobj1.put("FACECHECKID","");
  6730. jsobj1.put("COMPREHENSIVEID","");
  6731. jsobj1.put("JUDGE_TYPE","C");
  6732. jsobj1.put("PROD_LINE",qjl.getPline_code());
  6733. jsobj1.put("ISJUDGE","1");
  6734. jsobj1.put("PROD_TYPE",qjl.getProd_name());
  6735. jsobj1.put("SLAB_NO",qjl.getMaterial_no());
  6736. jsobj1.put("CHECKNO",qjf.get(0).getAssay_no_rl());
  6737. jsobj1.put("OPTMAN", param1.get(5).toString());
  6738. jsobj1.put("ISFX", "0");
  6739. jsobj1.put("CHEMRESULT_FX", "4");
  6740. jsobj1.put("REMARK", param1.get(4).toString());
  6741. ttmaps.add(jsobj1);
  6742. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  6743. String result = callWebserviceASMX(url,"ChemJudge",JSON.toJSONString(ttmaps));
  6744. JSONObject jo = JSONObject.parseObject(result);
  6745. if(jo.get("code").toString().equals("1")){
  6746. throw new Exception("成分判废失败!"+jo.get("message").toString());
  6747. }
  6748. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  6749. qjog.setOperate_name(param1.get(5).toString());
  6750. qjog.setOperate_type("成分判废");
  6751. qjog.setParams(param1.get(0).toString());
  6752. qjog.setBatchno(qjl.getBatch_no());
  6753. qjog.setProd_line(qjl.getPline_code());
  6754. mapper.insertQcmJudgeOperateLog(qjog);
  6755. }
  6756. qjl.setUnlock_name(param1.get(5).toString());
  6757. mapper.UpdateQcmJudgeLocking2(qjl);
  6758. LgultimateJudgeAutoBySystem(qjl.getMaterial_no(),param1.get(5).toString(),qjl.getPline_code(),qjl.getProd_name());
  6759. SqlSession.commit();
  6760. }
  6761. //关闭
  6762. if(param1.get(3).toString().equals("11")){
  6763. qjl.setUnlock_type_code("11");
  6764. qjl.setUnlock_type_desc("关闭");
  6765. qjl.setUnlock_memo(param1.get(4).toString());
  6766. if(param1.get(2).toString().equals("F")){
  6767. qjl.setFic_locking("0");
  6768. qjl.setLock_type_code("F");
  6769. }
  6770. if(param1.get(2).toString().equals("C")){
  6771. qjl.setCic_locking("0");
  6772. qjl.setLock_type_code("C");
  6773. }
  6774. qjl.setUnlock_name(param1.get(5).toString());
  6775. mapper.UpdateQcmJudgeLocking2(qjl);
  6776. SqlSession.commit();
  6777. }
  6778. //复样
  6779. if(param1.get(3).toString().equals("12")){
  6780. //重新
  6781. //质量锁定解锁
  6782. qjl.setUnlock_type_code("12");
  6783. qjl.setUnlock_type_desc("复样+放行");
  6784. qjl.setUnlock_memo(param1.get(4).toString());
  6785. qjl.setUnlock_name(param1.get(5).toString());
  6786. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  6787. List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(param1.get(0).toString());
  6788. if(hashmap.size() == 0){
  6789. hashmap = qjms.doQueryMaterialInfoJ(param1.get(0).toString());
  6790. }
  6791. if(hashmap.size()==0){
  6792. hashmap = mapper.doQueryMaterialInfoY(param1.get(0).toString());
  6793. }
  6794. if(param1.get(2).toString().equals("C")){
  6795. qjl.setCic_locking("0");
  6796. qjl.setLock_type_code("C");
  6797. JSONObject jsobj2 = new JSONObject();
  6798. JSONArray ttmaps = new JSONArray();
  6799. JSONObject jsobj1 = new JSONObject();
  6800. jsobj1.put("CHEMRESULT_LK", "");
  6801. jsobj1.put("FACERESULT","");
  6802. jsobj1.put("COMPREHENSIVERESULT","");
  6803. jsobj1.put("CHEMJUDGEID",qjl.getLock_id()==null?"":qjl.getLock_id());
  6804. jsobj1.put("FACECHECKID","");
  6805. jsobj1.put("COMPREHENSIVEID","");
  6806. jsobj1.put("JUDGE_TYPE","C");
  6807. jsobj1.put("PROD_LINE",qjl.getPline_code());
  6808. jsobj1.put("ISJUDGE","2");
  6809. jsobj1.put("PROD_TYPE",qjl.getProd_name());
  6810. jsobj1.put("SLAB_NO",qjl.getMaterial_no());
  6811. jsobj1.put("CHECKNO","");
  6812. jsobj1.put("OPTMAN", param1.get(5).toString());
  6813. jsobj1.put("ISFX", "0");
  6814. jsobj1.put("CHEMRESULT_FX", "");
  6815. jsobj1.put("REMARK", param1.get(4).toString());
  6816. ttmaps.add(jsobj1);
  6817. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  6818. String result = callWebserviceASMX(url,"ChemJudge",JSON.toJSONString(ttmaps));
  6819. JSONObject jo = JSONObject.parseObject(result);
  6820. if(jo.get("code").toString().equals("1")){
  6821. throw new Exception("成分复样+放行失败!");
  6822. }
  6823. //调用单项判定
  6824. }else{
  6825. throw new Exception("封锁来源与所选的异常材处置操作不一致,请重新选择处置操作!");
  6826. }
  6827. mapper.UpdateQcmJudgeLocking2(qjl);
  6828. SqlSession.commit();
  6829. LGRlChemJudgeBySystem1(qjl.getHeat_no(), qjl.getMaterial_no(), qjl.getDesign_key(), param1.get(5).toString(), qjl.getSteel_name(), qjl.getProd_name(), qjl.getPline_code(),param1.get(10).toString());
  6830. }
  6831. //LgultimateJudgeAutoBySystem(param1.get(0).toString(),"system",qjl.getPline_code(),qjl.getProd_name());
  6832. /*Thread t1 = new Thread(){
  6833. @Override
  6834. public void run(){
  6835. //调用综合判定
  6836. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  6837. try {
  6838. qjpsi.LgultimateJudgeAutoBySystem(param1.get(0).toString(),"system",qjl.getPline_code(),qjl.getProd_name());
  6839. } catch (Exception e) {
  6840. // TODO Auto-generated catch block
  6841. e.printStackTrace();
  6842. }
  6843. }
  6844. };
  6845. t1.start();*/
  6846. }catch(Exception e){
  6847. cro.setV_errCode(-1);
  6848. cro.setV_errMsg(e.getMessage());
  6849. SqlSession.rollback();
  6850. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.doInformationLgSure:【" + param1.toString() + "】" + e);
  6851. }
  6852. SqlSession.close();
  6853. return cro;
  6854. }
  6855. /**param1 改判除外的异常材处置 (成分、材质除外)(中厚板使用)
  6856. * 产品序号、锁定记录号、封锁来源、处置去向、处置去向说明、操作人,单项判定记录号
  6857. * @param param1
  6858. * @return
  6859. * @throws Exception
  6860. */
  6861. @SuppressWarnings("rawtypes")
  6862. public CoreReturnObject doInformationSureH2(ArrayList param1) throws Exception{
  6863. try{
  6864. if(param1 == null || param1.size() <= 0){
  6865. throw new Exception("请传入参数!");
  6866. }
  6867. QcmJudgeSurfaceServiceImpl qjft = new QcmJudgeSurfaceServiceImpl();
  6868. String sql = "select * from qcm_judge_locking where material_no = '"+param1.get(0).toString()+"' and lock_seq = '"+param1.get(1).toString()+"' and unlock_type_code is null ";
  6869. List<QCMJudgeLocking> qjls = mapper.queryQCMJudgeLockings(sql);
  6870. if(qjls.size() == 0){
  6871. throw new Exception("该处置信息已被处置,未找到信息!");
  6872. }
  6873. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  6874. QCMJudgeLocking qjl = mapper.queryQCMJudgeLockings(sql).get(0);
  6875. String lock_id = param1.get(6).toString();
  6876. qjl.setReason_code(lock_id);
  6877. String sf_type = param1.get(8).toString();
  6878. List<HashMap> listsu = qjft.finddefecttype(lock_id);
  6879. if(listsu.size() >0)
  6880. {
  6881. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  6882. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  6883. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  6884. }
  6885. sql = "select * from zj_result_all@xgcx where BILLETID = '"+param1.get(0).toString()+"'";
  6886. List<HashMap> list1 = mapper.query(sql);
  6887. sql = "select * from QCM_JUDGE_COIL_RESULT where coil_no = '"+param1.get(0).toString()+"'";
  6888. List<HashMap> list2 = mapper.query(sql);
  6889. //放行
  6890. if(param1.get(3).toString().equals("0")){
  6891. qjl.setUnlock_type_code("0");
  6892. qjl.setUnlock_type_desc("放行");
  6893. qjl.setUnlock_memo(param1.get(4).toString());
  6894. if(param1.get(2).toString().equals("S")){
  6895. qjl.setSic_locking("0");
  6896. //库存表放
  6897. if(list1.size() >0 || list2.size() >0){
  6898. if(list1.size()>0){
  6899. for(HashMap lists:list1){
  6900. if(!lists.get("JUDGERESULT").toString().equals("0")){
  6901. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  6902. }
  6903. }
  6904. ZjResultAll zra = new ZjResultAll();
  6905. zra.setBilletid(param1.get(0).toString());
  6906. zra.setSizeresult("1");
  6907. zra.setSizeresult_desc("合格");
  6908. zra.setSic_is_lock("2");
  6909. mapper.UpdateJugeResultB(zra);
  6910. }else{
  6911. for(HashMap lists:list2){
  6912. if(!lists.get("JUDGERESULT").toString().equals("0")){
  6913. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  6914. }
  6915. }
  6916. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  6917. zra.setCoil_no(param1.get(0).toString());
  6918. zra.setSizeresult("1");
  6919. zra.setSizeresult_desc("合格");
  6920. zra.setSic_is_lock("2");
  6921. mapper.UpdateJugeResultJ(zra);
  6922. }
  6923. }else{
  6924. throw new Exception("未找到库存信息!");
  6925. }
  6926. qjl.setUnlock_name(param1.get(5).toString());
  6927. qjl.setMaterial_no(param1.get(0).toString());
  6928. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  6929. mapper.UpdateQcmJudgeLocking(qjl);
  6930. QcmJudgeLog qjlt = new QcmJudgeLog();
  6931. qjlt.setJudge_type("U");
  6932. qjlt.setMaterial_no(param1.get(0).toString());
  6933. qjlt.setCreate_name("system");
  6934. qjlt.setProd_line(qjl.getPline_code());
  6935. mapper.insertQcmJudgeLog(qjlt);
  6936. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  6937. qjog.setOperate_name(param1.get(5).toString());
  6938. qjog.setOperate_type("放行");
  6939. qjog.setParams(param1.get(0).toString());
  6940. qjog.setBatchno(qjls.get(0).getBatch_no());
  6941. qjog.setProd_line(qjl.getPline_code());
  6942. mapper.insertQcmJudgeOperateLog(qjog);
  6943. SqlSession.commit();
  6944. }
  6945. if(param1.get(2).toString().equals("D")){
  6946. qjl.setDic_locking("0");
  6947. //库存表放
  6948. if(list1.size() >0 || list2.size() >0){
  6949. if(list1.size()>0){
  6950. for(HashMap lists:list1){
  6951. if(!lists.get("JUDGERESULT").toString().equals("0")){
  6952. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  6953. }
  6954. }
  6955. ZjResultAll zra = new ZjResultAll();
  6956. zra.setBilletid(param1.get(0).toString());
  6957. zra.setDic_is_lock("2");
  6958. zra.setSpyresult("1");
  6959. zra.setSpyresult_desc("合格");
  6960. mapper.UpdateJugeResultB(zra);
  6961. }else{
  6962. for(HashMap lists:list2){
  6963. if(!lists.get("JUDGERESULT").toString().equals("0")){
  6964. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  6965. }
  6966. }
  6967. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  6968. zra.setCoil_no(param1.get(0).toString());
  6969. zra.setDic_is_lock("2");
  6970. zra.setSpyresult("1");
  6971. zra.setSpyresult_desc("合格");
  6972. mapper.UpdateJugeResultJ(zra);
  6973. }
  6974. }else{
  6975. throw new Exception("未找到库存信息!");
  6976. }
  6977. qjl.setUnlock_name(param1.get(5).toString());
  6978. qjl.setMaterial_no(param1.get(0).toString());
  6979. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  6980. mapper.UpdateQcmJudgeLocking(qjl);
  6981. QcmJudgeLog qjlt = new QcmJudgeLog();
  6982. qjlt.setJudge_type("U");
  6983. qjlt.setMaterial_no(param1.get(0).toString());
  6984. qjlt.setCreate_name("system");
  6985. qjlt.setProd_line(qjl.getPline_code());
  6986. mapper.insertQcmJudgeLog(qjlt);
  6987. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  6988. qjog.setOperate_name(param1.get(5).toString());
  6989. qjog.setOperate_type("放行");
  6990. qjog.setParams(param1.get(0).toString());
  6991. qjog.setBatchno(qjls.get(0).getBatch_no());
  6992. qjog.setProd_line(qjl.getPline_code());
  6993. mapper.insertQcmJudgeOperateLog(qjog);
  6994. SqlSession.commit();
  6995. }
  6996. //表面放行
  6997. if(param1.get(2).toString().equals("F")){
  6998. qjl.setFic_locking("0");
  6999. sql = "select * from qcm_judge_surface where surface_id = '"+lock_id+"' order by JUDGE_TIME desc";
  7000. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  7001. QcmJudgeSurface qjsf = new QcmJudgeSurface();
  7002. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  7003. if(sf_type.equals("上表面")) {
  7004. qjsf.setSfu_is_lock("2");
  7005. } else if(sf_type.equals("下表面")) {
  7006. qjsf.setSfd_is_lock("2");
  7007. }
  7008. /*qjsf.setSfd_is_lock("2");
  7009. qjsf.setSfe_is_lock("2");
  7010. qjsf.setSfu_is_lock("2");*/
  7011. mapper.UpdateQcmJudgeSurface(qjsf);
  7012. //更新库存表放行
  7013. if(list1.size() >0 || list2.size() >0){
  7014. if(list1.size()>0){
  7015. for(HashMap lists:list1){
  7016. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7017. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  7018. }
  7019. }
  7020. ZjResultAll zra = new ZjResultAll();
  7021. zra.setBilletid(param1.get(0).toString());
  7022. if(sf_type.equals("上表面")) {
  7023. if(list1.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  7024. zra.setSfu_is_lock("2");
  7025. zra.setUp_surface_result("1");
  7026. zra.setUp_surface_result_desc("合格");
  7027. }
  7028. } else if(sf_type.equals("下表面")) {
  7029. if(list1.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  7030. zra.setSfd_is_lock("2");
  7031. zra.setUd_surface_result("1");
  7032. zra.setUd_surface_result_desc("合格");
  7033. }
  7034. }
  7035. /*if(list1.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  7036. zra.setSfe_is_lock("2");
  7037. zra.setMarginal_result("1");
  7038. zra.setMarginal_result_id_desc("合格");
  7039. }*/
  7040. mapper.UpdateJugeResultB(zra);
  7041. ///都合格
  7042. sql = "select * from zj_result_all@xgcx where BILLETID = '"+param1.get(0).toString()+"'";
  7043. List<HashMap> list4 = mapper.query(sql);
  7044. if(list4.size() >0){
  7045. for(HashMap list3:list4){
  7046. if(list3.get("UP_SURFACE_RESULT").equals("1") && list3.get("UD_SURFACE_RESULT").equals("1")) {
  7047. zra.setBilletid(param1.get(0).toString());
  7048. zra.setSurfaceresult("1");
  7049. zra.setSurfaceresult_desc("合格");
  7050. mapper.UpdateJugeResultB(zra);
  7051. }
  7052. }
  7053. }else{
  7054. throw new Exception("未找到库存信息!");
  7055. }
  7056. }else{
  7057. for(HashMap lists:list2){
  7058. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7059. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  7060. }
  7061. }
  7062. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  7063. zra.setCoil_no(param1.get(0).toString());
  7064. zra.setSurfaceresult("1");
  7065. zra.setSurfaceresult_desc("合格");
  7066. zra.setSurfaceresult_desc("合格");
  7067. if(list2.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  7068. zra.setSfu_is_lock("2");
  7069. zra.setUp_surface_result("1");
  7070. zra.setUp_surface_result_desc("合格");
  7071. }
  7072. if(list2.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  7073. zra.setSfd_is_lock("2");
  7074. zra.setUd_surface_result("1");
  7075. zra.setUd_surface_result_desc("合格");
  7076. }
  7077. if(list2.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  7078. zra.setSfe_is_lock("2");
  7079. zra.setMarginal_result("1");
  7080. zra.setMarginal_result_id_desc("合格");
  7081. }
  7082. mapper.UpdateJugeResultJ(zra);
  7083. }
  7084. }else{
  7085. throw new Exception("未找到库存信息!");
  7086. }
  7087. qjl.setUnlock_name(param1.get(5).toString());
  7088. qjl.setMaterial_no(param1.get(0).toString());
  7089. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7090. mapper.UpdateQcmJudgeLocking(qjl);
  7091. QcmJudgeLog qjlt = new QcmJudgeLog();
  7092. qjlt.setJudge_type("U");
  7093. qjlt.setMaterial_no(param1.get(0).toString());
  7094. qjlt.setCreate_name("system");
  7095. qjlt.setProd_line(qjl.getPline_code());
  7096. mapper.insertQcmJudgeLog(qjlt);
  7097. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7098. qjog.setOperate_name(param1.get(5).toString());
  7099. qjog.setOperate_type("表面放行");
  7100. qjog.setParams(param1.get(0).toString());
  7101. qjog.setBatchno(qjls.get(0).getBatch_no());
  7102. qjog.setProd_line(qjl.getPline_code());
  7103. mapper.insertQcmJudgeOperateLog(qjog);
  7104. SqlSession.commit();
  7105. }
  7106. }
  7107. //修磨
  7108. if(param1.get(3).toString().equals("2")){
  7109. if(!param1.get(2).toString().equals("F")){
  7110. throw new Exception("封锁来源与所选的异常材处置操作不一致,请重新选择处置操作!");
  7111. }
  7112. qjl.setUnlock_type_code("2");
  7113. qjl.setUnlock_type_desc("修磨");
  7114. qjl.setUnlock_memo(param1.get(4).toString());
  7115. qjl.setFic_locking("0");
  7116. qjl.setUnlock_name(param1.get(5).toString());
  7117. qjl.setMaterial_no(param1.get(0).toString());
  7118. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7119. //质量锁定解锁
  7120. mapper.UpdateQcmJudgeLocking(qjl);
  7121. sql = "select * from qcm_judge_surface where surface_id = '"+lock_id+"' order by JUDGE_TIME desc";
  7122. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  7123. QcmJudgeSurface qjsf = new QcmJudgeSurface();
  7124. if(sf_type.equals("上表面")) {
  7125. qjsf.setSfu_is_lock("0");
  7126. } else if(sf_type.equals("下表面")) {
  7127. qjsf.setSfd_is_lock("0");
  7128. }
  7129. /*qjsf.setSfe_is_lock("0");*/
  7130. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  7131. //表面锁定解锁
  7132. mapper.UpdateQcmJudgeSurface(qjsf);
  7133. //库存解锁
  7134. if(list1.size() >0 || list2.size() >0){
  7135. if(list1.size()>0){
  7136. for(HashMap lists:list1){
  7137. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7138. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能修磨!");
  7139. }
  7140. }
  7141. ZjResultAll zra = new ZjResultAll();
  7142. zra.setBilletid(param1.get(0).toString());
  7143. zra.setSurfaceresult("0");
  7144. zra.setSurfaceresult_desc("待判");
  7145. if(sf_type.equals("上表面")) {
  7146. zra.setSfu_is_lock("0");
  7147. } else if(sf_type.equals("下表面")) {
  7148. zra.setSfd_is_lock("0");
  7149. }
  7150. /*zra.setSfe_is_lock("0");*/
  7151. mapper.UpdateJugeResultB(zra);
  7152. SqlSession.commit();
  7153. }else{
  7154. for(HashMap lists:list2){
  7155. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7156. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能修磨!");
  7157. }
  7158. }
  7159. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  7160. zra.setCoil_no(param1.get(0).toString());
  7161. zra.setSurfaceresult("0");
  7162. zra.setSurfaceresult_desc("待判");
  7163. zra.setSfd_is_lock("0");
  7164. zra.setSfe_is_lock("0");
  7165. zra.setSfu_is_lock("0");
  7166. mapper.UpdateJugeResultJ(zra);
  7167. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7168. qjog.setOperate_name(param1.get(5).toString());
  7169. qjog.setOperate_type("修磨");
  7170. qjog.setParams(param1.get(0).toString());
  7171. qjog.setBatchno(qjls.get(0).getBatch_no());
  7172. qjog.setProd_line(qjl.getPline_code());
  7173. mapper.insertQcmJudgeOperateLog(qjog);
  7174. SqlSession.commit();
  7175. }
  7176. }else{
  7177. throw new Exception("未找到库存信息!");
  7178. }
  7179. }
  7180. //改尺
  7181. if(param1.get(3).toString().equals("3")){
  7182. if(!param1.get(2).toString().equals("S")){
  7183. throw new Exception("封锁来源与所选的异常材处置操作不一致,请重新选择处置操作!");
  7184. }
  7185. //更改质量异常锁定表
  7186. qjl.setUnlock_type_code("3");
  7187. qjl.setUnlock_type_desc("改尺");
  7188. qjl.setUnlock_memo(param1.get(4).toString());
  7189. qjl.setSic_locking("0");
  7190. qjl.setUnlock_name(param1.get(5).toString());
  7191. qjl.setMaterial_no(param1.get(0).toString());
  7192. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7193. mapper.UpdateQcmJudgeLocking(qjl);
  7194. //库存解锁
  7195. if(list1.size() >0 || list2.size() >0){
  7196. if(list1.size()>0){
  7197. for(HashMap lists:list1){
  7198. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7199. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能修磨!");
  7200. }
  7201. }
  7202. //脱单
  7203. ZjResultAll zra = new ZjResultAll();
  7204. zra.setBilletid(param1.get(0).toString());
  7205. zra.setSizeresult("0");
  7206. zra.setSizeresult_desc("待判");
  7207. zra.setSic_is_lock("0");
  7208. mapper.UpdateJugeResultB(zra);
  7209. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7210. qjog.setOperate_name(param1.get(5).toString());
  7211. qjog.setOperate_type("改尺");
  7212. qjog.setParams(param1.get(0).toString());
  7213. qjog.setBatchno(qjls.get(0).getBatch_no());
  7214. qjog.setProd_line(qjl.getPline_code());
  7215. mapper.insertQcmJudgeOperateLog(qjog);
  7216. SqlSession.commit();
  7217. }else{
  7218. for(HashMap lists:list2){
  7219. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7220. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能修磨!");
  7221. }
  7222. }
  7223. //脱单
  7224. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  7225. zra.setCoil_no(param1.get(0).toString());
  7226. zra.setSizeresult("0");
  7227. zra.setSizeresult_desc("待判");
  7228. zra.setSic_is_lock("0");
  7229. mapper.UpdateJugeResultJ(zra);
  7230. order_down(param1.get(0).toString(),"改尺");
  7231. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7232. qjog.setOperate_name(param1.get(5).toString());
  7233. qjog.setOperate_type("改尺");
  7234. qjog.setParams(param1.get(0).toString());
  7235. qjog.setBatchno(qjls.get(0).getBatch_no());
  7236. qjog.setProd_line(qjl.getPline_code());
  7237. mapper.insertQcmJudgeOperateLog(qjog);
  7238. SqlSession.commit();
  7239. }
  7240. }else{
  7241. throw new Exception("未找到库存信息!");
  7242. }
  7243. }
  7244. //判次
  7245. if(param1.get(3).toString().equals("4")){
  7246. qjl.setUnlock_type_code("4");
  7247. qjl.setUnlock_type_desc("判次");
  7248. qjl.setUnlock_memo(param1.get(4).toString());
  7249. qjl.setUnlock_name(param1.get(5).toString());
  7250. if(param1.get(2).toString().equals("S")){
  7251. qjl.setSic_locking("0");
  7252. qjl.setMaterial_no(param1.get(0).toString());
  7253. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7254. mapper.UpdateQcmJudgeLocking(qjl);
  7255. //库存表放
  7256. if(list1.size() >0 || list2.size() >0){
  7257. if(list1.size()>0){
  7258. for(HashMap lists:list1){
  7259. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7260. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判次!");
  7261. }
  7262. }
  7263. ZjResultAll zra = new ZjResultAll();
  7264. zra.setBilletid(param1.get(0).toString());
  7265. zra.setSizeresult("3");
  7266. zra.setSizeresult_desc("判次");
  7267. zra.setSic_is_lock("0");
  7268. mapper.UpdateJugeResultB(zra);
  7269. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"3");
  7270. //脱单
  7271. order_down(param1.get(0).toString(),"判次");
  7272. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7273. qjog.setOperate_name(param1.get(5).toString());
  7274. qjog.setOperate_type("判次");
  7275. qjog.setParams(param1.get(0).toString());
  7276. qjog.setBatchno(qjls.get(0).getBatch_no());
  7277. qjog.setProd_line(qjl.getPline_code());
  7278. mapper.insertQcmJudgeOperateLog(qjog);
  7279. SqlSession.commit();
  7280. }else{
  7281. throw new Exception("卷板尺寸不合格不允许判次!");
  7282. /*for(HashMap lists:list2){
  7283. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7284. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能修磨!");
  7285. }
  7286. }
  7287. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  7288. zra.setCoil_no(param1.get(0).toString());
  7289. zra.setSizeresult("3");
  7290. zra.setSizeresult_desc("判次");
  7291. zra.setSic_is_lock("0");
  7292. mapper.UpdateJugeResultJ(zra);
  7293. //脱单
  7294. SqlSession.commit();*/
  7295. }
  7296. }else{
  7297. throw new Exception("未找到库存信息!");
  7298. }
  7299. }
  7300. if(param1.get(2).toString().equals("D")){
  7301. qjl.setDic_locking("0");
  7302. qjl.setMaterial_no(param1.get(0).toString());
  7303. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7304. mapper.UpdateQcmJudgeLocking(qjl);
  7305. //库存表放
  7306. if(list1.size() >0 || list2.size() >0){
  7307. if(list1.size()>0){
  7308. for(HashMap lists:list1){
  7309. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7310. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判次!");
  7311. }
  7312. }
  7313. ZjResultAll zra = new ZjResultAll();
  7314. zra.setBilletid(param1.get(0).toString());
  7315. zra.setSpyresult("3");
  7316. zra.setSpyresult_desc("判次");
  7317. zra.setDic_is_lock("0");
  7318. mapper.UpdateJugeResultB(zra);
  7319. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"3");
  7320. //脱单
  7321. order_down(param1.get(0).toString(),"判次");
  7322. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7323. qjog.setOperate_name(param1.get(5).toString());
  7324. qjog.setOperate_type("判次");
  7325. qjog.setParams(param1.get(0).toString());
  7326. qjog.setBatchno(qjls.get(0).getBatch_no());
  7327. qjog.setProd_line(qjl.getPline_code());
  7328. mapper.insertQcmJudgeOperateLog(qjog);
  7329. SqlSession.commit();
  7330. }else{
  7331. for(HashMap lists:list2){
  7332. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7333. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能修磨!");
  7334. }
  7335. }
  7336. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  7337. zra.setCoil_no(param1.get(0).toString());
  7338. zra.setSpyresult("3");
  7339. zra.setSpyresult_desc("判次");
  7340. zra.setDic_is_lock("0");
  7341. mapper.UpdateJugeResultJ(zra);
  7342. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7343. qjog.setOperate_name(param1.get(5).toString());
  7344. qjog.setOperate_type("判次");
  7345. qjog.setParams(param1.get(0).toString());
  7346. qjog.setBatchno(qjls.get(0).getBatch_no());
  7347. qjog.setProd_line(qjl.getPline_code());
  7348. mapper.insertQcmJudgeOperateLog(qjog);
  7349. //脱单
  7350. SqlSession.commit();
  7351. }
  7352. }else{
  7353. throw new Exception("未找到库存信息!");
  7354. }
  7355. }
  7356. if(param1.get(2).toString().equals("F")){
  7357. List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(param1.get(0).toString());
  7358. qjl.setFic_locking("0");
  7359. qjl.setMaterial_no(param1.get(0).toString());
  7360. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7361. mapper.UpdateQcmJudgeLocking(qjl);
  7362. sql = "select * from qcm_judge_surface where surface_id = '"+lock_id+"' order by JUDGE_TIME desc";
  7363. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  7364. QcmJudgeSurface qjsf = new QcmJudgeSurface();
  7365. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  7366. if(sf_type.equals("上表面")) {
  7367. qjsf.setSfu_is_lock("0");
  7368. } else if(sf_type.equals("下表面")) {
  7369. qjsf.setSfd_is_lock("0");
  7370. }
  7371. /*qjsf.setSfe_is_lock("0");*/
  7372. mapper.UpdateQcmJudgeSurface(qjsf);
  7373. //修改库存锁定
  7374. if(list1.size() >0 || list2.size() >0){
  7375. if(list1.size()>0){
  7376. for(HashMap lists:list1){
  7377. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7378. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判次!");
  7379. }
  7380. }
  7381. ZjResultAll zra = new ZjResultAll();
  7382. zra.setBilletid(param1.get(0).toString());
  7383. zra.setSurfaceresult("3");
  7384. zra.setSurfaceresult_desc("判次");
  7385. if(sf_type.equals("上表面")) {
  7386. if(list1.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  7387. zra.setSfu_is_lock("0");
  7388. zra.setUp_surface_result("3");
  7389. zra.setUp_surface_result_desc("判次");
  7390. }
  7391. } else if(sf_type.equals("下表面")) {
  7392. if(list1.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  7393. zra.setSfd_is_lock("0");
  7394. zra.setUd_surface_result("3");
  7395. zra.setUd_surface_result_desc("判次");
  7396. }
  7397. }
  7398. /*if(list1.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  7399. zra.setSfe_is_lock("0");
  7400. zra.setMarginal_result("3");
  7401. zra.setMarginal_result_id_desc("判次");
  7402. }*/
  7403. mapper.UpdateJugeResultB(zra);
  7404. //表面信息发送到MES
  7405. if(param1.get(0).toString().startsWith("H") || param1.get(0).toString().startsWith("Z")){
  7406. String aJudgeType = "次品";
  7407. String aGZLB = "";
  7408. String aGYLB = "";
  7409. String aXGLB = "";
  7410. List<QcmJudgeSurfaceFlaw> qjf1 = mapper.queryQcmJudgeSurfaceFlaw("select * from qcm_judge_surface_flaw where surface_id = '"+param1.get(6).toString()+"' and flaw_seq = '1'");
  7411. if(qjf1.size() >0){
  7412. if(qjf1.get(0).getIs_repair().equals("0") || qjf1.get(0).getIs_repair().equals("未修复")){
  7413. aXGLB = "402301";
  7414. }else{
  7415. aXGLB = "402303";
  7416. }
  7417. List<HashMap> listgzl = mapper.query("select * from qcm_base_defect a where a.defect_code = '"+qjf1.get(0).getFlaw_code()+"'");
  7418. if(listgzl.size() > 0){
  7419. if(listgzl.get(0).get("DEFECT_TYPE_CODE").equals("S")){
  7420. List<HashMap> listgz = mapper.query("select * from scm_base_info a where a.sort_code = '4124' and memo like '%钢质%' and name_ = '"+qjf1.get(0).getFlaw_desc()+"'");
  7421. if(listgz.size() > 0){
  7422. aGZLB = listgz.get(0).get("ID_").toString();
  7423. }else{
  7424. aGZLB = qjf1.get(0).getFlaw_desc();
  7425. }
  7426. }else{
  7427. List<HashMap> listgy = mapper.query("select * from scm_base_info a where a.sort_code = '4124' and memo like '%工艺%' and name_ = '"+qjf1.get(0).getFlaw_desc()+"'");
  7428. if(listgy.size() > 0){
  7429. aGYLB = listgy.get(0).get("ID_").toString();
  7430. }else{
  7431. aGYLB = qjf1.get(0).getFlaw_desc();
  7432. }
  7433. }
  7434. }
  7435. }
  7436. bmjy((sf_type.equals("上表面") ? "S" : "X")+param1.get(6).toString(),param1.get(0).toString(),aJudgeType, aGZLB, aGYLB, aXGLB,hashmap.get(0).get("STEEL_NAME")==null?"":hashmap.get(0).get("STEEL_NAME").toString(), hashmap.get(0).get("PROD_NAME")==null?"":hashmap.get(0).get("PROD_NAME").toString() , hashmap.get(0).get("STD_NAME")==null?"":hashmap.get(0).get("STD_NAME").toString(), param1.get(5).toString() , "", "", param1.get(4).toString(), "");
  7437. }
  7438. //脱单
  7439. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"3");
  7440. order_down(param1.get(0).toString(),"判次");
  7441. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7442. qjog.setOperate_name(param1.get(5).toString());
  7443. qjog.setOperate_type("判次");
  7444. qjog.setParams(param1.get(0).toString());
  7445. qjog.setBatchno(qjls.get(0).getBatch_no());
  7446. qjog.setProd_line(qjl.getPline_code());
  7447. mapper.insertQcmJudgeOperateLog(qjog);
  7448. SqlSession.commit();
  7449. }else{
  7450. for(HashMap lists:list2){
  7451. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7452. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能修磨!");
  7453. }
  7454. }
  7455. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  7456. zra.setCoil_no(param1.get(0).toString());
  7457. zra.setSurfaceresult("3");
  7458. zra.setSurfaceresult_desc("判次");
  7459. if(list2.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  7460. zra.setSfu_is_lock("0");
  7461. zra.setUp_surface_result("3");
  7462. zra.setUp_surface_result_desc("判次");
  7463. }
  7464. if(list2.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  7465. zra.setSfd_is_lock("0");
  7466. zra.setUd_surface_result("3");
  7467. zra.setUd_surface_result_desc("判次");
  7468. }
  7469. if(list2.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  7470. zra.setSfe_is_lock("0");
  7471. zra.setMarginal_result("3");
  7472. zra.setMarginal_result_id_desc("判次");
  7473. }
  7474. mapper.UpdateJugeResultJ(zra);
  7475. //脱单
  7476. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7477. qjog.setOperate_name(param1.get(5).toString());
  7478. qjog.setOperate_type("判次");
  7479. qjog.setParams(param1.get(0).toString());
  7480. qjog.setBatchno(qjls.get(0).getBatch_no());
  7481. qjog.setProd_line(qjl.getPline_code());
  7482. mapper.insertQcmJudgeOperateLog(qjog);
  7483. SqlSession.commit();
  7484. }
  7485. }else{
  7486. throw new Exception("未找到库存信息!");
  7487. }
  7488. }
  7489. }
  7490. //判废
  7491. if(param1.get(3).toString().equals("5")){
  7492. qjl.setUnlock_type_code("5");
  7493. qjl.setUnlock_type_desc("判废");
  7494. qjl.setUnlock_memo(param1.get(4).toString());
  7495. qjl.setUnlock_name(param1.get(5).toString());
  7496. if(param1.get(2).toString().equals("S")){
  7497. qjl.setSic_locking("0");
  7498. qjl.setMaterial_no(param1.get(0).toString());
  7499. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7500. mapper.UpdateQcmJudgeLocking(qjl);
  7501. //库存表放
  7502. if(list1.size() >0 || list2.size() >0){
  7503. if(list1.size()>0){
  7504. for(HashMap lists:list1){
  7505. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7506. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判废!");
  7507. }
  7508. }
  7509. ZjResultAll zra = new ZjResultAll();
  7510. zra.setBilletid(param1.get(0).toString());
  7511. zra.setSizeresult("4");
  7512. zra.setSizeresult_desc("判废");
  7513. zra.setSic_is_lock("0");
  7514. mapper.UpdateJugeResultB(zra);
  7515. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"4");
  7516. //脱单
  7517. order_down(param1.get(0).toString(),"判废");
  7518. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7519. qjog.setOperate_name(param1.get(5).toString());
  7520. qjog.setOperate_type("判废");
  7521. qjog.setParams(param1.get(0).toString());
  7522. qjog.setBatchno(qjls.get(0).getBatch_no());
  7523. qjog.setProd_line(qjl.getPline_code());
  7524. mapper.insertQcmJudgeOperateLog(qjog);
  7525. SqlSession.commit();
  7526. }else{
  7527. throw new Exception("卷板尺寸不合格不允许判废!");
  7528. /*for(HashMap lists:list2){
  7529. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7530. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能修磨!");
  7531. }
  7532. }
  7533. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  7534. zra.setCoil_no(param1.get(0).toString());
  7535. zra.setSizeresult("4");
  7536. zra.setSizeresult_desc("判废");
  7537. zra.setSic_is_lock("0");
  7538. mapper.UpdateJugeResultJ(zra);
  7539. //脱单
  7540. SqlSession.commit();*/
  7541. }
  7542. }else{
  7543. throw new Exception("未找到库存信息!");
  7544. }
  7545. }
  7546. if(param1.get(2).toString().equals("D")){
  7547. qjl.setDic_locking("0");
  7548. qjl.setMaterial_no(param1.get(0).toString());
  7549. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7550. mapper.UpdateQcmJudgeLocking(qjl);
  7551. //库存表放
  7552. if(list1.size() >0 || list2.size() >0){
  7553. if(list1.size()>0){
  7554. for(HashMap lists:list1){
  7555. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7556. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判废!");
  7557. }
  7558. }
  7559. ZjResultAll zra = new ZjResultAll();
  7560. zra.setBilletid(param1.get(0).toString());
  7561. zra.setSpyresult("4");
  7562. zra.setSpyresult_desc("判废");
  7563. zra.setDic_is_lock("0");
  7564. mapper.UpdateJugeResultB(zra);
  7565. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"4");
  7566. //脱单
  7567. order_down(param1.get(0).toString(),"判废");
  7568. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7569. qjog.setOperate_name(param1.get(5).toString());
  7570. qjog.setOperate_type("判废");
  7571. qjog.setParams(param1.get(0).toString());
  7572. qjog.setBatchno(qjls.get(0).getBatch_no());
  7573. qjog.setProd_line(qjl.getPline_code());
  7574. mapper.insertQcmJudgeOperateLog(qjog);
  7575. SqlSession.commit();
  7576. }else{
  7577. for(HashMap lists:list2){
  7578. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7579. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能修磨!");
  7580. }
  7581. }
  7582. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  7583. zra.setCoil_no(param1.get(0).toString());
  7584. zra.setSpyresult("4");
  7585. zra.setSpyresult_desc("判废");
  7586. zra.setDic_is_lock("0");
  7587. mapper.UpdateJugeResultJ(zra);
  7588. //脱单
  7589. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7590. qjog.setOperate_name(param1.get(5).toString());
  7591. qjog.setOperate_type("判废");
  7592. qjog.setParams(param1.get(0).toString());
  7593. qjog.setBatchno(qjls.get(0).getBatch_no());
  7594. qjog.setProd_line(qjl.getPline_code());
  7595. mapper.insertQcmJudgeOperateLog(qjog);
  7596. SqlSession.commit();
  7597. }
  7598. }else{
  7599. throw new Exception("未找到库存信息!");
  7600. }
  7601. }
  7602. if(param1.get(2).toString().equals("F")){
  7603. List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(param1.get(0).toString());
  7604. qjl.setFic_locking("0");
  7605. qjl.setMaterial_no(param1.get(0).toString());
  7606. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7607. mapper.UpdateQcmJudgeLocking(qjl);
  7608. sql = "select * from qcm_judge_surface where surface_id = '"+lock_id+"' order by JUDGE_TIME desc";
  7609. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  7610. QcmJudgeSurface qjsf = new QcmJudgeSurface();
  7611. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  7612. if(sf_type.equals("上表面")) {
  7613. qjsf.setSfu_is_lock("0");
  7614. } else if(sf_type.equals("下表面")) {
  7615. qjsf.setSfd_is_lock("0");
  7616. }
  7617. /*qjsf.setSfe_is_lock("0");*/
  7618. mapper.UpdateQcmJudgeSurface(qjsf);
  7619. //修改库存锁定
  7620. if(list1.size() >0 || list2.size() >0){
  7621. if(list1.size()>0){
  7622. for(HashMap lists:list1){
  7623. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7624. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判废!");
  7625. }
  7626. }
  7627. ZjResultAll zra = new ZjResultAll();
  7628. zra.setBilletid(param1.get(0).toString());
  7629. zra.setSurfaceresult("4");
  7630. zra.setSurfaceresult_desc("判废");
  7631. if(sf_type.equals("上表面")) {
  7632. if(list1.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  7633. zra.setSfu_is_lock("0");
  7634. zra.setUp_surface_result("4");
  7635. zra.setUp_surface_result_desc("判废");
  7636. }
  7637. } else if(sf_type.equals("下表面")) {
  7638. if(list1.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  7639. zra.setSfd_is_lock("0");
  7640. zra.setUd_surface_result("4");
  7641. zra.setUd_surface_result_desc("判废");
  7642. }
  7643. }
  7644. /*if(list1.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  7645. zra.setSfe_is_lock("0");
  7646. zra.setMarginal_result("4");
  7647. zra.setMarginal_result_id_desc("判废");
  7648. }*/
  7649. mapper.UpdateJugeResultB(zra);
  7650. //脱单
  7651. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"4");
  7652. order_down(param1.get(0).toString(),"判废");
  7653. //表面信息发送到MES
  7654. if(param1.get(0).toString().startsWith("H") || param1.get(0).toString().startsWith("Z")){
  7655. String aJudgeType = "次品";
  7656. String aGZLB = "";
  7657. String aGYLB = "";
  7658. String aXGLB = "";
  7659. List<QcmJudgeSurfaceFlaw> qjf1 = mapper.queryQcmJudgeSurfaceFlaw("select * from qcm_judge_surface_flaw where surface_id = '"+param1.get(6).toString()+"' and flaw_seq = '1'");
  7660. if(qjf1.size() >0){
  7661. if(qjf1.get(0).getIs_repair().equals("0") || qjf1.get(0).getIs_repair().equals("未修复")){
  7662. aXGLB = "402301";
  7663. }else{
  7664. aXGLB = "402303";
  7665. }
  7666. List<HashMap> listgzl = mapper.query("select * from qcm_base_defect a where a.defect_code = '"+qjf1.get(0).getFlaw_code()+"'");
  7667. if(listgzl.size() > 0){
  7668. if(listgzl.get(0).get("DEFECT_TYPE_CODE").equals("S")){
  7669. List<HashMap> listgz = mapper.query("select * from scm_base_info a where a.sort_code = '4124' and memo like '%钢质%' and name_ = '"+qjf1.get(0).getFlaw_desc()+"'");
  7670. if(listgz.size() > 0){
  7671. aGZLB = listgz.get(0).get("ID_").toString();
  7672. }else{
  7673. aGZLB = qjf1.get(0).getFlaw_desc();
  7674. }
  7675. }else{
  7676. List<HashMap> listgy = mapper.query("select * from scm_base_info a where a.sort_code = '4124' and memo like '%工艺%' and name_ = '"+qjf1.get(0).getFlaw_desc()+"'");
  7677. if(listgy.size() > 0){
  7678. aGYLB = listgy.get(0).get("ID_").toString();
  7679. }else{
  7680. aGYLB = qjf1.get(0).getFlaw_desc();
  7681. }
  7682. }
  7683. }
  7684. }
  7685. bmjy(sf_type.equals("上表面") ? "S" : "X"+param1.get(6).toString(),param1.get(0).toString(),aJudgeType, aGZLB, aGYLB, aXGLB,hashmap.get(0).get("STEEL_NAME")==null?"":hashmap.get(0).get("STEEL_NAME").toString(), hashmap.get(0).get("PROD_NAME")==null?"":hashmap.get(0).get("PROD_NAME").toString() , hashmap.get(0).get("STD_NAME")==null?"":hashmap.get(0).get("STD_NAME").toString(), param1.get(5).toString() , "", "", param1.get(4).toString(), "");
  7686. }
  7687. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7688. qjog.setOperate_name(param1.get(5).toString());
  7689. qjog.setOperate_type("判废");
  7690. qjog.setParams(param1.get(0).toString());
  7691. qjog.setBatchno(qjls.get(0).getBatch_no());
  7692. qjog.setProd_line(qjl.getPline_code());
  7693. mapper.insertQcmJudgeOperateLog(qjog);
  7694. SqlSession.commit();
  7695. }else{
  7696. for(HashMap lists:list2){
  7697. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7698. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能修磨!");
  7699. }
  7700. }
  7701. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  7702. zra.setCoil_no(param1.get(0).toString());
  7703. zra.setSurfaceresult("4");
  7704. zra.setSurfaceresult_desc("判废");
  7705. if(list2.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  7706. zra.setSfu_is_lock("0");
  7707. zra.setUp_surface_result("4");
  7708. zra.setUp_surface_result_desc("判废");
  7709. }
  7710. if(list2.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  7711. zra.setSfd_is_lock("0");
  7712. zra.setUd_surface_result("4");
  7713. zra.setUd_surface_result_desc("判废");
  7714. }
  7715. if(list2.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  7716. zra.setSfe_is_lock("0");
  7717. zra.setMarginal_result("4");
  7718. zra.setMarginal_result_id_desc("判废");
  7719. }
  7720. mapper.UpdateJugeResultJ(zra);
  7721. //脱单
  7722. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7723. qjog.setOperate_name(param1.get(5).toString());
  7724. qjog.setOperate_type("判废");
  7725. qjog.setParams(param1.get(0).toString());
  7726. qjog.setBatchno(qjls.get(0).getBatch_no());
  7727. qjog.setProd_line(qjl.getPline_code());
  7728. mapper.insertQcmJudgeOperateLog(qjog);
  7729. SqlSession.commit();
  7730. }
  7731. }else{
  7732. throw new Exception("未找到库存信息!");
  7733. }
  7734. }
  7735. }
  7736. //脱单 根据产线划分 中厚板保留原有判定结果,只是进行解锁,热卷 进行充当清除判定记录
  7737. if(param1.get(3).toString().equals("6")){
  7738. qjl.setUnlock_type_code("6");
  7739. qjl.setUnlock_type_desc("脱单");
  7740. qjl.setUnlock_memo(param1.get(4).toString());
  7741. qjl.setUnlock_name(param1.get(5).toString());
  7742. mapper.UpdateQcmJudgeLocking(qjl);
  7743. if(qjl.getPline_code().equals("ZB1") || qjl.getPline_code().equals("HB1")){
  7744. //调用脱单接口
  7745. if(param1.get(2).toString().equals("S")){
  7746. qjl.setSic_locking("0");
  7747. //库存表放
  7748. if(list1.size() >0 || list2.size() >0){
  7749. if(list1.size()>0){
  7750. for(HashMap lists:list1){
  7751. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7752. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  7753. }
  7754. }
  7755. ZjResultAll zra = new ZjResultAll();
  7756. zra.setBilletid(param1.get(0).toString());
  7757. zra.setSic_is_lock("0");
  7758. mapper.UpdateJugeResultB(zra);
  7759. qjl.setUnlock_name(param1.get(5).toString());
  7760. qjl.setMaterial_no(param1.get(0).toString());
  7761. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7762. mapper.UpdateQcmJudgeLocking(qjl);
  7763. //脱单
  7764. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7765. qjog.setOperate_name(param1.get(5).toString());
  7766. qjog.setOperate_type("脱单");
  7767. qjog.setParams(param1.get(0).toString());
  7768. qjog.setBatchno(qjls.get(0).getBatch_no());
  7769. qjog.setProd_line(qjl.getPline_code());
  7770. mapper.insertQcmJudgeOperateLog(qjog);
  7771. SqlSession.commit();
  7772. }else{
  7773. for(HashMap lists:list2){
  7774. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7775. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  7776. }
  7777. }
  7778. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  7779. zra.setCoil_no(param1.get(0).toString());
  7780. zra.setSic_is_lock("0");
  7781. mapper.UpdateJugeResultJ(zra);
  7782. qjl.setUnlock_name(param1.get(5).toString());
  7783. qjl.setMaterial_no(param1.get(0).toString());
  7784. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7785. mapper.UpdateQcmJudgeLocking(qjl);
  7786. //脱单
  7787. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7788. qjog.setOperate_name(param1.get(5).toString());
  7789. qjog.setOperate_type("脱单");
  7790. qjog.setParams(param1.get(0).toString());
  7791. qjog.setBatchno(qjls.get(0).getBatch_no());
  7792. qjog.setProd_line(qjl.getPline_code());
  7793. mapper.insertQcmJudgeOperateLog(qjog);
  7794. SqlSession.commit();
  7795. }
  7796. }else{
  7797. throw new Exception("未找到库存信息!");
  7798. }
  7799. }
  7800. if(param1.get(2).toString().equals("D")){
  7801. qjl.setDic_locking("0");
  7802. //库存表放
  7803. if(list1.size() >0 || list2.size() >0){
  7804. if(list1.size()>0){
  7805. for(HashMap lists:list1){
  7806. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7807. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  7808. }
  7809. }
  7810. ZjResultAll zra = new ZjResultAll();
  7811. zra.setBilletid(param1.get(0).toString());
  7812. zra.setSic_is_lock("0");
  7813. mapper.UpdateJugeResultB(zra);
  7814. qjl.setUnlock_name(param1.get(5).toString());
  7815. qjl.setMaterial_no(param1.get(0).toString());
  7816. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7817. mapper.UpdateQcmJudgeLocking(qjl);
  7818. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7819. qjog.setOperate_name(param1.get(5).toString());
  7820. qjog.setOperate_type("脱单");
  7821. qjog.setParams(param1.get(0).toString());
  7822. qjog.setBatchno(qjls.get(0).getBatch_no());
  7823. qjog.setProd_line(qjl.getPline_code());
  7824. mapper.insertQcmJudgeOperateLog(qjog);
  7825. //脱单
  7826. SqlSession.commit();
  7827. }else{
  7828. for(HashMap lists:list2){
  7829. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7830. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  7831. }
  7832. }
  7833. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  7834. zra.setCoil_no(param1.get(0).toString());
  7835. zra.setSic_is_lock("0");
  7836. mapper.UpdateJugeResultJ(zra);
  7837. qjl.setUnlock_name(param1.get(5).toString());
  7838. qjl.setMaterial_no(param1.get(0).toString());
  7839. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7840. mapper.UpdateQcmJudgeLocking(qjl);
  7841. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7842. qjog.setOperate_name(param1.get(5).toString());
  7843. qjog.setOperate_type("脱单");
  7844. qjog.setParams(param1.get(0).toString());
  7845. qjog.setBatchno(qjls.get(0).getBatch_no());
  7846. qjog.setProd_line(qjl.getPline_code());
  7847. mapper.insertQcmJudgeOperateLog(qjog);
  7848. //脱单
  7849. SqlSession.commit();
  7850. }
  7851. }else{
  7852. throw new Exception("未找到库存信息!");
  7853. }
  7854. }
  7855. //表面
  7856. if(param1.get(2).toString().equals("F")){
  7857. qjl.setFic_locking("0");
  7858. sql = "select * from qcm_judge_surface where surface_id = '"+lock_id+"' order by JUDGE_TIME desc";
  7859. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  7860. QcmJudgeSurface qjsf = new QcmJudgeSurface();
  7861. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  7862. if(sf_type.equals("上表面")) {
  7863. qjsf.setSfu_is_lock("0");
  7864. } else if(sf_type.equals("下表面")) {
  7865. qjsf.setSfd_is_lock("0");
  7866. }
  7867. /*qjsf.setSfe_is_lock("0");*/
  7868. mapper.UpdateQcmJudgeSurface(qjsf);
  7869. //更新库存表放行
  7870. if(list1.size() >0 || list2.size() >0){
  7871. if(list1.size()>0){
  7872. for(HashMap lists:list1){
  7873. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7874. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  7875. }
  7876. }
  7877. ZjResultAll zra = new ZjResultAll();
  7878. zra.setBilletid(param1.get(0).toString());
  7879. if(sf_type.equals("上表面")) {
  7880. if(list1.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  7881. zra.setSfu_is_lock("0");
  7882. }
  7883. } else if(sf_type.equals("下表面")) {
  7884. if(list1.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  7885. zra.setSfd_is_lock("0");
  7886. }
  7887. }
  7888. /*if(list1.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  7889. zra.setSfe_is_lock("0");
  7890. }*/
  7891. mapper.UpdateJugeResultB(zra);
  7892. qjl.setUnlock_name(param1.get(5).toString());
  7893. qjl.setMaterial_no(param1.get(0).toString());
  7894. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7895. mapper.UpdateQcmJudgeLocking(qjl);
  7896. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7897. qjog.setOperate_name(param1.get(5).toString());
  7898. qjog.setOperate_type("脱单");
  7899. qjog.setParams(param1.get(0).toString());
  7900. qjog.setBatchno(qjls.get(0).getBatch_no());
  7901. qjog.setProd_line(qjl.getPline_code());
  7902. mapper.insertQcmJudgeOperateLog(qjog);
  7903. //脱单
  7904. SqlSession.commit();
  7905. }else{
  7906. for(HashMap lists:list2){
  7907. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7908. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  7909. }
  7910. }
  7911. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  7912. zra.setCoil_no(param1.get(0).toString());
  7913. if(list2.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  7914. zra.setSfu_is_lock("0");
  7915. }
  7916. if(list2.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  7917. zra.setSfd_is_lock("0");
  7918. }
  7919. if(list2.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  7920. zra.setSfe_is_lock("0");
  7921. }
  7922. mapper.UpdateJugeResultJ(zra);
  7923. qjl.setUnlock_name(param1.get(5).toString());
  7924. qjl.setMaterial_no(param1.get(0).toString());
  7925. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7926. mapper.UpdateQcmJudgeLocking(qjl);
  7927. //脱单
  7928. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7929. qjog.setOperate_name(param1.get(5).toString());
  7930. qjog.setOperate_type("脱单");
  7931. qjog.setParams(param1.get(0).toString());
  7932. qjog.setBatchno(qjls.get(0).getBatch_no());
  7933. qjog.setProd_line(qjl.getPline_code());
  7934. mapper.insertQcmJudgeOperateLog(qjog);
  7935. SqlSession.commit();
  7936. }
  7937. }else{
  7938. throw new Exception("未找到库存信息!");
  7939. }
  7940. }
  7941. }else if(qjl.getPline_code().equals("RZ1") || qjl.getPline_code().equals("LT1") || qjl.getPline_code().equals("SZ1")){
  7942. if(param1.get(2).toString().equals("S")){
  7943. qjl.setSic_locking("0");
  7944. }
  7945. //表面
  7946. if(param1.get(2).toString().equals("F")){
  7947. qjl.setFic_locking("0");
  7948. }
  7949. //脱单
  7950. qjl.setUnlock_name(param1.get(5).toString());
  7951. qjl.setMaterial_no(param1.get(0).toString());
  7952. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  7953. mapper.UpdateQcmJudgeLocking(qjl);
  7954. SqlSession.commit();
  7955. }
  7956. }
  7957. //解除
  7958. if(param1.get(3).toString().equals("9")){
  7959. qjl.setUnlock_type_code("9");
  7960. qjl.setUnlock_type_desc("解除");
  7961. qjl.setUnlock_memo(param1.get(4).toString());
  7962. if(param1.get(2).toString().equals("S")){
  7963. qjl.setSic_locking("0");
  7964. //库存表放
  7965. if(list1.size() >0 || list2.size() >0){
  7966. if(list1.size()>0){
  7967. for(HashMap lists:list1){
  7968. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7969. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能解锁!");
  7970. }
  7971. }
  7972. ZjResultAll zra = new ZjResultAll();
  7973. zra.setBilletid(param1.get(0).toString());
  7974. zra.setSic_is_lock("0");
  7975. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7976. qjog.setOperate_name(param1.get(5).toString());
  7977. qjog.setOperate_type("解除");
  7978. qjog.setParams(param1.get(0).toString());
  7979. qjog.setBatchno(qjls.get(0).getBatch_no());
  7980. qjog.setProd_line(qjl.getPline_code());
  7981. mapper.insertQcmJudgeOperateLog(qjog);
  7982. mapper.UpdateJugeResultB(zra);
  7983. }else{
  7984. for(HashMap lists:list2){
  7985. if(!lists.get("JUDGERESULT").toString().equals("0")){
  7986. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能解锁!");
  7987. }
  7988. }
  7989. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  7990. zra.setCoil_no(param1.get(0).toString());
  7991. zra.setSic_is_lock("0");
  7992. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  7993. qjog.setOperate_name(param1.get(5).toString());
  7994. qjog.setOperate_type("解除");
  7995. qjog.setParams(param1.get(0).toString());
  7996. qjog.setBatchno(qjls.get(0).getBatch_no());
  7997. qjog.setProd_line(qjl.getPline_code());
  7998. mapper.insertQcmJudgeOperateLog(qjog);
  7999. mapper.UpdateJugeResultJ(zra);
  8000. }
  8001. }else{
  8002. throw new Exception("未找到库存信息!");
  8003. }
  8004. //库存表放
  8005. qjl.setUnlock_name(param1.get(5).toString());
  8006. qjl.setMaterial_no(param1.get(0).toString());
  8007. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  8008. mapper.UpdateQcmJudgeLocking(qjl);
  8009. SqlSession.commit();
  8010. }
  8011. //表面解锁
  8012. if(param1.get(2).toString().equals("F")){
  8013. qjl.setFic_locking("0");
  8014. //更新库存表放行
  8015. if(list1.size() >0 || list2.size() >0){
  8016. if(list1.size()>0){
  8017. for(HashMap lists:list1){
  8018. if(!lists.get("JUDGERESULT").toString().equals("0")){
  8019. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  8020. }
  8021. }
  8022. ZjResultAll zra = new ZjResultAll();
  8023. zra.setBilletid(param1.get(0).toString());
  8024. if(sf_type.equals("上表面")) {
  8025. if(list1.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  8026. zra.setSfu_is_lock("0");
  8027. zra.setSfe_is_lock("0");
  8028. }
  8029. } else if(sf_type.equals("下表面")) {
  8030. if(list1.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  8031. zra.setSfd_is_lock("0");
  8032. zra.setSfe_is_lock("0");
  8033. }
  8034. }
  8035. zra.setSfe_is_lock("0");
  8036. /*if(list1.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  8037. zra.setSfe_is_lock("0");
  8038. }*/
  8039. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  8040. qjog.setOperate_name(param1.get(5).toString());
  8041. qjog.setOperate_type("解除");
  8042. qjog.setParams(param1.get(0).toString());
  8043. qjog.setBatchno(qjls.get(0).getBatch_no());
  8044. qjog.setProd_line(qjl.getPline_code());
  8045. mapper.insertQcmJudgeOperateLog(qjog);
  8046. mapper.UpdateJugeResultB(zra);
  8047. }else{
  8048. for(HashMap lists:list2){
  8049. if(!lists.get("JUDGERESULT").toString().equals("0")){
  8050. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  8051. }
  8052. }
  8053. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  8054. zra.setCoil_no(param1.get(0).toString());
  8055. if(list2.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  8056. zra.setSfu_is_lock("0");
  8057. }
  8058. if(list2.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  8059. zra.setSfd_is_lock("0");
  8060. }
  8061. if(list2.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  8062. zra.setSfe_is_lock("0");
  8063. }
  8064. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  8065. qjog.setOperate_name(param1.get(5).toString());
  8066. qjog.setOperate_type("解除");
  8067. qjog.setParams(param1.get(0).toString());
  8068. qjog.setBatchno(qjls.get(0).getBatch_no());
  8069. qjog.setProd_line(qjl.getPline_code());
  8070. mapper.insertQcmJudgeOperateLog(qjog);
  8071. mapper.UpdateJugeResultJ(zra);
  8072. }
  8073. }else{
  8074. throw new Exception("未找到库存信息!");
  8075. }
  8076. sql = "select * from qcm_judge_surface where surface_id = '"+lock_id+"' order by JUDGE_TIME desc";
  8077. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  8078. QcmJudgeSurface qjsf = new QcmJudgeSurface();
  8079. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  8080. if(sf_type.equals("上表面")) {
  8081. qjsf.setSfu_is_lock("0");
  8082. } else if(sf_type.equals("下表面")) {
  8083. qjsf.setSfd_is_lock("0");
  8084. }
  8085. /*qjsf.setSfe_is_lock("0");*/
  8086. mapper.UpdateQcmJudgeSurface(qjsf);
  8087. qjl.setUnlock_name(param1.get(5).toString());
  8088. qjl.setMaterial_no(param1.get(0).toString());
  8089. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  8090. mapper.UpdateQcmJudgeLocking(qjl);
  8091. SqlSession.commit();
  8092. }
  8093. }
  8094. }
  8095. catch(Exception e){
  8096. cro.setV_errCode(-1);
  8097. cro.setV_errMsg(e.getMessage());
  8098. SqlSession.rollback();
  8099. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.doInformationSureH2:【" + param1.toString() + "】" + e);
  8100. }
  8101. SqlSession.close();
  8102. return cro;
  8103. }
  8104. /**
  8105. * 材质异常申请 申请放行
  8106. */
  8107. public CoreReturnObject LockingApply(ArrayList param1) throws Exception{
  8108. try{
  8109. if(param1 == null || param1.size() <= 0){
  8110. throw new Exception("请传入参数!");
  8111. }
  8112. QcmJudgeSurfaceServiceImpl qjft = new QcmJudgeSurfaceServiceImpl();
  8113. String sql = "select * from qcm_judge_locking where material_no = '"+param1.get(0).toString()+"' and lock_seq = '"+param1.get(1).toString()+"' and unlock_type_code is null ";
  8114. List<QCMJudgeLocking> qjls = mapper.queryQCMJudgeLockings(sql);
  8115. if(qjls.size() == 0){
  8116. throw new Exception("该处置信息已被处置,未找到信息!");
  8117. }
  8118. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  8119. QCMJudgeLocking qjl = mapper.queryQCMJudgeLockings(sql).get(0);
  8120. sql = "select * from zj_result_all@xgcx where BILLETID = '"+param1.get(0).toString()+"'";
  8121. List<HashMap> list1 = mapper.query(sql);
  8122. sql = "select * from QCM_JUDGE_COIL_RESULT where coil_no = '"+param1.get(0).toString()+"'";
  8123. List<HashMap> list2 = mapper.query(sql);
  8124. sql = "select * from QCM_JUDGE_YT_COIL_RESULT where coil_no = '"+param1.get(0).toString()+"'";
  8125. List<HashMap> list3 = mapper.query(sql);
  8126. //放行
  8127. if(param1.get(3).toString().equals("0")){
  8128. //材质放行
  8129. if(param1.get(2).toString().equals("P")){
  8130. qjl.setPic_locking("0");
  8131. //更新库存表放行
  8132. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  8133. if(list1.size()>0){
  8134. for(HashMap lists:list1){
  8135. if(!lists.get("JUDGERESULT").toString().equals("0")){
  8136. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行申请!");
  8137. }
  8138. }
  8139. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list1.get(0).get("BILLETID_JY").toString()+"' and JUDGE_STATUS = '0'");
  8140. if(qjsrt.size() > 0){
  8141. throw new Exception("该检验号下存在未判信息,不能放行申请!");
  8142. }
  8143. for(HashMap lists:list1){
  8144. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  8145. qjog.setOperate_name(param1.get(5).toString());
  8146. qjog.setOperate_type("材质放行申请");
  8147. qjog.setParams(lists.get("BILLETID_JY").toString());
  8148. qjog.setBatchno(qjl.getBatch_no());
  8149. qjog.setProd_line(qjl.getPline_code());
  8150. mapper.insertQcmJudgeOperateLog(qjog);
  8151. //质量异常材处置
  8152. Date now = new Date();
  8153. String opr_time = new SimpleDateFormat("yyyyMMddHHmmss").format(now); //操作时间
  8154. SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
  8155. String date=sdf.format(now);
  8156. int count=0;
  8157. String type1 = "";
  8158. type1 = "AP";
  8159. sql ="select * from (select * from qcm_judge_locking_apply where apply_id like '"+type1+date+"%' order by apply_id desc) where rownum <= 1";
  8160. List<QcmJudgeLockingApply> listUl=mapper.QcmJudgeLockingApply(sql);
  8161. if (listUl!=null&&listUl.size()>0) {
  8162. String s=listUl.get(0).getApply_id();
  8163. count=Integer.parseInt(s.substring(s.length()-4,s.length()));
  8164. }
  8165. count++;
  8166. String APPLY_ID=type1+sdf.format(now)+String.format("%04d",count);
  8167. //qjl = new QCMJudgeLocking();
  8168. qjl.setUnlock_memo(param1.get(4).toString());
  8169. qjl.setUnlock_result(param1.get(9).toString());
  8170. qjl.setApply_id(APPLY_ID);
  8171. qjl.setPic_locking("2");
  8172. qjl.setStatus("1");
  8173. qjl.setBatch_no(qjls.get(0).getBatch_no());
  8174. qjl.setMaterial_no(lists.get("BILLETID").toString());
  8175. qjl.setUnlock_name(param1.get(5).toString());
  8176. qjl.setLock_id(param1.get(6).toString());
  8177. qjl.setReason_code(param1.get(7).toString());
  8178. qjl.setLock_type_code(param1.get(2).toString());
  8179. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  8180. if(listsu.size() >0)
  8181. {
  8182. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  8183. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  8184. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  8185. }
  8186. mapper.UpdateQcmJudgeLocking3(qjl);
  8187. QcmJudgeLockingApply qjla = new QcmJudgeLockingApply();
  8188. qjla.setApply_id(APPLY_ID);
  8189. qjla.setMaterial_no(qjl.getMaterial_no());
  8190. qjla.setLock_seq(qjl.getLock_seq());
  8191. qjla.setLock_type_code(qjl.getLock_type_code());
  8192. qjla.setLock_type_desc(qjl.getLock_type_desc());
  8193. qjla.setLock_memo(qjl.getLock_memo());
  8194. qjla.setUnlock_type_code("0");
  8195. qjla.setUnlock_type_desc("放行");
  8196. qjla.setUnlock_memo(qjl.getUnlock_memo());
  8197. qjla.setHeat_no(qjl.getHeat_no());
  8198. qjla.setBatch_no(qjl.getBatch_no());
  8199. qjla.setBoard_no(qjl.getBoard_no());
  8200. qjla.setPlan_no(qjl.getPlan_no());
  8201. qjla.setHt_no(qjl.getHt_no());
  8202. qjla.setDesign_key(qjl.getDesign_key());
  8203. qjla.setPsc(qjl.getPsc());
  8204. qjla.setPsc_desc(qjl.getPsc_desc());
  8205. qjla.setPline_code(qjl.getPline_code());
  8206. qjla.setPline_name(qjl.getPline_name());
  8207. qjla.setProd_code(qjl.getProd_code());
  8208. qjla.setProd_name(qjl.getProd_name());
  8209. qjla.setSteel_code(qjl.getSteel_code());
  8210. qjla.setSteel_name(qjl.getSteel_name());
  8211. qjla.setStd_code(qjl.getStd_code());
  8212. qjla.setStd_name(qjl.getStd_name());
  8213. qjla.setLock_id(qjl.getLock_id());
  8214. qjla.setCreate_id("");
  8215. qjla.setCreate_name(qjl.getUnlock_name());
  8216. qjla.setHeight(qjl.getHeight());
  8217. mapper.insertQCMJudgeLockingApply(qjla);
  8218. }
  8219. SqlSession.commit();
  8220. }else if(list2.size() >0){
  8221. for(HashMap lists:list2){
  8222. if(!lists.get("JUDGERESULT").toString().equals("0")){
  8223. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行申请!");
  8224. }
  8225. }
  8226. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  8227. if(qjsrt.size() > 0){
  8228. throw new Exception("该检验号下存在未判信息,不能放行申请!");
  8229. }
  8230. for(HashMap lists:list2){
  8231. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  8232. qjog.setOperate_name(param1.get(5).toString());
  8233. qjog.setOperate_type("材质放行申请");
  8234. qjog.setParams(lists.get("INSPECTION_LOT").toString());
  8235. qjog.setBatchno(qjl.getBatch_no());
  8236. qjog.setProd_line(qjl.getPline_code());
  8237. mapper.insertQcmJudgeOperateLog(qjog);
  8238. //质量异常材处置
  8239. Date now = new Date();
  8240. String opr_time = new SimpleDateFormat("yyyyMMddHHmmss").format(now); //操作时间
  8241. SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
  8242. String date=sdf.format(now);
  8243. int count=0;
  8244. String type1 = "";
  8245. type1 = "AP";
  8246. sql ="select * from (select * from qcm_judge_locking_apply where apply_id like '"+type1+date+"%' order by apply_id desc) where rownum <= 1";
  8247. List<QcmJudgeLockingApply> listUl=mapper.QcmJudgeLockingApply(sql);
  8248. if (listUl!=null&&listUl.size()>0) {
  8249. String s=listUl.get(0).getApply_id();
  8250. count=Integer.parseInt(s.substring(s.length()-4,s.length()));
  8251. }
  8252. count++;
  8253. String APPLY_ID=type1+sdf.format(now)+String.format("%04d",count);
  8254. //qjl = new QCMJudgeLocking();
  8255. qjl.setUnlock_memo(param1.get(4).toString());
  8256. qjl.setUnlock_result(param1.get(9).toString());
  8257. qjl.setPic_locking("2");
  8258. qjl.setStatus("1");
  8259. qjl.setApply_id(APPLY_ID);
  8260. qjl.setBatch_no(qjls.get(0).getBatch_no());
  8261. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  8262. qjl.setUnlock_name(param1.get(5).toString());
  8263. qjl.setLock_id(param1.get(6).toString());
  8264. qjl.setReason_code(param1.get(7).toString());
  8265. qjl.setLock_type_code(param1.get(2).toString());
  8266. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  8267. if(listsu.size() >0)
  8268. {
  8269. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  8270. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  8271. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  8272. }
  8273. mapper.UpdateQcmJudgeLocking3(qjl);
  8274. QcmJudgeLockingApply qjla = new QcmJudgeLockingApply();
  8275. qjla.setApply_id(APPLY_ID);
  8276. qjla.setMaterial_no(qjl.getMaterial_no());
  8277. qjla.setLock_seq(qjl.getLock_seq());
  8278. qjla.setLock_type_code(qjl.getLock_type_code());
  8279. qjla.setLock_type_desc(qjl.getLock_type_desc());
  8280. qjla.setLock_memo(qjl.getLock_memo());
  8281. qjla.setUnlock_type_code("0");
  8282. qjla.setUnlock_type_desc("放行");
  8283. qjla.setUnlock_memo(qjl.getUnlock_memo());
  8284. qjla.setHeat_no(qjl.getHeat_no());
  8285. qjla.setBatch_no(qjl.getBatch_no());
  8286. qjla.setBoard_no(qjl.getBoard_no());
  8287. qjla.setPlan_no(qjl.getPlan_no());
  8288. qjla.setHt_no(qjl.getHt_no());
  8289. qjla.setDesign_key(qjl.getDesign_key());
  8290. qjla.setPsc(qjl.getPsc());
  8291. qjla.setPsc_desc(qjl.getPsc_desc());
  8292. qjla.setPline_code(qjl.getPline_code());
  8293. qjla.setPline_name(qjl.getPline_name());
  8294. qjla.setProd_code(qjl.getProd_code());
  8295. qjla.setProd_name(qjl.getProd_name());
  8296. qjla.setSteel_code(qjl.getSteel_code());
  8297. qjla.setSteel_name(qjl.getSteel_name());
  8298. qjla.setStd_code(qjl.getStd_code());
  8299. qjla.setStd_name(qjl.getStd_name());
  8300. qjla.setLock_id(qjl.getLock_id());
  8301. qjla.setCreate_id("");
  8302. qjla.setCreate_name(qjl.getUnlock_name());
  8303. qjla.setHeight(qjl.getHeight());
  8304. mapper.insertQCMJudgeLockingApply(qjla);
  8305. }
  8306. SqlSession.commit();
  8307. }else{
  8308. for(HashMap lists:list3){
  8309. if(!lists.get("JUDGERESULT").toString().equals("0")){
  8310. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行申请!");
  8311. }
  8312. }
  8313. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  8314. if(qjsrt.size() > 0){
  8315. throw new Exception("该检验号下存在未判信息,不能放行申请!");
  8316. }
  8317. for(HashMap lists:list3){
  8318. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  8319. qjog.setOperate_name(param1.get(5).toString());
  8320. qjog.setOperate_type("材质放行申请");
  8321. qjog.setParams(lists.get("INSPECTION_LOT").toString());
  8322. qjog.setBatchno(qjl.getBatch_no());
  8323. qjog.setProd_line(qjl.getPline_code());
  8324. mapper.insertQcmJudgeOperateLog(qjog);
  8325. //质量异常材处置
  8326. Date now = new Date();
  8327. String opr_time = new SimpleDateFormat("yyyyMMddHHmmss").format(now); //操作时间
  8328. SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
  8329. String date=sdf.format(now);
  8330. int count=0;
  8331. String type1 = "";
  8332. type1 = "AP";
  8333. sql ="select * from (select * from qcm_judge_locking_apply where apply_id like '"+type1+date+"%' order by apply_id desc) where rownum <= 1";
  8334. List<QcmJudgeLockingApply> listUl=mapper.QcmJudgeLockingApply(sql);
  8335. if (listUl!=null&&listUl.size()>0) {
  8336. String s=listUl.get(0).getApply_id();
  8337. count=Integer.parseInt(s.substring(s.length()-4,s.length()));
  8338. }
  8339. count++;
  8340. String APPLY_ID=type1+sdf.format(now)+String.format("%04d",count);
  8341. //qjl = new QCMJudgeLocking();
  8342. qjl.setUnlock_memo(param1.get(4).toString());
  8343. qjl.setUnlock_result(param1.get(9).toString());
  8344. qjl.setApply_id(APPLY_ID);
  8345. qjl.setPic_locking("2");
  8346. qjl.setStatus("1");
  8347. qjl.setBatch_no(qjls.get(0).getBatch_no());
  8348. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  8349. qjl.setUnlock_name(param1.get(5).toString());
  8350. qjl.setLock_id(param1.get(6).toString());
  8351. qjl.setReason_code(param1.get(7).toString());
  8352. qjl.setLock_type_code(param1.get(2).toString());
  8353. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  8354. if(listsu.size() >0)
  8355. {
  8356. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  8357. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  8358. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  8359. }
  8360. mapper.UpdateQcmJudgeLocking3(qjl);
  8361. QcmJudgeLockingApply qjla = new QcmJudgeLockingApply();
  8362. qjla.setApply_id(APPLY_ID);
  8363. qjla.setMaterial_no(qjl.getMaterial_no());
  8364. qjla.setLock_seq(qjl.getLock_seq());
  8365. qjla.setLock_type_code(qjl.getLock_type_code());
  8366. qjla.setLock_type_desc(qjl.getLock_type_desc());
  8367. qjla.setLock_memo(qjl.getLock_memo());
  8368. qjla.setUnlock_type_code("0");
  8369. qjla.setUnlock_type_desc("放行");
  8370. qjla.setUnlock_memo(qjl.getUnlock_memo());
  8371. qjla.setHeat_no(qjl.getHeat_no());
  8372. qjla.setBatch_no(qjl.getBatch_no());
  8373. qjla.setBoard_no(qjl.getBoard_no());
  8374. qjla.setPlan_no(qjl.getPlan_no());
  8375. qjla.setHt_no(qjl.getHt_no());
  8376. qjla.setDesign_key(qjl.getDesign_key());
  8377. qjla.setPsc(qjl.getPsc());
  8378. qjla.setPsc_desc(qjl.getPsc_desc());
  8379. qjla.setPline_code(qjl.getPline_code());
  8380. qjla.setPline_name(qjl.getPline_name());
  8381. qjla.setProd_code(qjl.getProd_code());
  8382. qjla.setProd_name(qjl.getProd_name());
  8383. qjla.setSteel_code(qjl.getSteel_code());
  8384. qjla.setSteel_name(qjl.getSteel_name());
  8385. qjla.setStd_code(qjl.getStd_code());
  8386. qjla.setStd_name(qjl.getStd_name());
  8387. qjla.setLock_id(qjl.getLock_id());
  8388. qjla.setCreate_id("");
  8389. qjla.setCreate_name(qjl.getUnlock_name());
  8390. qjla.setHeight(qjl.getHeight());
  8391. mapper.insertQCMJudgeLockingApply(qjla);
  8392. }
  8393. SqlSession.commit();
  8394. }
  8395. }else{
  8396. throw new Exception("未找到库存信息!");
  8397. }
  8398. }if(param1.get(2).toString().equals("C")){
  8399. qjl.setCic_locking("0");
  8400. //更改合同与试样表
  8401. if(list1.size() >0 || list2.size() >0 || list3.size()>0){
  8402. if(list1.size()>0){
  8403. for(HashMap lists:list1){
  8404. if(!lists.get("JUDGERESULT").toString().equals("0")){
  8405. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  8406. }
  8407. }
  8408. if(param1.get(6).toString().contains("C")){
  8409. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list1.get(0).get("BILLETID_JY").toString()+"' and JUDGE_STATUS = '0'");
  8410. if(qjsrt.size() > 0){
  8411. throw new Exception("该检验号下存在未判信息,不能放行!");
  8412. }
  8413. for(HashMap lists:list1){
  8414. //质量异常材处置
  8415. Date now = new Date();
  8416. String opr_time = new SimpleDateFormat("yyyyMMddHHmmss").format(now); //操作时间
  8417. SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
  8418. String date=sdf.format(now);
  8419. int count=0;
  8420. String type1 = "";
  8421. type1 = "AP";
  8422. sql ="select * from (select * from qcm_judge_locking_apply where apply_id like '"+type1+date+"%' order by apply_id desc) where rownum <= 1";
  8423. List<QcmJudgeLockingApply> listUl=mapper.QcmJudgeLockingApply(sql);
  8424. if (listUl!=null&&listUl.size()>0) {
  8425. String s=listUl.get(0).getApply_id();
  8426. count=Integer.parseInt(s.substring(s.length()-4,s.length()));
  8427. }
  8428. count++;
  8429. String APPLY_ID=type1+sdf.format(now)+String.format("%04d",count);
  8430. qjl = new QCMJudgeLocking();
  8431. qjl.setUnlock_memo(param1.get(4).toString());
  8432. qjl.setUnlock_result(param1.get(9).toString());
  8433. qjl.setCic_locking("2");
  8434. qjl.setStatus("1");
  8435. qjl.setApply_id(APPLY_ID);
  8436. qjl.setBatch_no(qjls.get(0).getBatch_no());
  8437. //qjl.setMaterial_no(lists.get("BILLETID").toString());
  8438. qjl.setUnlock_name(param1.get(5).toString());
  8439. qjl.setLock_id(param1.get(6).toString());
  8440. qjl.setReason_code(param1.get(7).toString());
  8441. qjl.setLock_type_code(param1.get(2).toString());
  8442. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  8443. if(listsu.size() >0)
  8444. {
  8445. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  8446. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  8447. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  8448. }
  8449. mapper.UpdateQcmJudgeLocking3(qjl);
  8450. QcmJudgeLockingApply qjla = new QcmJudgeLockingApply();
  8451. qjla.setApply_id(APPLY_ID);
  8452. qjla.setMaterial_no(qjl.getMaterial_no());
  8453. qjla.setLock_seq(qjl.getLock_seq());
  8454. qjla.setLock_type_code(qjl.getLock_type_code());
  8455. qjla.setLock_type_desc(qjl.getLock_type_desc());
  8456. qjla.setLock_memo(qjl.getLock_memo());
  8457. qjla.setUnlock_type_code("0");
  8458. qjla.setUnlock_type_desc("放行");
  8459. qjla.setUnlock_memo(qjl.getUnlock_memo());
  8460. qjla.setHeat_no(qjl.getHeat_no());
  8461. qjla.setBatch_no(qjl.getBatch_no());
  8462. qjla.setBoard_no(qjl.getBoard_no());
  8463. qjla.setPlan_no(qjl.getPlan_no());
  8464. qjla.setHt_no(qjl.getHt_no());
  8465. qjla.setDesign_key(qjl.getDesign_key());
  8466. qjla.setPsc(qjl.getPsc());
  8467. qjla.setPsc_desc(qjl.getPsc_desc());
  8468. qjla.setPline_code(qjl.getPline_code());
  8469. qjla.setPline_name(qjl.getPline_name());
  8470. qjla.setProd_code(qjl.getProd_code());
  8471. qjla.setProd_name(qjl.getProd_name());
  8472. qjla.setSteel_code(qjl.getSteel_code());
  8473. qjla.setSteel_name(qjl.getSteel_name());
  8474. qjla.setStd_code(qjl.getStd_code());
  8475. qjla.setStd_name(qjl.getStd_name());
  8476. qjla.setLock_id(qjl.getLock_id());
  8477. qjla.setCreate_id("");
  8478. qjla.setCreate_name(qjl.getUnlock_name());
  8479. qjla.setHeight(qjl.getHeight());
  8480. mapper.insertQCMJudgeLockingApply(qjla);
  8481. }
  8482. SqlSession.commit();
  8483. }else{
  8484. Date now = new Date();
  8485. String opr_time = new SimpleDateFormat("yyyyMMddHHmmss").format(now); //操作时间
  8486. SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
  8487. String date=sdf.format(now);
  8488. int count=0;
  8489. String type1 = "";
  8490. type1 = "AP";
  8491. sql ="select * from (select * from qcm_judge_locking_apply where apply_id like '"+type1+date+"%' order by apply_id desc) where rownum <= 1";
  8492. List<QcmJudgeLockingApply> listUl=mapper.QcmJudgeLockingApply(sql);
  8493. if (listUl!=null&&listUl.size()>0) {
  8494. String s=listUl.get(0).getApply_id();
  8495. count=Integer.parseInt(s.substring(s.length()-4,s.length()));
  8496. }
  8497. count++;
  8498. String APPLY_ID=type1+sdf.format(now)+String.format("%04d",count);
  8499. qjl.setUnlock_name(param1.get(5).toString());
  8500. qjl.setApply_id(APPLY_ID);
  8501. qjl.setStatus("1");
  8502. qjl.setReason_code(param1.get(7).toString());
  8503. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  8504. if(listsu.size() >0)
  8505. {
  8506. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  8507. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  8508. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  8509. }
  8510. mapper.UpdateQcmJudgeLocking(qjl);
  8511. QcmJudgeLockingApply qjla = new QcmJudgeLockingApply();
  8512. qjla.setApply_id(APPLY_ID);
  8513. qjla.setMaterial_no(qjl.getMaterial_no());
  8514. qjla.setLock_seq(qjl.getLock_seq());
  8515. qjla.setLock_type_code(qjl.getLock_type_code());
  8516. qjla.setLock_type_desc(qjl.getLock_type_desc());
  8517. qjla.setLock_memo(qjl.getLock_memo());
  8518. qjla.setUnlock_type_code("0");
  8519. qjla.setUnlock_type_desc("放行");
  8520. qjla.setUnlock_memo(qjl.getUnlock_memo());
  8521. qjla.setHeat_no(qjl.getHeat_no());
  8522. qjla.setBatch_no(qjl.getBatch_no());
  8523. qjla.setBoard_no(qjl.getBoard_no());
  8524. qjla.setPlan_no(qjl.getPlan_no());
  8525. qjla.setHt_no(qjl.getHt_no());
  8526. qjla.setDesign_key(qjl.getDesign_key());
  8527. qjla.setPsc(qjl.getPsc());
  8528. qjla.setPsc_desc(qjl.getPsc_desc());
  8529. qjla.setPline_code(qjl.getPline_code());
  8530. qjla.setPline_name(qjl.getPline_name());
  8531. qjla.setProd_code(qjl.getProd_code());
  8532. qjla.setProd_name(qjl.getProd_name());
  8533. qjla.setSteel_code(qjl.getSteel_code());
  8534. qjla.setSteel_name(qjl.getSteel_name());
  8535. qjla.setStd_code(qjl.getStd_code());
  8536. qjla.setStd_name(qjl.getStd_name());
  8537. qjla.setLock_id(qjl.getLock_id());
  8538. qjla.setCreate_id("");
  8539. qjla.setCreate_name(qjl.getUnlock_name());
  8540. qjla.setHeight(qjl.getHeight());
  8541. mapper.insertQCMJudgeLockingApply(qjla);
  8542. SqlSession.commit();
  8543. }
  8544. }else if(list2.size() >0){
  8545. for(HashMap lists:list2){
  8546. if(!lists.get("JUDGERESULT").toString().equals("0")){
  8547. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  8548. }
  8549. }
  8550. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  8551. if(param1.get(6).toString().contains("C")){
  8552. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  8553. if(qjsrt.size() > 0){
  8554. throw new Exception("该检验号下存在未判信息,不能放行!");
  8555. }
  8556. //PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  8557. //QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  8558. for(HashMap lists:list2){
  8559. //质量异常材处置
  8560. Date now = new Date();
  8561. String opr_time = new SimpleDateFormat("yyyyMMddHHmmss").format(now); //操作时间
  8562. SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
  8563. String date=sdf.format(now);
  8564. int count=0;
  8565. String type1 = "";
  8566. type1 = "AP";
  8567. sql ="select * from (select * from qcm_judge_locking_apply where apply_id like '"+type1+date+"%' order by apply_id desc) where rownum <= 1";
  8568. List<QcmJudgeLockingApply> listUl=mapper.QcmJudgeLockingApply(sql);
  8569. if (listUl!=null&&listUl.size()>0) {
  8570. String s=listUl.get(0).getApply_id();
  8571. count=Integer.parseInt(s.substring(s.length()-4,s.length()));
  8572. }
  8573. count++;
  8574. String APPLY_ID=type1+sdf.format(now)+String.format("%04d",count);
  8575. qjl = new QCMJudgeLocking();
  8576. qjl.setUnlock_memo(param1.get(4).toString());
  8577. qjl.setUnlock_result(param1.get(9).toString());
  8578. qjl.setCic_locking("2");
  8579. qjl.setStatus("1");
  8580. qjl.setApply_id(APPLY_ID);
  8581. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  8582. qjl.setBatch_no(qjls.get(0).getBatch_no());
  8583. qjl.setUnlock_name(param1.get(5).toString());
  8584. qjl.setLock_id(param1.get(6).toString());
  8585. qjl.setReason_code(param1.get(7).toString());
  8586. qjl.setLock_type_code(param1.get(2).toString());
  8587. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  8588. if(listsu.size() >0)
  8589. {
  8590. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  8591. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  8592. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  8593. }
  8594. mapper.UpdateQcmJudgeLocking3(qjl);
  8595. QcmJudgeLockingApply qjla = new QcmJudgeLockingApply();
  8596. qjla.setApply_id(APPLY_ID);
  8597. qjla.setMaterial_no(qjl.getMaterial_no());
  8598. qjla.setLock_seq(qjl.getLock_seq());
  8599. qjla.setLock_type_code(qjl.getLock_type_code());
  8600. qjla.setLock_type_desc(qjl.getLock_type_desc());
  8601. qjla.setLock_memo(qjl.getLock_memo());
  8602. qjla.setUnlock_type_code("0");
  8603. qjla.setUnlock_type_desc("放行");
  8604. qjla.setUnlock_memo(qjl.getUnlock_memo());
  8605. qjla.setHeat_no(qjl.getHeat_no());
  8606. qjla.setBatch_no(qjl.getBatch_no());
  8607. qjla.setBoard_no(qjl.getBoard_no());
  8608. qjla.setPlan_no(qjl.getPlan_no());
  8609. qjla.setHt_no(qjl.getHt_no());
  8610. qjla.setDesign_key(qjl.getDesign_key());
  8611. qjla.setPsc(qjl.getPsc());
  8612. qjla.setPsc_desc(qjl.getPsc_desc());
  8613. qjla.setPline_code(qjl.getPline_code());
  8614. qjla.setPline_name(qjl.getPline_name());
  8615. qjla.setProd_code(qjl.getProd_code());
  8616. qjla.setProd_name(qjl.getProd_name());
  8617. qjla.setSteel_code(qjl.getSteel_code());
  8618. qjla.setSteel_name(qjl.getSteel_name());
  8619. qjla.setStd_code(qjl.getStd_code());
  8620. qjla.setStd_name(qjl.getStd_name());
  8621. qjla.setLock_id(qjl.getLock_id());
  8622. qjla.setCreate_id("");
  8623. qjla.setCreate_name(qjl.getUnlock_name());
  8624. qjla.setHeight(qjl.getHeight());
  8625. mapper.insertQCMJudgeLockingApply(qjla);
  8626. }
  8627. SqlSession.commit();
  8628. }else{
  8629. Date now = new Date();
  8630. String opr_time = new SimpleDateFormat("yyyyMMddHHmmss").format(now); //操作时间
  8631. SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
  8632. String date=sdf.format(now);
  8633. int count=0;
  8634. String type1 = "";
  8635. type1 = "AP";
  8636. sql ="select * from (select * from qcm_judge_locking_apply where apply_id like '"+type1+date+"%' order by apply_id desc) where rownum <= 1";
  8637. List<QcmJudgeLockingApply> listUl=mapper.QcmJudgeLockingApply(sql);
  8638. if (listUl!=null&&listUl.size()>0) {
  8639. String s=listUl.get(0).getApply_id();
  8640. count=Integer.parseInt(s.substring(s.length()-4,s.length()));
  8641. }
  8642. count++;
  8643. String APPLY_ID=type1+sdf.format(now)+String.format("%04d",count);
  8644. qjl.setUnlock_name(param1.get(5).toString());
  8645. qjl.setReason_code(param1.get(7).toString());
  8646. qjl.setApply_id(APPLY_ID);
  8647. qjl.setStatus("1");
  8648. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  8649. if(listsu.size() >0)
  8650. {
  8651. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  8652. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  8653. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  8654. }
  8655. mapper.UpdateQcmJudgeLocking(qjl);
  8656. QcmJudgeLockingApply qjla = new QcmJudgeLockingApply();
  8657. qjla.setApply_id(APPLY_ID);
  8658. qjla.setMaterial_no(qjl.getMaterial_no());
  8659. qjla.setLock_seq(qjl.getLock_seq());
  8660. qjla.setLock_type_code(qjl.getLock_type_code());
  8661. qjla.setLock_type_desc(qjl.getLock_type_desc());
  8662. qjla.setLock_memo(qjl.getLock_memo());
  8663. qjla.setUnlock_type_code("0");
  8664. qjla.setUnlock_type_desc("放行");
  8665. qjla.setUnlock_memo(qjl.getUnlock_memo());
  8666. qjla.setHeat_no(qjl.getHeat_no());
  8667. qjla.setBatch_no(qjl.getBatch_no());
  8668. qjla.setBoard_no(qjl.getBoard_no());
  8669. qjla.setPlan_no(qjl.getPlan_no());
  8670. qjla.setHt_no(qjl.getHt_no());
  8671. qjla.setDesign_key(qjl.getDesign_key());
  8672. qjla.setPsc(qjl.getPsc());
  8673. qjla.setPsc_desc(qjl.getPsc_desc());
  8674. qjla.setPline_code(qjl.getPline_code());
  8675. qjla.setPline_name(qjl.getPline_name());
  8676. qjla.setProd_code(qjl.getProd_code());
  8677. qjla.setProd_name(qjl.getProd_name());
  8678. qjla.setSteel_code(qjl.getSteel_code());
  8679. qjla.setSteel_name(qjl.getSteel_name());
  8680. qjla.setStd_code(qjl.getStd_code());
  8681. qjla.setStd_name(qjl.getStd_name());
  8682. qjla.setLock_id(qjl.getLock_id());
  8683. qjla.setCreate_id("");
  8684. qjla.setCreate_name(qjl.getUnlock_name());
  8685. qjla.setHeight(qjl.getHeight());
  8686. mapper.insertQCMJudgeLockingApply(qjla);
  8687. SqlSession.commit();
  8688. }
  8689. }else{
  8690. for(HashMap lists:list3){
  8691. if(!lists.get("JUDGERESULT").toString().equals("0")){
  8692. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  8693. }
  8694. }
  8695. if(param1.get(6).toString().contains("C")){
  8696. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  8697. if(qjsrt.size() > 0){
  8698. throw new Exception("该检验号下存在未判信息,不能放行!");
  8699. }
  8700. //PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  8701. //QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  8702. for(HashMap lists:list2){
  8703. //质量异常材处置
  8704. Date now = new Date();
  8705. String opr_time = new SimpleDateFormat("yyyyMMddHHmmss").format(now); //操作时间
  8706. SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
  8707. String date=sdf.format(now);
  8708. int count=0;
  8709. String type1 = "";
  8710. type1 = "AP";
  8711. sql ="select * from (select * from qcm_judge_locking_apply where apply_id like '"+type1+date+"%' order by apply_id desc) where rownum <= 1";
  8712. List<QcmJudgeLockingApply> listUl=mapper.QcmJudgeLockingApply(sql);
  8713. if (listUl!=null&&listUl.size()>0) {
  8714. String s=listUl.get(0).getApply_id();
  8715. count=Integer.parseInt(s.substring(s.length()-4,s.length()));
  8716. }
  8717. count++;
  8718. String APPLY_ID=type1+sdf.format(now)+String.format("%04d",count);
  8719. qjl = new QCMJudgeLocking();
  8720. qjl.setUnlock_memo(param1.get(4).toString());
  8721. qjl.setUnlock_result(param1.get(9).toString());
  8722. qjl.setApply_id(APPLY_ID);
  8723. qjl.setCic_locking("2");
  8724. qjl.setStatus("1");
  8725. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  8726. qjl.setBatch_no(qjls.get(0).getBatch_no());
  8727. qjl.setUnlock_name(param1.get(5).toString());
  8728. qjl.setLock_id(param1.get(6).toString());
  8729. qjl.setReason_code(param1.get(7).toString());
  8730. qjl.setLock_type_code(param1.get(2).toString());
  8731. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  8732. if(listsu.size() >0)
  8733. {
  8734. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  8735. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  8736. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  8737. }
  8738. mapper.UpdateQcmJudgeLocking3(qjl);
  8739. QcmJudgeLockingApply qjla = new QcmJudgeLockingApply();
  8740. qjla.setApply_id(APPLY_ID);
  8741. qjla.setMaterial_no(qjl.getMaterial_no());
  8742. qjla.setLock_seq(qjl.getLock_seq());
  8743. qjla.setLock_type_code(qjl.getLock_type_code());
  8744. qjla.setLock_type_desc(qjl.getLock_type_desc());
  8745. qjla.setLock_memo(qjl.getLock_memo());
  8746. qjla.setUnlock_type_code("0");
  8747. qjla.setUnlock_type_desc("放行");
  8748. qjla.setUnlock_memo(qjl.getUnlock_memo());
  8749. qjla.setHeat_no(qjl.getHeat_no());
  8750. qjla.setBatch_no(qjl.getBatch_no());
  8751. qjla.setBoard_no(qjl.getBoard_no());
  8752. qjla.setPlan_no(qjl.getPlan_no());
  8753. qjla.setHt_no(qjl.getHt_no());
  8754. qjla.setDesign_key(qjl.getDesign_key());
  8755. qjla.setPsc(qjl.getPsc());
  8756. qjla.setPsc_desc(qjl.getPsc_desc());
  8757. qjla.setPline_code(qjl.getPline_code());
  8758. qjla.setPline_name(qjl.getPline_name());
  8759. qjla.setProd_code(qjl.getProd_code());
  8760. qjla.setProd_name(qjl.getProd_name());
  8761. qjla.setSteel_code(qjl.getSteel_code());
  8762. qjla.setSteel_name(qjl.getSteel_name());
  8763. qjla.setStd_code(qjl.getStd_code());
  8764. qjla.setStd_name(qjl.getStd_name());
  8765. qjla.setLock_id(qjl.getLock_id());
  8766. qjla.setCreate_id("");
  8767. qjla.setCreate_name(qjl.getUnlock_name());
  8768. qjla.setHeight(qjl.getHeight());
  8769. mapper.insertQCMJudgeLockingApply(qjla);
  8770. }
  8771. SqlSession.commit();
  8772. }else{
  8773. Date now = new Date();
  8774. String opr_time = new SimpleDateFormat("yyyyMMddHHmmss").format(now); //操作时间
  8775. SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
  8776. String date=sdf.format(now);
  8777. int count=0;
  8778. String type1 = "";
  8779. type1 = "AP";
  8780. sql ="select * from (select * from qcm_judge_locking_apply where apply_id like '"+type1+date+"%' order by apply_id desc) where rownum <= 1";
  8781. List<QcmJudgeLockingApply> listUl=mapper.QcmJudgeLockingApply(sql);
  8782. if (listUl!=null&&listUl.size()>0) {
  8783. String s=listUl.get(0).getApply_id();
  8784. count=Integer.parseInt(s.substring(s.length()-4,s.length()));
  8785. }
  8786. count++;
  8787. String APPLY_ID=type1+sdf.format(now)+String.format("%04d",count);
  8788. qjl.setUnlock_name(param1.get(5).toString());
  8789. qjl.setApply_id(APPLY_ID);
  8790. qjl.setStatus("1");
  8791. qjl.setReason_code(param1.get(7).toString());
  8792. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  8793. if(listsu.size() >0)
  8794. {
  8795. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  8796. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  8797. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  8798. }
  8799. mapper.UpdateQcmJudgeLocking(qjl);
  8800. QcmJudgeLockingApply qjla = new QcmJudgeLockingApply();
  8801. qjla.setApply_id(APPLY_ID);
  8802. qjla.setMaterial_no(qjl.getMaterial_no());
  8803. qjla.setLock_seq(qjl.getLock_seq());
  8804. qjla.setLock_type_code(qjl.getLock_type_code());
  8805. qjla.setLock_type_desc(qjl.getLock_type_desc());
  8806. qjla.setLock_memo(qjl.getLock_memo());
  8807. qjla.setUnlock_type_code("0");
  8808. qjla.setUnlock_type_desc("放行");
  8809. qjla.setUnlock_memo(qjl.getUnlock_memo());
  8810. qjla.setHeat_no(qjl.getHeat_no());
  8811. qjla.setBatch_no(qjl.getBatch_no());
  8812. qjla.setBoard_no(qjl.getBoard_no());
  8813. qjla.setPlan_no(qjl.getPlan_no());
  8814. qjla.setHt_no(qjl.getHt_no());
  8815. qjla.setDesign_key(qjl.getDesign_key());
  8816. qjla.setPsc(qjl.getPsc());
  8817. qjla.setPsc_desc(qjl.getPsc_desc());
  8818. qjla.setPline_code(qjl.getPline_code());
  8819. qjla.setPline_name(qjl.getPline_name());
  8820. qjla.setProd_code(qjl.getProd_code());
  8821. qjla.setProd_name(qjl.getProd_name());
  8822. qjla.setSteel_code(qjl.getSteel_code());
  8823. qjla.setSteel_name(qjl.getSteel_name());
  8824. qjla.setStd_code(qjl.getStd_code());
  8825. qjla.setStd_name(qjl.getStd_name());
  8826. qjla.setLock_id(qjl.getLock_id());
  8827. qjla.setCreate_id("");
  8828. qjla.setCreate_name(qjl.getUnlock_name());
  8829. qjla.setHeight(qjl.getHeight());
  8830. mapper.insertQCMJudgeLockingApply(qjla);
  8831. SqlSession.commit();
  8832. }
  8833. }
  8834. }else{
  8835. throw new Exception("未找到库存信息!");
  8836. }
  8837. }
  8838. }
  8839. }
  8840. catch(Exception e){
  8841. cro.setV_errCode(-1);
  8842. cro.setV_errMsg(e.getMessage());
  8843. SqlSession.rollback();
  8844. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.LockingApply:【" + param1.toString() + "】" + e);
  8845. }
  8846. SqlSession.close();
  8847. return cro;
  8848. }
  8849. /**param1 改判除外的异常材处置 审批通过
  8850. * 产品序号、锁定记录号、封锁来源、处置去向、操作人,单项判定记录号、产线、申请编号
  8851. * @param param1
  8852. * @return
  8853. * @throws Exception
  8854. */
  8855. @SuppressWarnings("rawtypes")
  8856. public CoreReturnObject doApplyFx(ArrayList param2) throws Exception{
  8857. try{
  8858. if(param2 == null || param2.size() <= 0){
  8859. throw new Exception("请传入参数!");
  8860. }
  8861. String upsql = "update QCM_JUDGE_LOCKING_APPLY t set t.handle_memo = '"+param2.get(8).toString()+"' where t.apply_id = '"+param2.get(7).toString()+"' ";
  8862. mapper.updateJudgeStatus(upsql.toString());
  8863. SqlSession.commit();
  8864. String sql = "select * from qcm_judge_locking where material_no = '"+param2.get(0).toString()+"' and lock_seq = '"+param2.get(1).toString()+"' and unlock_type_code is null ";
  8865. List<QCMJudgeLocking> qjls = mapper.queryQCMJudgeLockings(sql);
  8866. if(qjls.size() == 0){
  8867. SqlSession.close();
  8868. return cro;
  8869. }
  8870. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  8871. /*List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(param1.get(0).toString());
  8872. if(hashmap.size() == 0){
  8873. hashmap = qjms.doQueryMaterialInfoJ(param1.get(0).toString());
  8874. }*/
  8875. QcmJudgeSurfaceServiceImpl qjft = new QcmJudgeSurfaceServiceImpl();
  8876. QCMJudgeLocking qjl = qjls.get(0);
  8877. sql = "select * from zj_result_all@xgcx where BILLETID = '"+param2.get(0).toString()+"'";
  8878. List<HashMap> list1 = mapper.query(sql);
  8879. sql = "select * from QCM_JUDGE_COIL_RESULT where coil_no = '"+param2.get(0).toString()+"'";
  8880. List<HashMap> list2 = mapper.query(sql);
  8881. sql = "select * from QCM_JUDGE_YT_COIL_RESULT where coil_no = '"+param2.get(0).toString()+"'";
  8882. List<HashMap> list3 = mapper.query(sql);
  8883. //放行
  8884. if(param2.get(3).toString().equals("0")){
  8885. qjl.setUnlock_type_code("0");
  8886. qjl.setUnlock_type_desc("放行");
  8887. //材质放行
  8888. if(param2.get(2).toString().equals("P")){
  8889. qjl.setPic_locking("0");
  8890. //更改合同试样表
  8891. List<QcmJhySampleROrd> qjst = mapper.queryQcmJhySampleROrd1("select * from qcm_jhy_sample_r_ord where phy_id = '"+param2.get(5).toString()+"'");
  8892. QcmJhySampleROrd qjsr = new QcmJhySampleROrd();
  8893. qjsr.setPhy_id(param2.get(5).toString());
  8894. qjsr.setJudge_result_code("1");
  8895. qjsr.setJudge_result_desc("合格");
  8896. qjsr.setJudge_name(param2.get(4).toString());
  8897. qjsr.setJudge_time(new Date());
  8898. qjsr.setDesign_key(qjl.getDesign_key());
  8899. qjsr.setPsc(qjst.get(0).getPsc());
  8900. qjsr.setSmp_no(qjst.get(0).getSmp_no());
  8901. mapper.updateQcmJhySampleROrds(qjsr);
  8902. /*sql = "select * from qcm_judge_physical where phy_id = '"+param1.get(6).toString()+"' order by judge_ttime desc";
  8903. List<QcmJudgePhysical> qjps = mapper.queryQcmJudgePhysical(sql);
  8904. QcmJudgePhysical qjsf = new QcmJudgePhysical();
  8905. qjsf.setPhy_id(qjps.get(0).getPhy_id());
  8906. qjsf.setPhy_result_code("1");
  8907. qjsf.setPhy_result_desc("合格");
  8908. mapper.updateQcmJudgePhysical(qjsf);*/
  8909. //更新库存表放行
  8910. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  8911. if(list1.size()>0){
  8912. for(HashMap lists:list1){
  8913. if(!lists.get("JUDGERESULT").toString().equals("0")){
  8914. throw new Exception("该产品序号["+param2.get(0).toString()+"]做了综合判定,不能审批通过!");
  8915. }
  8916. }
  8917. ZjResultAll zra = new ZjResultAll();
  8918. if(param2.get(5).toString().equals(list1.get(0).get("PHYFSTSID"))){
  8919. zra.setPhyfstsresult("1");
  8920. zra.setPhyfstsresult_desc("合格");
  8921. }
  8922. zra.setBilletid(list1.get(0).get("BILLETID").toString());
  8923. zra.setPic_is_lock("2");
  8924. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list1.get(0).get("BILLETID_JY").toString()+"' and JUDGE_STATUS = '0'");
  8925. if(qjsrt.size() > 0){
  8926. throw new Exception("该检验号下存在未判信息,不能放行!");
  8927. }
  8928. mapper.UpdateJugeResultB(zra);
  8929. PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param2.get(4).toString());
  8930. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  8931. for(HashMap lists:list1){
  8932. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  8933. qjog.setOperate_name(param2.get(4).toString());
  8934. qjog.setOperate_type("材质放行通过");
  8935. qjog.setParams(lists.get("BILLETID_JY").toString());
  8936. qjog.setBatchno(qjl.getBatch_no());
  8937. qjog.setProd_line(qjl.getPline_code());
  8938. mapper.insertQcmJudgeOperateLog(qjog);
  8939. //质量异常材处置
  8940. qjl = new QCMJudgeLocking();
  8941. qjl.setUnlock_type_code("0");
  8942. qjl.setUnlock_type_desc("放行");
  8943. qjl.setPic_locking("2");
  8944. qjl.setStatus("2");
  8945. qjl.setBatch_no(qjls.get(0).getBatch_no());
  8946. qjl.setMaterial_no(lists.get("BILLETID").toString());
  8947. qjl.setLock_id(param2.get(5).toString());
  8948. qjl.setLock_type_code(param2.get(2).toString());
  8949. qjl.setCheck_name(param2.get(4).toString());
  8950. mapper.UpdateQcmJudgeLocking3(qjl);
  8951. mapper.doApply(param2.get(7).toString(),param2.get(4).toString(),"1");
  8952. //mapper.upda
  8953. QcmJudgeLog qjlt = new QcmJudgeLog();
  8954. qjlt.setJudge_type("U");
  8955. qjlt.setMaterial_no(lists.get("BILLETID").toString());
  8956. qjlt.setCreate_name("system");
  8957. qjlt.setProd_line(qjl.getPline_code());
  8958. mapper.insertQcmJudgeLog(qjlt);
  8959. }
  8960. SqlSession.commit();
  8961. }else if(list2.size() >0){
  8962. for(HashMap lists:list2){
  8963. if(!lists.get("JUDGERESULT").toString().equals("0")){
  8964. throw new Exception("该产品序号["+param2.get(0).toString()+"]做了综合判定,不能放行!");
  8965. }
  8966. }
  8967. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  8968. if(param2.get(5).toString().equals(list2.get(0).get("PHYFSTSID"))){
  8969. zra.setPhyfstsresult("1");
  8970. zra.setPhyfstsresult_desc("合格");
  8971. }
  8972. zra.setInspection_lot(list2.get(0).get("INSPECTION_LOT").toString());
  8973. zra.setPic_is_lock("2");
  8974. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  8975. if(qjsrt.size() > 0){
  8976. throw new Exception("该检验号下存在未判信息,不能放行!");
  8977. }
  8978. mapper.UpdateJugeResultJ(zra);
  8979. PhyUtmJudge(qjl.getDesign_key(),list2.get(0).get("INSPECTION_LOT").toString() , param2.get(4).toString());
  8980. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  8981. for(HashMap lists:list2){
  8982. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  8983. qjog.setOperate_name(param2.get(4).toString());
  8984. qjog.setOperate_type("材质放行通过");
  8985. qjog.setParams(lists.get("INSPECTION_LOT").toString());
  8986. qjog.setBatchno(qjl.getBatch_no());
  8987. qjog.setProd_line(qjl.getPline_code());
  8988. mapper.insertQcmJudgeOperateLog(qjog);
  8989. //质量异常材处置
  8990. qjl = new QCMJudgeLocking();
  8991. qjl.setUnlock_type_code("0");
  8992. qjl.setUnlock_type_desc("放行");
  8993. qjl.setPic_locking("2");
  8994. qjl.setStatus("2");
  8995. qjl.setBatch_no(qjls.get(0).getBatch_no());
  8996. qjl.setMaterial_no(lists.get("COIL_NO").toString());
  8997. qjl.setLock_id(param2.get(5).toString());
  8998. qjl.setLock_type_code(param2.get(2).toString());
  8999. qjl.setCheck_name(param2.get(4).toString());
  9000. mapper.UpdateQcmJudgeLocking3(qjl);
  9001. mapper.doApply(param2.get(7).toString(),param2.get(4).toString(),"1");
  9002. if(param2.get(0).toString().startsWith("R") || param2.get(0).toString().startsWith("L")){//240910
  9003. String sqlrl="select t.* from QCM_JUDGE_LOCKING_APPLY t where t.material_no = '"+param2.get(0).toString()+"' "
  9004. + " and t.lock_type_code = '"+param2.get(2).toString()+"' and t.STATUS = '0' and t.VALID_FLAG='1' ";
  9005. List<HashMap> listrl = mapper.query(sqlrl);
  9006. if(listrl != null && listrl.size() >=1){
  9007. for(HashMap li :listrl){
  9008. //更改是否有效
  9009. String UpSqlRL = " UPDATE QCM_JUDGE_LOCKING_APPLY T "
  9010. +" SET T.VALID_FLAG = '0' "
  9011. +" WHERE material_no = '"+li.get("MATERIAL_NO").toString()+"' "
  9012. +" and lock_type_code = '"+li.get("LOCK_TYPE_CODE").toString()+"' and STATUS = '0' and VALID_FLAG='1' ";
  9013. mapper.updateJudgeStatus(UpSqlRL.toString());
  9014. }
  9015. }
  9016. }
  9017. QcmJudgeLog qjlt = new QcmJudgeLog();
  9018. qjlt.setJudge_type("R");
  9019. qjlt.setMaterial_no(lists.get("INSPECTION_LOT").toString());
  9020. qjlt.setCreate_name("system");
  9021. qjlt.setMaterial_type("1");
  9022. qjlt.setProd_line(qjl.getPline_code());
  9023. mapper.insertQcmJudgeLog(qjlt);
  9024. }
  9025. sql = "select * from qcm_judge_coil_result where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and judgeresult = '0' ";
  9026. List<HashMap> listq1 = mapper.query(sql);
  9027. for(HashMap listq2 :listq1){
  9028. coiljudge_status_call(param2.get(6).toString(), listq2.get("COIL_NO").toString(), null, "1", null, null, null, null, null,"");
  9029. }
  9030. SqlSession.commit();
  9031. }else{
  9032. for(HashMap lists:list3){
  9033. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9034. throw new Exception("该产品序号["+param2.get(0).toString()+"]做了综合判定,不能放行!");
  9035. }
  9036. }
  9037. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  9038. if(param2.get(5).toString().equals(list3.get(0).get("PHYFSTSID"))){
  9039. zra.setPhyfstsresult("1");
  9040. zra.setPhyfstsresult_desc("合格");
  9041. }
  9042. zra.setInspection_lot(list3.get(0).get("INSPECTION_LOT").toString());
  9043. zra.setPic_is_lock("2");
  9044. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  9045. if(qjsrt.size() > 0){
  9046. throw new Exception("该检验号下存在未判信息,不能放行!");
  9047. }
  9048. mapper.UpdateJugeResultY(zra);
  9049. PhyUtmJudge(qjl.getDesign_key(),list3.get(0).get("INSPECTION_LOT").toString() , param2.get(4).toString());
  9050. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  9051. for(HashMap lists:list3){
  9052. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9053. qjog.setOperate_name(param2.get(4).toString());
  9054. qjog.setOperate_type("材质放行通过");
  9055. qjog.setParams(lists.get("INSPECTION_LOT").toString());
  9056. qjog.setBatchno(qjl.getBatch_no());
  9057. qjog.setProd_line(qjl.getPline_code());
  9058. mapper.insertQcmJudgeOperateLog(qjog);
  9059. //质量异常材处置
  9060. qjl = new QCMJudgeLocking();
  9061. qjl.setUnlock_type_code("0");
  9062. qjl.setUnlock_type_desc("放行");
  9063. qjl.setPic_locking("2");
  9064. qjl.setStatus("2");
  9065. qjl.setBatch_no(qjls.get(0).getBatch_no());
  9066. qjl.setMaterial_no(lists.get("COIL_NO").toString());
  9067. qjl.setUnlock_name(param2.get(4).toString());
  9068. qjl.setLock_id(param2.get(5).toString());
  9069. qjl.setLock_type_code(param2.get(2).toString());
  9070. qjl.setCheck_name(param2.get(4).toString());
  9071. mapper.UpdateQcmJudgeLocking3(qjl);
  9072. mapper.doApply(param2.get(7).toString(),param2.get(4).toString(),"1");
  9073. QcmJudgeLog qjlt = new QcmJudgeLog();
  9074. qjlt.setJudge_type("R");
  9075. qjlt.setMaterial_no(lists.get("INSPECTION_LOT").toString());
  9076. qjlt.setCreate_name("system");
  9077. qjlt.setMaterial_type("1");
  9078. qjlt.setProd_line(qjl.getPline_code());
  9079. mapper.insertQcmJudgeLog(qjlt);
  9080. }
  9081. SqlSession.commit();
  9082. }
  9083. }else{
  9084. throw new Exception("未找到库存信息!");
  9085. }
  9086. }
  9087. if(param2.get(2).toString().equals("C")){
  9088. qjl.setCic_locking("0");
  9089. if(param2.get(5).toString().contains("C")){
  9090. //更改合同试样表
  9091. List<QcmJhySampleROrd> qjst = mapper.queryQcmJhySampleROrd1("select * from qcm_jhy_sample_r_ord where cic_id = '"+param2.get(5).toString()+"'");
  9092. QcmJhySampleROrd qjsr = new QcmJhySampleROrd();
  9093. qjsr.setCic_id(param2.get(5).toString());
  9094. qjsr.setJudge_result_code("1");
  9095. qjsr.setJudge_result_desc("合格");
  9096. qjsr.setJudge_name(param2.get(4).toString());
  9097. qjsr.setJudge_time(new Date());
  9098. qjsr.setDesign_key(qjl.getDesign_key());
  9099. qjsr.setPsc(qjst.get(0).getPsc());
  9100. qjsr.setSmp_no(qjst.get(0).getSmp_no());
  9101. mapper.updateQcmJhySampleROrds(qjsr);
  9102. }
  9103. //更改合同与试样表
  9104. if(list1.size() >0 || list2.size() >0 || list3.size()>0){
  9105. if(list1.size()>0){
  9106. for(HashMap lists:list1){
  9107. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9108. throw new Exception("该产品序号["+param2.get(0).toString()+"]做了综合判定,不能放行!");
  9109. }
  9110. }
  9111. ZjResultAll zra = new ZjResultAll();
  9112. if(param2.get(5).toString().contains("C")){
  9113. zra.setBilletid_jy(list1.get(0).get("BILLETID_JY").toString());
  9114. zra.setCic_is_lock("2");
  9115. zra.setChemresult("1");
  9116. zra.setChemresult_desc("合格");
  9117. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list1.get(0).get("BILLETID_JY").toString()+"' and JUDGE_STATUS = '0'");
  9118. if(qjsrt.size() > 0){
  9119. throw new Exception("该检验号下存在未判信息,不能放行!");
  9120. }
  9121. mapper.UpdateJugeResultB(zra);
  9122. //PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  9123. //QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  9124. for(HashMap lists:list1){
  9125. //质量异常材处置
  9126. qjl = new QCMJudgeLocking();
  9127. qjl.setUnlock_type_code("0");
  9128. qjl.setUnlock_type_desc("放行");
  9129. qjl.setCic_locking("2");
  9130. qjl.setStatus("2");
  9131. qjl.setBatch_no(qjls.get(0).getBatch_no());
  9132. //qjl.setMaterial_no(lists.get("BILLETID").toString());
  9133. qjl.setUnlock_name(param2.get(4).toString());
  9134. qjl.setLock_id(param2.get(5).toString());
  9135. qjl.setLock_type_code(param2.get(2).toString());
  9136. qjl.setCheck_name(param2.get(4).toString());
  9137. mapper.UpdateQcmJudgeLocking3(qjl);
  9138. mapper.doApply(param2.get(7).toString(),param2.get(4).toString(),"1");
  9139. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9140. qjog.setOperate_name(param2.get(4).toString());
  9141. qjog.setOperate_type("成分放行");
  9142. qjog.setParams(param2.get(0).toString());
  9143. qjog.setBatchno(qjl.getBatch_no());
  9144. qjog.setProd_line(qjl.getPline_code());
  9145. mapper.insertQcmJudgeOperateLog(qjog);
  9146. QcmJudgeLog qjlt = new QcmJudgeLog();
  9147. qjlt.setJudge_type("R");
  9148. qjlt.setMaterial_no(lists.get("BILLETID_JY").toString());
  9149. qjlt.setCreate_name("system");
  9150. qjlt.setMaterial_type("1");
  9151. qjlt.setProd_line(qjl.getPline_code());
  9152. mapper.insertQcmJudgeLog(qjlt);
  9153. }
  9154. SqlSession.commit();
  9155. }else{
  9156. zra.setBilletid(param2.get(0).toString());
  9157. zra.setR_cic_is_lock("2");
  9158. zra.setR_chemresult("1");
  9159. zra.setR_chemresult_desc("合格");
  9160. mapper.UpdateJugeResultB(zra);
  9161. qjl.setUnlock_name(param2.get(4).toString());
  9162. qjl.setCheck_name(param2.get(4).toString());
  9163. qjl.setStatus("2");
  9164. mapper.UpdateQcmJudgeLocking(qjl);
  9165. mapper.doApply(param2.get(7).toString(),param2.get(4).toString(),"1");
  9166. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9167. qjog.setOperate_name(param2.get(4).toString());
  9168. qjog.setOperate_type("成分放行");
  9169. qjog.setParams(param2.get(0).toString());
  9170. qjog.setBatchno(qjl.getBatch_no());
  9171. qjog.setProd_line(qjl.getPline_code());
  9172. mapper.insertQcmJudgeOperateLog(qjog);
  9173. QcmJudgeLog qjlt = new QcmJudgeLog();
  9174. qjlt.setJudge_type("U");
  9175. qjlt.setMaterial_no(param2.get(0).toString());
  9176. qjlt.setCreate_name("system");
  9177. qjlt.setProd_line(qjl.getPline_code());
  9178. qjlt.setProd_line(qjl.getPline_code());
  9179. mapper.insertQcmJudgeLog(qjlt);
  9180. SqlSession.commit();
  9181. }
  9182. }else if(list2.size() >0){
  9183. for(HashMap lists:list2){
  9184. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9185. throw new Exception("该产品序号["+param2.get(0).toString()+"]做了综合判定,不能放行!");
  9186. }
  9187. }
  9188. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  9189. zra.setCoil_no(param2.get(0).toString());
  9190. if(param2.get(5).toString().contains("C")){
  9191. zra.setCic_is_lock("2");
  9192. zra.setChemresult("1");
  9193. zra.setChemresult_desc("合格");
  9194. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  9195. if(qjsrt.size() > 0){
  9196. throw new Exception("该检验号下存在未判信息,不能放行!");
  9197. }
  9198. mapper.UpdateJugeResultJ(zra);
  9199. //PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  9200. //QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  9201. for(HashMap lists:list2){
  9202. //质量异常材处置
  9203. qjl = new QCMJudgeLocking();
  9204. qjl.setUnlock_type_code("0");
  9205. qjl.setUnlock_type_desc("放行");
  9206. qjl.setCic_locking("2");
  9207. qjl.setStatus("2");
  9208. qjl.setBatch_no(qjls.get(0).getBatch_no());
  9209. //qjl.setMaterial_no(lists.get("BILLETID").toString());
  9210. qjl.setUnlock_name(param2.get(4).toString());
  9211. qjl.setLock_id(param2.get(5).toString());
  9212. qjl.setLock_type_code(param2.get(2).toString());
  9213. qjl.setCheck_name(param2.get(4).toString());
  9214. mapper.UpdateQcmJudgeLocking3(qjl);
  9215. mapper.doApply(param2.get(7).toString(),param2.get(4).toString(),"1");
  9216. if(param2.get(0).toString().startsWith("R") || param2.get(0).toString().startsWith("L")){//240910
  9217. String sqlrl="select t.* from QCM_JUDGE_LOCKING_APPLY t where t.material_no = '"+param2.get(0).toString()+"' "
  9218. + " and t.lock_type_code = '"+param2.get(2).toString()+"' and t.STATUS = '0' and t.VALID_FLAG='1' ";
  9219. List<HashMap> listrl = mapper.query(sqlrl);
  9220. if(listrl != null && listrl.size() >=1){
  9221. for(HashMap li :listrl){
  9222. //更改是否有效
  9223. String UpSqlRL = " UPDATE QCM_JUDGE_LOCKING_APPLY T "
  9224. +" SET T.VALID_FLAG = '0' "
  9225. +" WHERE material_no = '"+li.get("MATERIAL_NO").toString()+"' "
  9226. +" and lock_type_code = '"+li.get("LOCK_TYPE_CODE").toString()+"' and STATUS = '0' and VALID_FLAG='1' ";
  9227. mapper.updateJudgeStatus(UpSqlRL.toString());
  9228. }
  9229. }
  9230. }
  9231. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9232. qjog.setOperate_name(param2.get(4).toString());
  9233. qjog.setOperate_type("成分放行");
  9234. qjog.setParams(param2.get(0).toString());
  9235. qjog.setBatchno(qjl.getBatch_no());
  9236. qjog.setProd_line(qjl.getPline_code());
  9237. mapper.insertQcmJudgeOperateLog(qjog);
  9238. QcmJudgeLog qjlt = new QcmJudgeLog();
  9239. qjlt.setJudge_type("R");
  9240. qjlt.setMaterial_no(lists.get("INSPECTION_LOT").toString());
  9241. qjlt.setCreate_name("system");
  9242. qjlt.setMaterial_type("1");
  9243. qjlt.setProd_line(qjl.getPline_code());
  9244. mapper.insertQcmJudgeLog(qjlt);
  9245. }
  9246. SqlSession.commit();
  9247. }else{
  9248. zra.setR_cic_is_lock("2");
  9249. zra.setR_chemresult("1");
  9250. zra.setR_chemresult_desc("合格");
  9251. mapper.UpdateJugeResultJ(zra);
  9252. qjl.setUnlock_name(param2.get(4).toString());
  9253. qjl.setCheck_name(param2.get(4).toString());
  9254. qjl.setStatus("2");
  9255. mapper.UpdateQcmJudgeLocking(qjl);
  9256. mapper.doApply(param2.get(7).toString(),param2.get(4).toString(),"1");
  9257. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9258. qjog.setOperate_name(param2.get(4).toString());
  9259. qjog.setOperate_type("成分放行");
  9260. qjog.setParams(param2.get(0).toString());
  9261. qjog.setBatchno(qjl.getBatch_no());
  9262. qjog.setProd_line(qjl.getPline_code());
  9263. mapper.insertQcmJudgeOperateLog(qjog);
  9264. QcmJudgeLog qjlt = new QcmJudgeLog();
  9265. qjlt.setJudge_type("U");
  9266. qjlt.setMaterial_no(param2.get(0).toString());
  9267. qjlt.setCreate_name("system");
  9268. qjlt.setProd_line(qjl.getPline_code());
  9269. mapper.insertQcmJudgeLog(qjlt);
  9270. SqlSession.commit();
  9271. }
  9272. }else{
  9273. for(HashMap lists:list3){
  9274. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9275. throw new Exception("该产品序号["+param2.get(0).toString()+"]做了综合判定,不能放行!");
  9276. }
  9277. }
  9278. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  9279. zra.setCoil_no(param2.get(0).toString());
  9280. if(param2.get(5).toString().contains("C")){
  9281. zra.setCic_is_lock("2");
  9282. zra.setChemresult("1");
  9283. zra.setChemresult_desc("合格");
  9284. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  9285. if(qjsrt.size() > 0){
  9286. throw new Exception("该检验号下存在未判信息,不能放行!");
  9287. }
  9288. mapper.UpdateJugeResultY(zra);
  9289. //PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  9290. //QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  9291. for(HashMap lists:list2){
  9292. //质量异常材处置
  9293. qjl = new QCMJudgeLocking();
  9294. qjl.setUnlock_type_code("0");
  9295. qjl.setUnlock_type_desc("放行");
  9296. qjl.setCic_locking("2");
  9297. qjl.setStatus("2");
  9298. qjl.setBatch_no(qjls.get(0).getBatch_no());
  9299. //qjl.setMaterial_no(lists.get("BILLETID").toString());
  9300. qjl.setUnlock_name(param2.get(4).toString());
  9301. qjl.setLock_id(param2.get(5).toString());
  9302. qjl.setLock_type_code(param2.get(2).toString());
  9303. qjl.setCheck_name(param2.get(4).toString());
  9304. mapper.UpdateQcmJudgeLocking3(qjl);
  9305. mapper.doApply(param2.get(7).toString(),param2.get(4).toString(),"1");
  9306. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9307. qjog.setOperate_name(param2.get(4).toString());
  9308. qjog.setOperate_type("成分放行");
  9309. qjog.setParams(param2.get(0).toString());
  9310. qjog.setBatchno(qjl.getBatch_no());
  9311. qjog.setProd_line(qjl.getPline_code());
  9312. mapper.insertQcmJudgeOperateLog(qjog);
  9313. QcmJudgeLog qjlt = new QcmJudgeLog();
  9314. qjlt.setJudge_type("R");
  9315. qjlt.setMaterial_no(lists.get("INSPECTION_LOT").toString());
  9316. qjlt.setCreate_name("system");
  9317. qjlt.setMaterial_type("1");
  9318. qjlt.setProd_line(qjl.getPline_code());
  9319. mapper.insertQcmJudgeLog(qjlt);
  9320. }
  9321. SqlSession.commit();
  9322. }else{
  9323. zra.setR_cic_is_lock("2");
  9324. zra.setR_chemresult("1");
  9325. zra.setR_chemresult_desc("合格");
  9326. mapper.UpdateJugeResultY(zra);
  9327. qjl.setUnlock_name(param2.get(4).toString());
  9328. qjl.setCheck_name(param2.get(4).toString());
  9329. qjl.setStatus("2");
  9330. mapper.UpdateQcmJudgeLocking(qjl);
  9331. mapper.doApply(param2.get(7).toString(),param2.get(4).toString(),"1");
  9332. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9333. qjog.setOperate_name(param2.get(4).toString());
  9334. qjog.setOperate_type("成分放行");
  9335. qjog.setParams(param2.get(0).toString());
  9336. qjog.setBatchno(qjl.getBatch_no());
  9337. qjog.setProd_line(qjl.getPline_code());
  9338. mapper.insertQcmJudgeOperateLog(qjog);
  9339. QcmJudgeLog qjlt = new QcmJudgeLog();
  9340. qjlt.setJudge_type("U");
  9341. qjlt.setMaterial_no(param2.get(0).toString());
  9342. qjlt.setCreate_name("system");
  9343. qjlt.setProd_line(qjl.getPline_code());
  9344. mapper.insertQcmJudgeLog(qjlt);
  9345. SqlSession.commit();
  9346. }
  9347. }
  9348. }else{
  9349. throw new Exception("未找到库存信息!");
  9350. }
  9351. }
  9352. }
  9353. }catch(Exception e){
  9354. cro.setV_errCode(-1);
  9355. cro.setV_errMsg(e.getMessage());
  9356. SqlSession.rollback();
  9357. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.doApplyFx:【" + param2.toString() + "】" + e);
  9358. }
  9359. SqlSession.close();
  9360. return cro;
  9361. }
  9362. /**param1 改判除外的异常材处置 (成分、材质除外)
  9363. * 产品序号、锁定记录号、封锁来源、处置去向、处置去向说明、操作人,单项判定记录号
  9364. * @param param1
  9365. * @return
  9366. * @throws Exception
  9367. */
  9368. @SuppressWarnings("rawtypes")
  9369. public CoreReturnObject doInformationSureH(ArrayList param1) throws Exception{
  9370. try{
  9371. if(param1 == null || param1.size() <= 0){
  9372. throw new Exception("请传入参数!");
  9373. }
  9374. QcmJudgeSurfaceServiceImpl qjft = new QcmJudgeSurfaceServiceImpl();
  9375. String sql = "select * from qcm_judge_locking where material_no = '"+param1.get(0).toString()+"' and lock_seq = '"+param1.get(1).toString()+"' and unlock_type_code is null ";
  9376. List<QCMJudgeLocking> qjls = mapper.queryQCMJudgeLockings(sql);
  9377. if(qjls.size() == 0){
  9378. throw new Exception("该处置信息已被处置,未找到信息!");
  9379. }
  9380. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  9381. QCMJudgeLocking qjl = mapper.queryQCMJudgeLockings(sql).get(0);
  9382. qjl.setReason_code(param1.get(7).toString());
  9383. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  9384. if(listsu.size() >0)
  9385. {
  9386. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  9387. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  9388. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  9389. }
  9390. sql = "select * from zj_result_all@xgcx where BILLETID = '"+param1.get(0).toString()+"'";
  9391. List<HashMap> list1 = mapper.query(sql);
  9392. sql = "select * from QCM_JUDGE_COIL_RESULT where coil_no = '"+param1.get(0).toString()+"'";
  9393. List<HashMap> list2 = mapper.query(sql);
  9394. sql = "select * from QCM_JUDGE_YT_COIL_RESULT where coil_no = '"+param1.get(0).toString()+"'";
  9395. List<HashMap> list3 = mapper.query(sql);
  9396. //放行
  9397. if(param1.get(3).toString().equals("0")){
  9398. qjl.setUnlock_type_code("0");
  9399. qjl.setUnlock_type_desc("放行");
  9400. qjl.setUnlock_memo(param1.get(4).toString());
  9401. qjl.setUnlock_result(param1.get(8).toString());
  9402. //判断产线是不是卷板,是的话调用存储过程COILJUDGE_STATUS
  9403. if(list2.size() > 0) {
  9404. /*List<HashMap> hashmap2 = qjms.doQueryMaterialInfoJ(param1.get(0).toString());
  9405. if (hashmap2.size() > 0) {
  9406. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  9407. if(param1.get(2).toString().equals("C")){
  9408. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), "1", null, null, null, null, null, null,"");
  9409. } else if(param1.get(2).toString().equals("P")){
  9410. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), null, "1", null, null, null, null, null,"");
  9411. } else if(param1.get(2).toString().equals("S")){
  9412. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), null, null, "1", null, null, null, null,"");
  9413. } else if(param1.get(2).toString().equals("F")){
  9414. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), null, null, null, "1", null, null, null,"");
  9415. }
  9416. }*/
  9417. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  9418. if(param1.get(2).toString().equals("C")){
  9419. coiljudge_status_call(qjl.getPline_code().toString(), param1.get(0).toString(), "1", null, null, null, null, null, null,"");
  9420. } else if(param1.get(2).toString().equals("P")){
  9421. coiljudge_status_call(qjl.getPline_code().toString().toString(), param1.get(0).toString(), null, "1", null, null, null, null, null,"");
  9422. } else if(param1.get(2).toString().equals("S")){
  9423. coiljudge_status_call(qjl.getPline_code().toString().toString(), param1.get(0).toString(), null, null, "1", null, null, null, null,"");
  9424. } else if(param1.get(2).toString().equals("F")){
  9425. coiljudge_status_call(qjl.getPline_code().toString().toString(), param1.get(0).toString(), null, null, null, "1", null, null, null,"");
  9426. }
  9427. }
  9428. if(param1.get(2).toString().equals("S")){
  9429. qjl.setSic_locking("0");
  9430. //库存表放
  9431. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  9432. if(list1.size()>0){
  9433. for(HashMap lists:list1){
  9434. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9435. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  9436. }
  9437. }
  9438. ZjResultAll zra = new ZjResultAll();
  9439. zra.setBilletid(param1.get(0).toString());
  9440. zra.setSizeresult("1");
  9441. zra.setSizeresult_desc("合格");
  9442. zra.setSic_is_lock("2");
  9443. mapper.UpdateJugeResultB(zra);
  9444. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9445. qjog.setOperate_name(param1.get(5).toString());
  9446. qjog.setOperate_type("放行");
  9447. qjog.setParams(param1.get(0).toString());
  9448. qjog.setBatchno(qjl.getBatch_no());
  9449. qjog.setProd_line(qjl.getPline_code());
  9450. mapper.insertQcmJudgeOperateLog(qjog);
  9451. }else if(list2.size() >0){
  9452. for(HashMap lists:list2){
  9453. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9454. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  9455. }
  9456. }
  9457. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  9458. zra.setCoil_no(param1.get(0).toString());
  9459. zra.setSizeresult("1");
  9460. zra.setSizeresult_desc("合格");
  9461. zra.setSic_is_lock("2");
  9462. mapper.UpdateJugeResultJ(zra);
  9463. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9464. qjog.setOperate_name(param1.get(5).toString());
  9465. qjog.setOperate_type("放行");
  9466. qjog.setParams(param1.get(0).toString());
  9467. qjog.setBatchno(qjl.getBatch_no());
  9468. qjog.setProd_line(qjl.getPline_code());
  9469. mapper.insertQcmJudgeOperateLog(qjog);
  9470. }else{
  9471. for(HashMap lists:list3){
  9472. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9473. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  9474. }
  9475. }
  9476. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  9477. zra.setCoil_no(param1.get(0).toString());
  9478. zra.setSizeresult("1");
  9479. zra.setSizeresult_desc("合格");
  9480. zra.setSic_is_lock("2");
  9481. mapper.UpdateJugeResultY(zra);
  9482. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9483. qjog.setOperate_name(param1.get(5).toString());
  9484. qjog.setOperate_type("公差放行");
  9485. qjog.setParams(param1.get(0).toString());
  9486. qjog.setBatchno(qjl.getBatch_no());
  9487. qjog.setProd_line(qjl.getPline_code());
  9488. mapper.insertQcmJudgeOperateLog(qjog);
  9489. }
  9490. }else{
  9491. throw new Exception("未找到库存信息!");
  9492. }
  9493. qjl.setUnlock_name(param1.get(5).toString());
  9494. qjl.setMaterial_no(param1.get(0).toString());
  9495. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  9496. mapper.UpdateQcmJudgeLocking(qjl);
  9497. QcmJudgeLog qjlt = new QcmJudgeLog();
  9498. qjlt.setJudge_type("R");
  9499. qjlt.setMaterial_no(param1.get(0).toString());
  9500. qjlt.setCreate_name("system");
  9501. qjlt.setProd_line(qjl.getPline_code());
  9502. mapper.insertQcmJudgeLog(qjlt);
  9503. SqlSession.commit();
  9504. }
  9505. if(param1.get(2).toString().equals("D")){
  9506. qjl.setDic_locking("0");
  9507. //库存表放
  9508. if(list1.size() >0 || list2.size() >0){
  9509. if(list1.size()>0){
  9510. for(HashMap lists:list1){
  9511. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9512. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  9513. }
  9514. }
  9515. ZjResultAll zra = new ZjResultAll();
  9516. zra.setBilletid(param1.get(0).toString());
  9517. zra.setDic_is_lock("2");
  9518. zra.setSpyresult("1");
  9519. zra.setSpyresult_desc("合格");
  9520. mapper.UpdateJugeResultB(zra);
  9521. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9522. qjog.setOperate_name(param1.get(5).toString());
  9523. qjog.setOperate_type("放行");
  9524. qjog.setParams(param1.get(0).toString());
  9525. qjog.setBatchno(qjl.getBatch_no());
  9526. qjog.setProd_line(qjl.getPline_code());
  9527. mapper.insertQcmJudgeOperateLog(qjog);
  9528. }else{
  9529. for(HashMap lists:list2){
  9530. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9531. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  9532. }
  9533. }
  9534. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  9535. zra.setCoil_no(param1.get(0).toString());
  9536. zra.setDic_is_lock("2");
  9537. zra.setSpyresult("1");
  9538. zra.setSpyresult_desc("合格");
  9539. mapper.UpdateJugeResultJ(zra);
  9540. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9541. qjog.setOperate_name(param1.get(5).toString());
  9542. qjog.setOperate_type("放行");
  9543. qjog.setParams(param1.get(0).toString());
  9544. qjog.setBatchno(qjl.getBatch_no());
  9545. qjog.setProd_line(qjl.getPline_code());
  9546. mapper.insertQcmJudgeOperateLog(qjog);
  9547. }
  9548. }else{
  9549. throw new Exception("未找到库存信息!");
  9550. }
  9551. qjl.setUnlock_name(param1.get(5).toString());
  9552. qjl.setMaterial_no(param1.get(0).toString());
  9553. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  9554. mapper.UpdateQcmJudgeLocking(qjl);
  9555. QcmJudgeLog qjlt = new QcmJudgeLog();
  9556. qjlt.setJudge_type("U");
  9557. qjlt.setMaterial_no(param1.get(0).toString());
  9558. qjlt.setCreate_name("system");
  9559. qjlt.setProd_line(qjl.getPline_code());
  9560. mapper.insertQcmJudgeLog(qjlt);
  9561. SqlSession.commit();
  9562. }
  9563. //表面放行
  9564. if(param1.get(2).toString().equals("F")){
  9565. qjl.setFic_locking("0");
  9566. sql = "select * from qcm_judge_surface where material_no = '"+param1.get(0).toString()+"' order by JUDGE_TIME desc";
  9567. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  9568. QcmJudgeSurface qjsf = new QcmJudgeSurface();
  9569. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  9570. qjsf.setSfd_is_lock("2");
  9571. qjsf.setSfe_is_lock("2");
  9572. qjsf.setSfu_is_lock("2");
  9573. mapper.UpdateQcmJudgeSurface(qjsf);
  9574. //更新库存表放行
  9575. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  9576. if(list1.size()>0){
  9577. for(HashMap lists:list1){
  9578. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9579. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  9580. }
  9581. }
  9582. ZjResultAll zra = new ZjResultAll();
  9583. zra.setBilletid(param1.get(0).toString());
  9584. zra.setSurfaceresult("1");
  9585. zra.setSurfaceresult_desc("合格");
  9586. if(list1.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  9587. zra.setSfu_is_lock("2");
  9588. zra.setUp_surface_result("1");
  9589. zra.setUp_surface_result_desc("合格");
  9590. }
  9591. if(list1.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  9592. zra.setSfd_is_lock("2");
  9593. zra.setUd_surface_result("1");
  9594. zra.setUd_surface_result_desc("合格");
  9595. }
  9596. if(list1.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  9597. zra.setSfe_is_lock("2");
  9598. zra.setMarginal_result("1");
  9599. zra.setMarginal_result_id_desc("合格");
  9600. }
  9601. mapper.UpdateJugeResultB(zra);
  9602. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9603. qjog.setOperate_name(param1.get(5).toString());
  9604. qjog.setOperate_type("表面放行");
  9605. qjog.setParams(param1.get(0).toString());
  9606. qjog.setBatchno(qjl.getBatch_no());
  9607. qjog.setProd_line(qjl.getPline_code());
  9608. mapper.insertQcmJudgeOperateLog(qjog);
  9609. }else if(list2.size() >0){
  9610. for(HashMap lists:list2){
  9611. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9612. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  9613. }
  9614. }
  9615. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  9616. zra.setCoil_no(param1.get(0).toString());
  9617. zra.setSurfaceresult("1");
  9618. zra.setSurfaceresult_desc("合格");
  9619. zra.setSurfaceresult_desc("合格");
  9620. if(list2.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  9621. zra.setSfu_is_lock("2");
  9622. zra.setUp_surface_result("1");
  9623. zra.setUp_surface_result_desc("合格");
  9624. }
  9625. if(list2.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  9626. zra.setSfd_is_lock("2");
  9627. zra.setUd_surface_result("1");
  9628. zra.setUd_surface_result_desc("合格");
  9629. }
  9630. if(list2.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  9631. zra.setSfe_is_lock("2");
  9632. zra.setMarginal_result("1");
  9633. zra.setMarginal_result_id_desc("合格");
  9634. }
  9635. mapper.UpdateJugeResultJ(zra);
  9636. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9637. qjog.setOperate_name(param1.get(5).toString());
  9638. qjog.setOperate_type("表面放行");
  9639. qjog.setParams(param1.get(0).toString());
  9640. qjog.setBatchno(qjl.getBatch_no());
  9641. qjog.setProd_line(qjl.getPline_code());
  9642. mapper.insertQcmJudgeOperateLog(qjog);
  9643. }else{
  9644. for(HashMap lists:list3){
  9645. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9646. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  9647. }
  9648. }
  9649. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  9650. zra.setCoil_no(param1.get(0).toString());
  9651. zra.setSurfaceresult("1");
  9652. zra.setSurfaceresult_desc("合格");
  9653. zra.setSurfaceresult_desc("合格");
  9654. if(list3.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  9655. zra.setSfu_is_lock("2");
  9656. zra.setUp_surface_result("1");
  9657. zra.setUp_surface_result_desc("合格");
  9658. }
  9659. if(list3.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  9660. zra.setSfd_is_lock("2");
  9661. zra.setUd_surface_result("1");
  9662. zra.setUd_surface_result_desc("合格");
  9663. }
  9664. if(list3.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  9665. zra.setSfe_is_lock("2");
  9666. zra.setMarginal_result("1");
  9667. zra.setMarginal_result_id_desc("合格");
  9668. }
  9669. mapper.UpdateJugeResultY(zra);
  9670. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9671. qjog.setOperate_name(param1.get(5).toString());
  9672. qjog.setOperate_type("表面放行");
  9673. qjog.setParams(param1.get(0).toString());
  9674. qjog.setBatchno(qjl.getBatch_no());
  9675. qjog.setProd_line(qjl.getPline_code());
  9676. mapper.insertQcmJudgeOperateLog(qjog);
  9677. }
  9678. }else{
  9679. throw new Exception("未找到库存信息!");
  9680. }
  9681. qjl.setUnlock_name(param1.get(5).toString());
  9682. qjl.setMaterial_no(param1.get(0).toString());
  9683. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  9684. mapper.UpdateQcmJudgeLocking(qjl);
  9685. QcmJudgeLog qjlt = new QcmJudgeLog();
  9686. qjlt.setJudge_type("R");
  9687. qjlt.setMaterial_no(param1.get(0).toString());
  9688. qjlt.setCreate_name("system");
  9689. qjlt.setProd_line(qjl.getPline_code());
  9690. mapper.insertQcmJudgeLog(qjlt);
  9691. SqlSession.commit();
  9692. }
  9693. //工艺放行
  9694. if(param1.get(2).toString().equals("T")){
  9695. qjl.setTic_locking("0");
  9696. //更新库存表放行
  9697. if(list1.size() >0 || list2.size() >0){
  9698. if(list2.size()>0){
  9699. for(HashMap lists:list2){
  9700. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9701. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  9702. }
  9703. }
  9704. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  9705. zra.setCoil_no(param1.get(0).toString());
  9706. zra.setTic_result("1");
  9707. zra.setTic_result_desc("合格");
  9708. zra.setSurfaceresult_desc("合格");
  9709. zra.setTic_is_lock("2");
  9710. mapper.UpdateJugeResultJ(zra);
  9711. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9712. qjog.setOperate_name(param1.get(5).toString());
  9713. qjog.setOperate_type("工艺放行");
  9714. qjog.setParams(param1.get(0).toString());
  9715. qjog.setBatchno(qjl.getBatch_no());
  9716. qjog.setProd_line(qjl.getPline_code());
  9717. mapper.insertQcmJudgeOperateLog(qjog);
  9718. }
  9719. }else{
  9720. throw new Exception("未找到库存信息!");
  9721. }
  9722. qjl.setUnlock_name(param1.get(5).toString());
  9723. qjl.setMaterial_no(param1.get(0).toString());
  9724. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  9725. mapper.UpdateQcmJudgeLocking(qjl);
  9726. QcmJudgeLog qjlt = new QcmJudgeLog();
  9727. qjlt.setJudge_type("U");
  9728. qjlt.setMaterial_no(param1.get(0).toString());
  9729. qjlt.setCreate_name("system");
  9730. qjlt.setProd_line(qjl.getPline_code());
  9731. mapper.insertQcmJudgeLog(qjlt);
  9732. SqlSession.commit();
  9733. }
  9734. }
  9735. //修磨
  9736. if(param1.get(3).toString().equals("2")){
  9737. if(!param1.get(2).toString().equals("F")){
  9738. throw new Exception("封锁来源与所选的异常材处置操作不一致,请重新选择处置操作!");
  9739. }
  9740. qjl.setUnlock_type_code("2");
  9741. qjl.setUnlock_type_desc("修磨");
  9742. qjl.setUnlock_memo(param1.get(4).toString());
  9743. qjl.setUnlock_result(param1.get(8).toString());
  9744. qjl.setFic_locking("0");
  9745. qjl.setUnlock_name(param1.get(5).toString());
  9746. qjl.setMaterial_no(param1.get(0).toString());
  9747. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  9748. //质量锁定解锁
  9749. mapper.UpdateQcmJudgeLocking(qjl);
  9750. sql = "select * from qcm_judge_surface where material_no = '"+param1.get(0).toString()+"' order by JUDGE_TIME desc";
  9751. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  9752. QcmJudgeSurface qjsf = new QcmJudgeSurface();
  9753. qjsf.setSfd_is_lock("0");
  9754. qjsf.setSfe_is_lock("0");
  9755. qjsf.setSfu_is_lock("0");
  9756. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  9757. //表面锁定解锁
  9758. mapper.UpdateQcmJudgeSurface(qjsf);
  9759. //库存解锁
  9760. if(list1.size() >0 || list2.size() >0){
  9761. if(list1.size()>0){
  9762. for(HashMap lists:list1){
  9763. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9764. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能修磨!");
  9765. }
  9766. }
  9767. ZjResultAll zra = new ZjResultAll();
  9768. zra.setBilletid(param1.get(0).toString());
  9769. zra.setSurfaceresult("0");
  9770. zra.setSurfaceresult_desc("待判");
  9771. zra.setSfd_is_lock("0");
  9772. zra.setSfe_is_lock("0");
  9773. zra.setSfu_is_lock("0");
  9774. mapper.UpdateJugeResultB(zra);
  9775. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9776. qjog.setOperate_name(param1.get(5).toString());
  9777. qjog.setOperate_type("修磨");
  9778. qjog.setParams(param1.get(0).toString());
  9779. qjog.setBatchno(qjl.getBatch_no());
  9780. qjog.setProd_line(qjl.getPline_code());
  9781. mapper.insertQcmJudgeOperateLog(qjog);
  9782. SqlSession.commit();
  9783. }else{
  9784. for(HashMap lists:list2){
  9785. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9786. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能修磨!");
  9787. }
  9788. }
  9789. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  9790. zra.setCoil_no(param1.get(0).toString());
  9791. zra.setSurfaceresult("0");
  9792. zra.setSurfaceresult_desc("待判");
  9793. zra.setSfd_is_lock("0");
  9794. zra.setSfe_is_lock("0");
  9795. zra.setSfu_is_lock("0");
  9796. mapper.UpdateJugeResultJ(zra);
  9797. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9798. qjog.setOperate_name(param1.get(5).toString());
  9799. qjog.setOperate_type("修磨");
  9800. qjog.setParams(param1.get(0).toString());
  9801. qjog.setBatchno(qjl.getBatch_no());
  9802. qjog.setProd_line(qjl.getPline_code());
  9803. mapper.insertQcmJudgeOperateLog(qjog);
  9804. SqlSession.commit();
  9805. }
  9806. }else{
  9807. throw new Exception("未找到库存信息!");
  9808. }
  9809. }
  9810. //改尺
  9811. if(param1.get(3).toString().equals("3")){
  9812. if(!param1.get(2).toString().equals("S")){
  9813. throw new Exception("封锁来源与所选的异常材处置操作不一致,请重新选择处置操作!");
  9814. }
  9815. //更改质量异常锁定表
  9816. qjl.setUnlock_type_code("3");
  9817. qjl.setUnlock_type_desc("改尺");
  9818. qjl.setUnlock_memo(param1.get(4).toString());
  9819. qjl.setUnlock_result(param1.get(8).toString());
  9820. qjl.setSic_locking("0");
  9821. qjl.setUnlock_name(param1.get(5).toString());
  9822. qjl.setMaterial_no(param1.get(0).toString());
  9823. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  9824. mapper.UpdateQcmJudgeLocking(qjl);
  9825. //库存解锁
  9826. if(list1.size() >0 || list2.size() >0){
  9827. if(list1.size()>0){
  9828. for(HashMap lists:list1){
  9829. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9830. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能改尺!");
  9831. }
  9832. }
  9833. //脱单
  9834. ZjResultAll zra = new ZjResultAll();
  9835. zra.setBilletid(param1.get(0).toString());
  9836. zra.setSizeresult("0");
  9837. zra.setSizeresult_desc("待判");
  9838. zra.setSic_is_lock("0");
  9839. mapper.UpdateJugeResultB(zra);
  9840. order_down(param1.get(0).toString(),"改尺");
  9841. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9842. qjog.setOperate_name(param1.get(5).toString());
  9843. qjog.setOperate_type("改尺");
  9844. qjog.setParams(param1.get(0).toString());
  9845. qjog.setBatchno(qjl.getBatch_no());
  9846. qjog.setProd_line(qjl.getPline_code());
  9847. mapper.insertQcmJudgeOperateLog(qjog);
  9848. SqlSession.commit();
  9849. }else{
  9850. for(HashMap lists:list2){
  9851. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9852. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能改尺!");
  9853. }
  9854. }
  9855. //脱单
  9856. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  9857. zra.setCoil_no(param1.get(0).toString());
  9858. zra.setSizeresult("0");
  9859. zra.setSizeresult_desc("待判");
  9860. zra.setSic_is_lock("0");
  9861. mapper.UpdateJugeResultJ(zra);
  9862. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9863. qjog.setOperate_name(param1.get(5).toString());
  9864. qjog.setOperate_type("改尺");
  9865. qjog.setParams(param1.get(0).toString());
  9866. qjog.setBatchno(qjl.getBatch_no());
  9867. qjog.setProd_line(qjl.getPline_code());
  9868. mapper.insertQcmJudgeOperateLog(qjog);
  9869. SqlSession.commit();
  9870. }
  9871. }else{
  9872. throw new Exception("未找到库存信息!");
  9873. }
  9874. }
  9875. //判次
  9876. if(param1.get(3).toString().equals("4")){
  9877. qjl.setUnlock_type_code("4");
  9878. qjl.setUnlock_type_desc("判次");
  9879. qjl.setUnlock_memo(param1.get(4).toString());
  9880. qjl.setUnlock_result(param1.get(8).toString());
  9881. qjl.setUnlock_name(param1.get(5).toString());
  9882. //判断产线是不是卷板,是的话调用存储过程COILJUDGE_STATUS
  9883. if(list2.size() > 0) {
  9884. //List<HashMap> hashmap2 = qjms.doQueryMaterialInfoJ(param1.get(0).toString());
  9885. /*if (hashmap2.size() > 0) {
  9886. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  9887. if(param1.get(2).toString().equals("C")){
  9888. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), "3", null, null, null, "3", null, null,"");
  9889. } else if(param1.get(2).toString().equals("P")){
  9890. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), null, "3", null, null, "3", null, null,"");
  9891. } else if(param1.get(2).toString().equals("S")){
  9892. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), null, null, "3", null, "3", null, null,"");
  9893. } else if(param1.get(2).toString().equals("F")){
  9894. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), null, null, null, "3", "3", null, null,"");
  9895. }
  9896. }*/
  9897. if(param1.get(2).toString().equals("C")){
  9898. coiljudge_status_call(qjl.getPline_code().toString(), param1.get(0).toString(), "1", null, null, null, null, null, null,"");
  9899. } else if(param1.get(2).toString().equals("P")){
  9900. coiljudge_status_call(qjl.getPline_code().toString().toString(), param1.get(0).toString(), null, "1", null, null, null, null, null,"");
  9901. } else if(param1.get(2).toString().equals("S")){
  9902. coiljudge_status_call(qjl.getPline_code().toString().toString(), param1.get(0).toString(), null, null, "1", null, null, null, null,"");
  9903. } else if(param1.get(2).toString().equals("F")){
  9904. coiljudge_status_call(qjl.getPline_code().toString().toString(), param1.get(0).toString(), null, null, null, "1", null, null, null,"");
  9905. }
  9906. }
  9907. if(param1.get(2).toString().equals("S")){
  9908. qjl.setSic_locking("0");
  9909. qjl.setMaterial_no(param1.get(0).toString());
  9910. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  9911. mapper.UpdateQcmJudgeLocking(qjl);
  9912. //库存表放
  9913. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  9914. if(list1.size()>0){
  9915. for(HashMap lists:list1){
  9916. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9917. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判次!");
  9918. }
  9919. }
  9920. ZjResultAll zra = new ZjResultAll();
  9921. zra.setBilletid(param1.get(0).toString());
  9922. zra.setSizeresult("3");
  9923. zra.setSizeresult_desc("判次");
  9924. zra.setSic_is_lock("0");
  9925. mapper.UpdateJugeResultB(zra);
  9926. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"3");
  9927. //脱单
  9928. order_down(param1.get(0).toString(),"判次");
  9929. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9930. qjog.setOperate_name(param1.get(5).toString());
  9931. qjog.setOperate_type("判次");
  9932. qjog.setParams(param1.get(0).toString());
  9933. qjog.setBatchno(qjl.getBatch_no());
  9934. qjog.setProd_line(qjl.getPline_code());
  9935. mapper.insertQcmJudgeOperateLog(qjog);
  9936. SqlSession.commit();
  9937. }else if(list2.size() >0){
  9938. for(HashMap lists:list2){
  9939. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9940. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判次!");
  9941. }
  9942. }
  9943. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  9944. zra.setCoil_no(param1.get(0).toString());
  9945. zra.setSizeresult("3");
  9946. zra.setSizeresult_desc("判次");
  9947. zra.setSic_is_lock("0");
  9948. mapper.UpdateJugeResultJ(zra);
  9949. //脱单
  9950. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9951. qjog.setOperate_name(param1.get(5).toString());
  9952. qjog.setOperate_type("判次");
  9953. qjog.setParams(param1.get(0).toString());
  9954. qjog.setBatchno(qjl.getBatch_no());
  9955. qjog.setProd_line(qjl.getPline_code());
  9956. mapper.insertQcmJudgeOperateLog(qjog);
  9957. SqlSession.commit();
  9958. }else{
  9959. for(HashMap lists:list3){
  9960. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9961. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  9962. }
  9963. }
  9964. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  9965. zra.setSizeresult("3");
  9966. zra.setSizeresult_desc("判次");
  9967. zra.setCoil_no(param1.get(0).toString());
  9968. //zra.setInspection_lot(list2.get(0).get("INSPECTION_LOT").toString());
  9969. zra.setSic_is_lock("0");
  9970. mapper.UpdateJugeResultY(zra);
  9971. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  9972. qjog.setOperate_name(param1.get(5).toString());
  9973. qjog.setOperate_type("判次");
  9974. qjog.setParams(param1.get(0).toString());
  9975. qjog.setBatchno(qjls.get(0).getBatch_no());
  9976. qjog.setProd_line(qjl.getPline_code());
  9977. mapper.insertQcmJudgeOperateLog(qjog);
  9978. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"3");
  9979. SqlSession.commit();
  9980. }
  9981. }else{
  9982. throw new Exception("未找到库存信息!");
  9983. }
  9984. }
  9985. if(param1.get(2).toString().equals("D")){
  9986. qjl.setDic_locking("0");
  9987. qjl.setMaterial_no(param1.get(0).toString());
  9988. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  9989. mapper.UpdateQcmJudgeLocking(qjl);
  9990. //库存表放
  9991. if(list1.size() >0 || list2.size() >0){
  9992. if(list1.size()>0){
  9993. for(HashMap lists:list1){
  9994. if(!lists.get("JUDGERESULT").toString().equals("0")){
  9995. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判次!");
  9996. }
  9997. }
  9998. ZjResultAll zra = new ZjResultAll();
  9999. zra.setBilletid(param1.get(0).toString());
  10000. zra.setSpyresult("3");
  10001. zra.setSpyresult_desc("判次");
  10002. zra.setDic_is_lock("0");
  10003. mapper.UpdateJugeResultB(zra);
  10004. //
  10005. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"3");
  10006. //脱单
  10007. order_down(param1.get(0).toString(),"判次");
  10008. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10009. qjog.setOperate_name(param1.get(5).toString());
  10010. qjog.setOperate_type("判次");
  10011. qjog.setParams(param1.get(0).toString());
  10012. qjog.setBatchno(qjl.getBatch_no());
  10013. qjog.setProd_line(qjl.getPline_code());
  10014. mapper.insertQcmJudgeOperateLog(qjog);
  10015. SqlSession.commit();
  10016. }else{
  10017. for(HashMap lists:list2){
  10018. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10019. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判次!");
  10020. }
  10021. }
  10022. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  10023. zra.setCoil_no(param1.get(0).toString());
  10024. zra.setSpyresult("3");
  10025. zra.setSpyresult_desc("判次");
  10026. zra.setDic_is_lock("0");
  10027. mapper.UpdateJugeResultJ(zra);
  10028. //脱单
  10029. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10030. qjog.setOperate_name(param1.get(5).toString());
  10031. qjog.setOperate_type("判次");
  10032. qjog.setParams(param1.get(0).toString());
  10033. qjog.setBatchno(qjl.getBatch_no());
  10034. qjog.setProd_line(qjl.getPline_code());
  10035. mapper.insertQcmJudgeOperateLog(qjog);
  10036. SqlSession.commit();
  10037. }
  10038. }else{
  10039. throw new Exception("未找到库存信息!");
  10040. }
  10041. }
  10042. if(param1.get(2).toString().equals("F")){
  10043. List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(param1.get(0).toString());
  10044. if(hashmap.size() == 0){
  10045. hashmap = qjms.doQueryMaterialInfoJ(param1.get(0).toString());
  10046. }
  10047. if(hashmap.size()==0){
  10048. hashmap = mapper.doQueryMaterialInfoY(param1.get(0).toString());
  10049. }
  10050. qjl.setFic_locking("0");
  10051. qjl.setMaterial_no(param1.get(0).toString());
  10052. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  10053. mapper.UpdateQcmJudgeLocking(qjl);
  10054. sql = "select * from qcm_judge_surface where material_no = '"+param1.get(0).toString()+"' and surface_id = '"+param1.get(6).toString()+"' order by JUDGE_TIME desc";
  10055. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  10056. QcmJudgeSurface qjsf = new QcmJudgeSurface();
  10057. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  10058. qjsf.setSfd_is_lock("0");
  10059. qjsf.setSfe_is_lock("0");
  10060. qjsf.setSfu_is_lock("0");
  10061. mapper.UpdateQcmJudgeSurface(qjsf);
  10062. //修改库存锁定
  10063. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  10064. if(list1.size()>0){
  10065. for(HashMap lists:list1){
  10066. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10067. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判次!");
  10068. }
  10069. }
  10070. ZjResultAll zra = new ZjResultAll();
  10071. zra.setBilletid(param1.get(0).toString());
  10072. zra.setSurfaceresult("3");
  10073. zra.setSurfaceresult_desc("判次");
  10074. if(list1.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  10075. zra.setSfu_is_lock("0");
  10076. zra.setUp_surface_result("3");
  10077. zra.setUp_surface_result_desc("判次");
  10078. }
  10079. if(list1.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  10080. zra.setSfd_is_lock("0");
  10081. zra.setUd_surface_result("3");
  10082. zra.setUd_surface_result_desc("判次");
  10083. }
  10084. if(list1.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  10085. zra.setSfe_is_lock("0");
  10086. zra.setMarginal_result("3");
  10087. zra.setMarginal_result_id_desc("判次");
  10088. }
  10089. mapper.UpdateJugeResultB(zra);
  10090. //表面信息发送到MES
  10091. if(param1.get(0).toString().startsWith("H") || param1.get(0).toString().startsWith("Z")){
  10092. String aJudgeType = "次品";
  10093. String aGZLB = "";
  10094. String aGYLB = "";
  10095. String aXGLB = "";
  10096. List<QcmJudgeSurfaceFlaw> qjf1 = mapper.queryQcmJudgeSurfaceFlaw("select * from qcm_judge_surface_flaw where surface_id = '"+param1.get(6).toString()+"' and flaw_seq = '1'");
  10097. if(qjf1.size() >0){
  10098. if(qjf1.get(0).getIs_repair().equals("0") || qjf1.get(0).getIs_repair().equals("未修复")){
  10099. aXGLB = "402301";
  10100. }else{
  10101. aXGLB = "402303";
  10102. }
  10103. List<HashMap> listgzl = mapper.query("select * from qcm_base_defect a where a.defect_code = '"+qjf1.get(0).getFlaw_code()+"'");
  10104. if(listgzl.size() > 0){
  10105. if(listgzl.get(0).get("DEFECT_TYPE_CODE").equals("S")){
  10106. List<HashMap> listgz = mapper.query("select * from scm_base_info a where a.sort_code = '4124' and memo like '%钢质%' and name_ = '"+qjf1.get(0).getFlaw_desc()+"'");
  10107. if(listgz.size() > 0){
  10108. aGZLB = listgz.get(0).get("ID_").toString();
  10109. }else{
  10110. aGZLB = qjf1.get(0).getFlaw_desc();
  10111. }
  10112. }else{
  10113. List<HashMap> listgy = mapper.query("select * from scm_base_info a where a.sort_code = '4124' and memo like '%工艺%' and name_ = '"+qjf1.get(0).getFlaw_desc()+"'");
  10114. if(listgy.size() > 0){
  10115. aGYLB = listgy.get(0).get("ID_").toString();
  10116. }else{
  10117. aGYLB = qjf1.get(0).getFlaw_desc();
  10118. }
  10119. }
  10120. }
  10121. }
  10122. bmjy(qjf.get(0).getSf_type().equals("U") ? "S" : "X"+param1.get(6).toString(),param1.get(0).toString(),aJudgeType, aGZLB, aGYLB, aXGLB,hashmap.get(0).get("STEEL_NAME")==null?"":hashmap.get(0).get("STEEL_NAME").toString(), hashmap.get(0).get("PROD_NAME")==null?"":hashmap.get(0).get("PROD_NAME").toString() , hashmap.get(0).get("STD_NAME")==null?"":hashmap.get(0).get("STD_NAME").toString(), param1.get(5).toString() , "", "", param1.get(4).toString(), "");
  10123. }
  10124. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"3");
  10125. //脱单
  10126. order_down(param1.get(0).toString(),"判次");
  10127. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10128. qjog.setOperate_name(param1.get(5).toString());
  10129. qjog.setOperate_type("判次");
  10130. qjog.setParams(param1.get(0).toString());
  10131. qjog.setBatchno(qjl.getBatch_no());
  10132. qjog.setProd_line(qjl.getPline_code());
  10133. mapper.insertQcmJudgeOperateLog(qjog);
  10134. SqlSession.commit();
  10135. }else if(list2.size() >0){
  10136. for(HashMap lists:list2){
  10137. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10138. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判次!");
  10139. }
  10140. }
  10141. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  10142. zra.setCoil_no(param1.get(0).toString());
  10143. zra.setSurfaceresult("3");
  10144. zra.setSurfaceresult_desc("判次");
  10145. if(list2.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  10146. zra.setSfu_is_lock("0");
  10147. zra.setUp_surface_result("3");
  10148. zra.setUp_surface_result_desc("判次");
  10149. }
  10150. if(list2.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  10151. zra.setSfd_is_lock("0");
  10152. zra.setUd_surface_result("3");
  10153. zra.setUd_surface_result_desc("判次");
  10154. }
  10155. if(list2.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  10156. zra.setSfe_is_lock("0");
  10157. zra.setMarginal_result("3");
  10158. zra.setMarginal_result_id_desc("判次");
  10159. }
  10160. mapper.UpdateJugeResultJ(zra);
  10161. //脱单
  10162. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10163. qjog.setOperate_name(param1.get(5).toString());
  10164. qjog.setOperate_type("判次");
  10165. qjog.setParams(param1.get(0).toString());
  10166. qjog.setBatchno(qjl.getBatch_no());
  10167. qjog.setProd_line(qjl.getPline_code());
  10168. mapper.insertQcmJudgeOperateLog(qjog);
  10169. SqlSession.commit();
  10170. }else{
  10171. for(HashMap lists:list3){
  10172. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10173. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  10174. }
  10175. }
  10176. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  10177. zra.setCoil_no(param1.get(0).toString());
  10178. zra.setSurfaceresult("3");
  10179. zra.setSurfaceresult_desc("判次");
  10180. if(list3.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  10181. zra.setSfu_is_lock("0");
  10182. zra.setUp_surface_result("3");
  10183. zra.setUp_surface_result_desc("判次");
  10184. }
  10185. if(list3.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  10186. zra.setSfd_is_lock("0");
  10187. zra.setUd_surface_result("3");
  10188. zra.setUd_surface_result_desc("判次");
  10189. }
  10190. if(list3.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  10191. zra.setSfe_is_lock("0");
  10192. zra.setMarginal_result("3");
  10193. zra.setMarginal_result_id_desc("判次");
  10194. }
  10195. //zra.setInspection_lot(list2.get(0).get("INSPECTION_LOT").toString());
  10196. zra.setSic_is_lock("0");
  10197. mapper.UpdateJugeResultY(zra);
  10198. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10199. qjog.setOperate_name(param1.get(5).toString());
  10200. qjog.setOperate_type("判次");
  10201. qjog.setParams(param1.get(0).toString());
  10202. qjog.setBatchno(qjls.get(0).getBatch_no());
  10203. qjog.setProd_line(qjl.getPline_code());
  10204. mapper.insertQcmJudgeOperateLog(qjog);
  10205. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"3");
  10206. SqlSession.commit();
  10207. }
  10208. }else{
  10209. throw new Exception("未找到库存信息!");
  10210. }
  10211. }
  10212. }
  10213. //判废
  10214. if(param1.get(3).toString().equals("5")){
  10215. qjl.setUnlock_type_code("5");
  10216. qjl.setUnlock_type_desc("判废");
  10217. qjl.setUnlock_memo(param1.get(4).toString());
  10218. qjl.setUnlock_result(param1.get(8).toString());
  10219. qjl.setUnlock_name(param1.get(5).toString());
  10220. //判断产线是不是卷板,是的话调用存储过程COILJUDGE_STATUS
  10221. if(list2.size() > 0) {
  10222. /*List<HashMap> hashmap2 = qjms.doQueryMaterialInfoJ(param1.get(0).toString());
  10223. if (hashmap2.size() > 0) {
  10224. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  10225. if(param1.get(2).toString().equals("C")){
  10226. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), "4", null, null, null, "4", null, null,"");
  10227. } else if(param1.get(2).toString().equals("P")){
  10228. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), null, "4", null, null, "4", null, null,"");
  10229. } else if(param1.get(2).toString().equals("S")){
  10230. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), null, null, "4", null, "4", null, null,"");
  10231. } else if(param1.get(2).toString().equals("F")){
  10232. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), null, null, null, "4", "4", null, null,"");
  10233. }
  10234. }*/
  10235. if(param1.get(2).toString().equals("C")){
  10236. coiljudge_status_call(qjl.getPline_code().toString(), param1.get(0).toString(), "1", null, null, null, null, null, null,"");
  10237. } else if(param1.get(2).toString().equals("P")){
  10238. coiljudge_status_call(qjl.getPline_code().toString().toString(), param1.get(0).toString(), null, "1", null, null, null, null, null,"");
  10239. } else if(param1.get(2).toString().equals("S")){
  10240. coiljudge_status_call(qjl.getPline_code().toString().toString(), param1.get(0).toString(), null, null, "1", null, null, null, null,"");
  10241. } else if(param1.get(2).toString().equals("F")){
  10242. coiljudge_status_call(qjl.getPline_code().toString().toString(), param1.get(0).toString(), null, null, null, "1", null, null, null,"");
  10243. }
  10244. }
  10245. if(param1.get(2).toString().equals("S")){
  10246. qjl.setSic_locking("0");
  10247. qjl.setMaterial_no(param1.get(0).toString());
  10248. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  10249. mapper.UpdateQcmJudgeLocking(qjl);
  10250. //库存表放
  10251. if(list1.size() >0 || list2.size() >0 || list3.size()>0){
  10252. if(list1.size()>0){
  10253. for(HashMap lists:list1){
  10254. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10255. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判废!");
  10256. }
  10257. }
  10258. ZjResultAll zra = new ZjResultAll();
  10259. zra.setBilletid(param1.get(0).toString());
  10260. zra.setSizeresult("4");
  10261. zra.setSizeresult_desc("判废");
  10262. zra.setSic_is_lock("0");
  10263. mapper.UpdateJugeResultB(zra);
  10264. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"4");
  10265. //脱单
  10266. order_down(param1.get(0).toString(),"判废");
  10267. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10268. qjog.setOperate_name(param1.get(5).toString());
  10269. qjog.setOperate_type("判废");
  10270. qjog.setParams(param1.get(0).toString());
  10271. qjog.setBatchno(qjl.getBatch_no());
  10272. qjog.setProd_line(qjl.getPline_code());
  10273. mapper.insertQcmJudgeOperateLog(qjog);
  10274. SqlSession.commit();
  10275. }else if(list2.size()>0){
  10276. for(HashMap lists:list2){
  10277. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10278. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判废!");
  10279. }
  10280. }
  10281. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  10282. zra.setCoil_no(param1.get(0).toString());
  10283. zra.setSizeresult("4");
  10284. zra.setSizeresult_desc("判废");
  10285. zra.setSic_is_lock("0");
  10286. mapper.UpdateJugeResultJ(zra);
  10287. //脱单
  10288. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10289. qjog.setOperate_name(param1.get(5).toString());
  10290. qjog.setOperate_type("判废");
  10291. qjog.setParams(param1.get(0).toString());
  10292. qjog.setBatchno(qjl.getBatch_no());
  10293. qjog.setProd_line(qjl.getPline_code());
  10294. mapper.insertQcmJudgeOperateLog(qjog);
  10295. SqlSession.commit();
  10296. }else{
  10297. for(HashMap lists:list3){
  10298. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10299. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  10300. }
  10301. }
  10302. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  10303. zra.setSizeresult("4");
  10304. zra.setSizeresult_desc("判废");
  10305. zra.setCoil_no(param1.get(0).toString());
  10306. //zra.setInspection_lot(list2.get(0).get("INSPECTION_LOT").toString());
  10307. zra.setSic_is_lock("0");
  10308. mapper.UpdateJugeResultY(zra);
  10309. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10310. qjog.setOperate_name(param1.get(5).toString());
  10311. qjog.setOperate_type("判废");
  10312. qjog.setParams(param1.get(0).toString());
  10313. qjog.setBatchno(qjls.get(0).getBatch_no());
  10314. qjog.setProd_line(qjl.getPline_code());
  10315. mapper.insertQcmJudgeOperateLog(qjog);
  10316. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"4");
  10317. SqlSession.commit();
  10318. }
  10319. }else{
  10320. throw new Exception("未找到库存信息!");
  10321. }
  10322. }
  10323. if(param1.get(2).toString().equals("D")){
  10324. qjl.setDic_locking("0");
  10325. qjl.setMaterial_no(param1.get(0).toString());
  10326. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  10327. mapper.UpdateQcmJudgeLocking(qjl);
  10328. //库存表放
  10329. if(list1.size() >0 || list2.size() >0){
  10330. if(list1.size()>0){
  10331. for(HashMap lists:list1){
  10332. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10333. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判废!");
  10334. }
  10335. }
  10336. ZjResultAll zra = new ZjResultAll();
  10337. zra.setBilletid(param1.get(0).toString());
  10338. zra.setSpyresult("4");
  10339. zra.setSpyresult_desc("判废");
  10340. zra.setDic_is_lock("0");
  10341. mapper.UpdateJugeResultB(zra);
  10342. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"4");
  10343. //脱单
  10344. order_down(param1.get(0).toString(),"判废");
  10345. SqlSession.commit();
  10346. }else{
  10347. for(HashMap lists:list2){
  10348. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10349. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判废!");
  10350. }
  10351. }
  10352. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  10353. zra.setCoil_no(param1.get(0).toString());
  10354. zra.setSpyresult("4");
  10355. zra.setSpyresult_desc("判废");
  10356. zra.setDic_is_lock("0");
  10357. mapper.UpdateJugeResultJ(zra);
  10358. //脱单
  10359. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10360. qjog.setOperate_name(param1.get(5).toString());
  10361. qjog.setOperate_type("判废");
  10362. qjog.setParams(param1.get(0).toString());
  10363. qjog.setBatchno(qjl.getBatch_no());
  10364. qjog.setProd_line(qjl.getPline_code());
  10365. mapper.insertQcmJudgeOperateLog(qjog);
  10366. SqlSession.commit();
  10367. }
  10368. }else{
  10369. throw new Exception("未找到库存信息!");
  10370. }
  10371. }
  10372. if(param1.get(2).toString().equals("F")){
  10373. List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(param1.get(0).toString());
  10374. if(hashmap.size() == 0){
  10375. hashmap = qjms.doQueryMaterialInfoJ(param1.get(0).toString());
  10376. }
  10377. if(hashmap.size()==0){
  10378. hashmap = mapper.doQueryMaterialInfoY(param1.get(0).toString());
  10379. }
  10380. qjl.setFic_locking("0");
  10381. qjl.setMaterial_no(param1.get(0).toString());
  10382. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  10383. mapper.UpdateQcmJudgeLocking(qjl);
  10384. sql = "select * from qcm_judge_surface where material_no = '"+param1.get(0).toString()+"' and surface_id = '"+param1.get(6).toString()+"' order by JUDGE_TIME desc";
  10385. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  10386. QcmJudgeSurface qjsf = new QcmJudgeSurface();
  10387. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  10388. qjsf.setSfd_is_lock("0");
  10389. qjsf.setSfe_is_lock("0");
  10390. qjsf.setSfu_is_lock("0");
  10391. mapper.UpdateQcmJudgeSurface(qjsf);
  10392. //修改库存锁定
  10393. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  10394. if(list1.size()>0){
  10395. for(HashMap lists:list1){
  10396. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10397. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判废!");
  10398. }
  10399. }
  10400. ZjResultAll zra = new ZjResultAll();
  10401. zra.setBilletid(param1.get(0).toString());
  10402. zra.setSurfaceresult("4");
  10403. zra.setSurfaceresult_desc("判废");
  10404. if(list1.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  10405. zra.setSfu_is_lock("0");
  10406. zra.setUp_surface_result("4");
  10407. zra.setUp_surface_result_desc("判废");
  10408. }
  10409. if(list1.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  10410. zra.setSfd_is_lock("0");
  10411. zra.setUd_surface_result("4");
  10412. zra.setUd_surface_result_desc("判废");
  10413. }
  10414. if(list1.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  10415. zra.setSfe_is_lock("0");
  10416. zra.setMarginal_result("4");
  10417. zra.setMarginal_result_id_desc("判废");
  10418. }
  10419. mapper.UpdateJugeResultB(zra);
  10420. //表面信息发送到MES
  10421. if(param1.get(0).toString().startsWith("H") || param1.get(0).toString().startsWith("Z")){
  10422. String aJudgeType = "废品";
  10423. String aGZLB = "";
  10424. String aGYLB = "";
  10425. String aXGLB = "";
  10426. List<QcmJudgeSurfaceFlaw> qjf1 = mapper.queryQcmJudgeSurfaceFlaw("select * from qcm_judge_surface_flaw where surface_id = '"+param1.get(6).toString()+"' and flaw_seq = '1'");
  10427. if(qjf1.size() >0){
  10428. if(qjf1.get(0).getIs_repair().equals("0") || qjf1.get(0).getIs_repair().equals("未修复")){
  10429. aXGLB = "402301";
  10430. }else{
  10431. aXGLB = "402303";
  10432. }
  10433. List<HashMap> listgzl = mapper.query("select * from qcm_base_defect a where a.defect_code = '"+qjf1.get(0).getFlaw_code()+"'");
  10434. if(listgzl.size() > 0){
  10435. if(listgzl.get(0).get("DEFECT_TYPE_CODE").equals("S")){
  10436. List<HashMap> listgz = mapper.query("select * from scm_base_info a where a.sort_code = '4124' and memo like '%钢质%' and name_ = '"+qjf1.get(0).getFlaw_desc()+"'");
  10437. if(listgz.size() > 0){
  10438. aGZLB = listgz.get(0).get("ID_").toString();
  10439. }else{
  10440. aGZLB = qjf1.get(0).getFlaw_desc();
  10441. }
  10442. }else{
  10443. List<HashMap> listgy = mapper.query("select * from scm_base_info a where a.sort_code = '4124' and memo like '%工艺%' and name_ = '"+qjf1.get(0).getFlaw_desc()+"'");
  10444. if(listgy.size() > 0){
  10445. aGYLB = listgy.get(0).get("ID_").toString();
  10446. }else{
  10447. aGYLB = qjf1.get(0).getFlaw_desc();
  10448. }
  10449. }
  10450. }
  10451. }
  10452. bmjy(qjf.get(0).getSf_type().equals("U") ? "S" : "X"+param1.get(6).toString(),param1.get(0).toString(),aJudgeType, aGZLB, aGYLB, aXGLB,hashmap.get(0).get("STEEL_NAME")==null?"":hashmap.get(0).get("STEEL_NAME").toString(), hashmap.get(0).get("PROD_NAME")==null?"":hashmap.get(0).get("PROD_NAME").toString() , hashmap.get(0).get("STD_NAME")==null?"":hashmap.get(0).get("STD_NAME").toString(), param1.get(5).toString() , "", "", param1.get(4).toString(), "");
  10453. }
  10454. //脱单
  10455. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"4");
  10456. order_down(param1.get(0).toString(),"判废");
  10457. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10458. qjog.setOperate_name(param1.get(5).toString());
  10459. qjog.setOperate_type("判废");
  10460. qjog.setParams(param1.get(0).toString());
  10461. qjog.setBatchno(qjl.getBatch_no());
  10462. qjog.setProd_line(qjl.getPline_code());
  10463. mapper.insertQcmJudgeOperateLog(qjog);
  10464. SqlSession.commit();
  10465. }else if(list2.size() >0){
  10466. for(HashMap lists:list2){
  10467. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10468. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判废!");
  10469. }
  10470. }
  10471. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  10472. zra.setCoil_no(param1.get(0).toString());
  10473. zra.setSurfaceresult("4");
  10474. zra.setSurfaceresult_desc("判废");
  10475. if(list2.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  10476. zra.setSfu_is_lock("0");
  10477. zra.setUp_surface_result("4");
  10478. zra.setUp_surface_result_desc("判废");
  10479. }
  10480. if(list2.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  10481. zra.setSfd_is_lock("0");
  10482. zra.setUd_surface_result("4");
  10483. zra.setUd_surface_result_desc("判废");
  10484. }
  10485. if(list2.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  10486. zra.setSfe_is_lock("0");
  10487. zra.setMarginal_result("4");
  10488. zra.setMarginal_result_id_desc("判废");
  10489. }
  10490. mapper.UpdateJugeResultJ(zra);
  10491. //脱单
  10492. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10493. qjog.setOperate_name(param1.get(5).toString());
  10494. qjog.setOperate_type("判废");
  10495. qjog.setParams(param1.get(0).toString());
  10496. qjog.setBatchno(qjl.getBatch_no());
  10497. qjog.setProd_line(qjl.getPline_code());
  10498. mapper.insertQcmJudgeOperateLog(qjog);
  10499. SqlSession.commit();
  10500. }else{
  10501. for(HashMap lists:list3){
  10502. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10503. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  10504. }
  10505. }
  10506. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  10507. zra.setCoil_no(param1.get(0).toString());
  10508. zra.setSurfaceresult("4");
  10509. zra.setSurfaceresult_desc("判废");
  10510. if(list3.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  10511. zra.setSfu_is_lock("0");
  10512. zra.setUp_surface_result("4");
  10513. zra.setUp_surface_result_desc("判废");
  10514. }
  10515. if(list3.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  10516. zra.setSfd_is_lock("0");
  10517. zra.setUd_surface_result("4");
  10518. zra.setUd_surface_result_desc("判废");
  10519. }
  10520. if(list3.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  10521. zra.setSfe_is_lock("0");
  10522. zra.setMarginal_result("4");
  10523. zra.setMarginal_result_id_desc("判废");
  10524. }
  10525. //zra.setInspection_lot(list2.get(0).get("INSPECTION_LOT").toString());
  10526. zra.setSic_is_lock("0");
  10527. mapper.UpdateJugeResultY(zra);
  10528. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10529. qjog.setOperate_name(param1.get(5).toString());
  10530. qjog.setOperate_type("判废");
  10531. qjog.setParams(param1.get(0).toString());
  10532. qjog.setBatchno(qjls.get(0).getBatch_no());
  10533. qjog.setProd_line(qjl.getPline_code());
  10534. mapper.insertQcmJudgeOperateLog(qjog);
  10535. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"4");
  10536. SqlSession.commit();
  10537. }
  10538. }else{
  10539. throw new Exception("未找到库存信息!");
  10540. }
  10541. }
  10542. }
  10543. //脱单 根据产线划分 中厚板保留原有判定结果,只是进行解锁,热卷 进行充当清除判定记录
  10544. if(param1.get(3).toString().equals("6")){
  10545. qjl.setUnlock_type_code("6");
  10546. qjl.setUnlock_type_desc("脱单");
  10547. qjl.setUnlock_memo(param1.get(4).toString());
  10548. qjl.setUnlock_result(param1.get(8).toString());
  10549. qjl.setUnlock_name(param1.get(5).toString());
  10550. mapper.UpdateQcmJudgeLocking(qjl);
  10551. if(qjl.getPline_code().equals("ZB1") || qjl.getPline_code().equals("HB1")){
  10552. //调用脱单接口
  10553. if(param1.get(2).toString().equals("S")){
  10554. qjl.setSic_locking("0");
  10555. //库存表放
  10556. if(list1.size() >0 || list2.size() >0){
  10557. if(list1.size()>0){
  10558. for(HashMap lists:list1){
  10559. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10560. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  10561. }
  10562. }
  10563. ZjResultAll zra = new ZjResultAll();
  10564. zra.setBilletid(param1.get(0).toString());
  10565. zra.setSic_is_lock("0");
  10566. mapper.UpdateJugeResultB(zra);
  10567. qjl.setUnlock_name(param1.get(5).toString());
  10568. qjl.setMaterial_no(param1.get(0).toString());
  10569. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  10570. mapper.UpdateQcmJudgeLocking(qjl);
  10571. //脱单
  10572. order_down(param1.get(0).toString(),"异常处置脱单");
  10573. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10574. qjog.setOperate_name(param1.get(5).toString());
  10575. qjog.setOperate_type("异常处置脱单");
  10576. qjog.setParams(param1.get(0).toString());
  10577. qjog.setBatchno(qjl.getBatch_no());
  10578. qjog.setProd_line(qjl.getPline_code());
  10579. mapper.insertQcmJudgeOperateLog(qjog);
  10580. SqlSession.commit();
  10581. }else{
  10582. for(HashMap lists:list2){
  10583. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10584. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  10585. }
  10586. }
  10587. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  10588. zra.setCoil_no(param1.get(0).toString());
  10589. zra.setSic_is_lock("0");
  10590. mapper.UpdateJugeResultJ(zra);
  10591. qjl.setUnlock_name(param1.get(5).toString());
  10592. qjl.setMaterial_no(param1.get(0).toString());
  10593. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  10594. mapper.UpdateQcmJudgeLocking(qjl);
  10595. //脱单
  10596. SqlSession.commit();
  10597. }
  10598. }else{
  10599. throw new Exception("未找到库存信息!");
  10600. }
  10601. }
  10602. if(param1.get(2).toString().equals("D")){
  10603. qjl.setDic_locking("0");
  10604. //库存表放
  10605. if(list1.size() >0 || list2.size() >0){
  10606. if(list1.size()>0){
  10607. for(HashMap lists:list1){
  10608. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10609. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  10610. }
  10611. }
  10612. ZjResultAll zra = new ZjResultAll();
  10613. zra.setBilletid(param1.get(0).toString());
  10614. zra.setSic_is_lock("0");
  10615. mapper.UpdateJugeResultB(zra);
  10616. qjl.setUnlock_name(param1.get(5).toString());
  10617. qjl.setMaterial_no(param1.get(0).toString());
  10618. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  10619. mapper.UpdateQcmJudgeLocking(qjl);
  10620. //脱单
  10621. order_down(param1.get(0).toString(),"异常处置脱单");
  10622. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10623. qjog.setOperate_name(param1.get(5).toString());
  10624. qjog.setOperate_type("异常处置脱单");
  10625. qjog.setParams(param1.get(0).toString());
  10626. qjog.setBatchno(qjl.getBatch_no());
  10627. qjog.setProd_line(qjl.getPline_code());
  10628. mapper.insertQcmJudgeOperateLog(qjog);
  10629. SqlSession.commit();
  10630. }else{
  10631. for(HashMap lists:list2){
  10632. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10633. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  10634. }
  10635. }
  10636. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  10637. zra.setCoil_no(param1.get(0).toString());
  10638. zra.setSic_is_lock("0");
  10639. mapper.UpdateJugeResultJ(zra);
  10640. qjl.setUnlock_name(param1.get(5).toString());
  10641. qjl.setMaterial_no(param1.get(0).toString());
  10642. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  10643. mapper.UpdateQcmJudgeLocking(qjl);
  10644. //脱单
  10645. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10646. qjog.setOperate_name(param1.get(5).toString());
  10647. qjog.setOperate_type("异常处置脱单");
  10648. qjog.setParams(param1.get(0).toString());
  10649. qjog.setBatchno(qjl.getBatch_no());
  10650. qjog.setProd_line(qjl.getPline_code());
  10651. mapper.insertQcmJudgeOperateLog(qjog);
  10652. SqlSession.commit();
  10653. }
  10654. }else{
  10655. throw new Exception("未找到库存信息!");
  10656. }
  10657. }
  10658. //表面
  10659. if(param1.get(2).toString().equals("F")){
  10660. qjl.setFic_locking("0");
  10661. sql = "select * from qcm_judge_surface where material_no = '"+param1.get(0).toString()+"' order by JUDGE_TIME desc";
  10662. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  10663. QcmJudgeSurface qjsf = new QcmJudgeSurface();
  10664. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  10665. qjsf.setSfd_is_lock("0");
  10666. qjsf.setSfe_is_lock("0");
  10667. qjsf.setSfu_is_lock("0");
  10668. mapper.UpdateQcmJudgeSurface(qjsf);
  10669. //更新库存表放行
  10670. if(list1.size() >0 || list2.size() >0){
  10671. if(list1.size()>0){
  10672. for(HashMap lists:list1){
  10673. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10674. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  10675. }
  10676. }
  10677. ZjResultAll zra = new ZjResultAll();
  10678. zra.setBilletid(param1.get(0).toString());
  10679. if(list1.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  10680. zra.setSfu_is_lock("0");
  10681. }
  10682. if(list1.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  10683. zra.setSfd_is_lock("0");
  10684. }
  10685. if(list1.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  10686. zra.setSfe_is_lock("0");
  10687. }
  10688. mapper.UpdateJugeResultB(zra);
  10689. qjl.setUnlock_name(param1.get(5).toString());
  10690. qjl.setMaterial_no(param1.get(0).toString());
  10691. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  10692. mapper.UpdateQcmJudgeLocking(qjl);
  10693. //脱单
  10694. order_down(param1.get(0).toString(),"异常处置脱单");
  10695. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10696. qjog.setOperate_name(param1.get(5).toString());
  10697. qjog.setOperate_type("异常处置脱单");
  10698. qjog.setParams(param1.get(0).toString());
  10699. qjog.setBatchno(qjl.getBatch_no());
  10700. qjog.setProd_line(qjl.getPline_code());
  10701. mapper.insertQcmJudgeOperateLog(qjog);
  10702. SqlSession.commit();
  10703. }else{
  10704. for(HashMap lists:list2){
  10705. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10706. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  10707. }
  10708. }
  10709. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  10710. zra.setCoil_no(param1.get(0).toString());
  10711. if(list2.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  10712. zra.setSfu_is_lock("0");
  10713. }
  10714. if(list2.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  10715. zra.setSfd_is_lock("0");
  10716. }
  10717. if(list2.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  10718. zra.setSfe_is_lock("0");
  10719. }
  10720. mapper.UpdateJugeResultJ(zra);
  10721. qjl.setUnlock_name(param1.get(5).toString());
  10722. qjl.setMaterial_no(param1.get(0).toString());
  10723. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  10724. mapper.UpdateQcmJudgeLocking(qjl);
  10725. //脱单
  10726. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10727. qjog.setOperate_name(param1.get(5).toString());
  10728. qjog.setOperate_type("异常处置脱单");
  10729. qjog.setParams(param1.get(0).toString());
  10730. qjog.setBatchno(qjl.getBatch_no());
  10731. qjog.setProd_line(qjl.getPline_code());
  10732. mapper.insertQcmJudgeOperateLog(qjog);
  10733. SqlSession.commit();
  10734. }
  10735. }else{
  10736. throw new Exception("未找到库存信息!");
  10737. }
  10738. }
  10739. }else if(qjl.getPline_code().equals("RZ1") || qjl.getPline_code().equals("LT1") || qjl.getPline_code().equals("SZ1")){
  10740. if(param1.get(2).toString().equals("S")){
  10741. qjl.setSic_locking("0");
  10742. }
  10743. //表面
  10744. if(param1.get(2).toString().equals("F")){
  10745. qjl.setFic_locking("0");
  10746. }
  10747. //脱单
  10748. qjl.setUnlock_name(param1.get(5).toString());
  10749. qjl.setMaterial_no(param1.get(0).toString());
  10750. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  10751. mapper.UpdateQcmJudgeLocking(qjl);
  10752. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10753. qjog.setOperate_name(param1.get(5).toString());
  10754. qjog.setOperate_type("异常处置脱单");
  10755. qjog.setParams(param1.get(0).toString());
  10756. qjog.setBatchno(qjl.getBatch_no());
  10757. qjog.setProd_line(qjl.getPline_code());
  10758. mapper.insertQcmJudgeOperateLog(qjog);
  10759. SqlSession.commit();
  10760. }
  10761. }
  10762. //解除
  10763. if(param1.get(3).toString().equals("9")){
  10764. qjl.setUnlock_type_code("9");
  10765. qjl.setUnlock_type_desc("解除");
  10766. qjl.setUnlock_memo(param1.get(4).toString());
  10767. qjl.setUnlock_result(param1.get(8).toString());
  10768. if(param1.get(2).toString().equals("S")){
  10769. qjl.setSic_locking("0");
  10770. //库存表放
  10771. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  10772. if(list1.size()>0){
  10773. for(HashMap lists:list1){
  10774. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10775. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  10776. }
  10777. }
  10778. ZjResultAll zra = new ZjResultAll();
  10779. zra.setBilletid(param1.get(0).toString());
  10780. zra.setSic_is_lock("0");
  10781. mapper.UpdateJugeResultB(zra);
  10782. }else if(list2.size() >0){
  10783. for(HashMap lists:list2){
  10784. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10785. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  10786. }
  10787. }
  10788. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  10789. zra.setCoil_no(param1.get(0).toString());
  10790. zra.setSic_is_lock("0");
  10791. mapper.UpdateJugeResultJ(zra);
  10792. }else{
  10793. for(HashMap lists:list3){
  10794. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10795. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  10796. }
  10797. }
  10798. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  10799. zra.setCoil_no(param1.get(0).toString());
  10800. zra.setSic_is_lock("0");
  10801. mapper.UpdateJugeResultY(zra);
  10802. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10803. qjog.setOperate_name(param1.get(5).toString());
  10804. qjog.setOperate_type("公差解除");
  10805. qjog.setParams(param1.get(0).toString());
  10806. qjog.setBatchno(qjl.getBatch_no());
  10807. qjog.setProd_line(qjl.getPline_code());
  10808. mapper.insertQcmJudgeOperateLog(qjog);
  10809. QcmJudgeLog qjl1 = new QcmJudgeLog();
  10810. qjl1.setJudge_type("R");
  10811. qjl1.setMaterial_no(param1.get(0).toString());
  10812. qjl1.setMaterial_type("0");
  10813. qjl1.setCreate_name("system");
  10814. qjl1.setProd_line("YT1");
  10815. mapper.insertQcmJudgeLog(qjl1);
  10816. }
  10817. }else{
  10818. throw new Exception("未找到库存信息!");
  10819. }
  10820. //库存表放
  10821. qjl.setUnlock_name(param1.get(5).toString());
  10822. qjl.setMaterial_no(param1.get(0).toString());
  10823. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  10824. mapper.UpdateQcmJudgeLocking(qjl);
  10825. SqlSession.commit();
  10826. }
  10827. //表面解锁
  10828. if(param1.get(2).toString().equals("F")){
  10829. qjl.setFic_locking("0");
  10830. //更新库存表放行
  10831. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  10832. if(list1.size()>0){
  10833. for(HashMap lists:list1){
  10834. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10835. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  10836. }
  10837. }
  10838. ZjResultAll zra = new ZjResultAll();
  10839. zra.setBilletid(param1.get(0).toString());
  10840. if(list1.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  10841. zra.setSfu_is_lock("0");
  10842. }
  10843. if(list1.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  10844. zra.setSfd_is_lock("0");
  10845. }
  10846. if(list1.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  10847. zra.setSfe_is_lock("0");
  10848. }
  10849. mapper.UpdateJugeResultB(zra);
  10850. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10851. qjog.setOperate_name(param1.get(5).toString());
  10852. qjog.setOperate_type("解除");
  10853. qjog.setParams(param1.get(0).toString());
  10854. qjog.setBatchno(qjl.getBatch_no());
  10855. qjog.setProd_line(qjl.getPline_code());
  10856. mapper.insertQcmJudgeOperateLog(qjog);
  10857. }else if(list2.size() >0){
  10858. for(HashMap lists:list2){
  10859. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10860. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  10861. }
  10862. }
  10863. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  10864. zra.setCoil_no(param1.get(0).toString());
  10865. if(list2.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  10866. zra.setSfu_is_lock("0");
  10867. }
  10868. if(list2.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  10869. zra.setSfd_is_lock("0");
  10870. }
  10871. if(list2.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  10872. zra.setSfe_is_lock("0");
  10873. }
  10874. mapper.UpdateJugeResultJ(zra);
  10875. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10876. qjog.setOperate_name(param1.get(5).toString());
  10877. qjog.setOperate_type("解除");
  10878. qjog.setParams(param1.get(0).toString());
  10879. qjog.setBatchno(qjl.getBatch_no());
  10880. qjog.setProd_line(qjl.getPline_code());
  10881. mapper.insertQcmJudgeOperateLog(qjog);
  10882. }else{
  10883. for(HashMap lists:list3){
  10884. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10885. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  10886. }
  10887. }
  10888. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  10889. zra.setCoil_no(param1.get(0).toString());
  10890. if(list3.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  10891. zra.setSfu_is_lock("0");
  10892. }
  10893. if(list3.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  10894. zra.setSfd_is_lock("0");
  10895. }
  10896. if(list3.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  10897. zra.setSfe_is_lock("0");
  10898. }
  10899. mapper.UpdateJugeResultY(zra);
  10900. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10901. qjog.setOperate_name(param1.get(5).toString());
  10902. qjog.setOperate_type("表面解除");
  10903. qjog.setParams(param1.get(0).toString());
  10904. qjog.setBatchno(qjl.getBatch_no());
  10905. qjog.setProd_line(qjl.getPline_code());
  10906. mapper.insertQcmJudgeOperateLog(qjog);
  10907. QcmJudgeLog qjl1 = new QcmJudgeLog();
  10908. qjl1.setJudge_type("R");
  10909. qjl1.setMaterial_no(param1.get(0).toString());
  10910. qjl1.setMaterial_type("0");
  10911. qjl1.setCreate_name("system");
  10912. qjl1.setProd_line("YT1");
  10913. mapper.insertQcmJudgeLog(qjl1);
  10914. }
  10915. }else{
  10916. throw new Exception("未找到库存信息!");
  10917. }
  10918. sql = "select * from qcm_judge_surface where material_no = '"+param1.get(0).toString()+"' order by JUDGE_TIME desc";
  10919. List<QcmJudgeSurface> qjf = mapper.queryQcmJudgeSurfaces(sql);
  10920. QcmJudgeSurface qjsf = new QcmJudgeSurface();
  10921. qjsf.setSurface_id(qjf.get(0).getSurface_id());
  10922. qjsf.setSfd_is_lock("0");
  10923. qjsf.setSfe_is_lock("0");
  10924. qjsf.setSfu_is_lock("0");
  10925. mapper.UpdateQcmJudgeSurface(qjsf);
  10926. qjl.setUnlock_name(param1.get(5).toString());
  10927. qjl.setMaterial_no(param1.get(0).toString());
  10928. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  10929. mapper.UpdateQcmJudgeLocking(qjl);
  10930. SqlSession.commit();
  10931. }
  10932. //工艺
  10933. if(param1.get(2).toString().equals("T")){
  10934. qjl.setTic_locking("0");
  10935. //更新库存表放行
  10936. if(list1.size() >0 || list2.size() >0){
  10937. if(list2.size()>0){
  10938. for(HashMap lists:list2){
  10939. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10940. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  10941. }
  10942. }
  10943. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  10944. zra.setCoil_no(param1.get(0).toString());
  10945. zra.setTic_is_lock("0");
  10946. mapper.UpdateJugeResultJ(zra);
  10947. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10948. qjog.setOperate_name(param1.get(5).toString());
  10949. qjog.setOperate_type("解除");
  10950. qjog.setParams(param1.get(0).toString());
  10951. qjog.setBatchno(qjl.getBatch_no());
  10952. qjog.setProd_line(qjl.getPline_code());
  10953. mapper.insertQcmJudgeOperateLog(qjog);
  10954. }
  10955. }else{
  10956. throw new Exception("未找到库存信息!");
  10957. }
  10958. qjl.setUnlock_name(param1.get(5).toString());
  10959. qjl.setMaterial_no(param1.get(0).toString());
  10960. qjl.setLock_seq(Integer.parseInt(param1.get(1).toString()));
  10961. mapper.UpdateQcmJudgeLocking(qjl);
  10962. QcmJudgeLog qjlt = new QcmJudgeLog();
  10963. qjlt.setJudge_type("U");
  10964. qjlt.setMaterial_no(param1.get(0).toString());
  10965. qjlt.setCreate_name("system");
  10966. qjlt.setProd_line(qjl.getPline_code());
  10967. mapper.insertQcmJudgeLog(qjlt);
  10968. SqlSession.commit();
  10969. }
  10970. }
  10971. if(param1.get(3).toString().equals("10")){
  10972. if(list3.size() >0){
  10973. qjl.setUnlock_type_code("10");
  10974. qjl.setUnlock_type_desc("待判");
  10975. qjl.setUnlock_memo(param1.get(4).toString());
  10976. qjl.setUnlock_result(param1.get(8).toString());
  10977. qjl.setUnlock_name(param1.get(5).toString());
  10978. qjl.setLock_id(param1.get(6).toString());
  10979. qjl.setMaterial_no(param1.get(0).toString());
  10980. mapper.UpdateQcmJudgeLocking1(qjl);
  10981. if(param1.get(2).toString().equals("S")){
  10982. for(HashMap lists:list3){
  10983. if(!lists.get("JUDGERESULT").toString().equals("0")){
  10984. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  10985. }
  10986. }
  10987. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  10988. zra.setCoil_no(param1.get(0).toString());
  10989. zra.setSic_is_lock("0");
  10990. zra.setSizeresult("0");
  10991. zra.setSizeresult_desc("");
  10992. mapper.UpdateJugeResultY(zra);
  10993. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  10994. qjog.setOperate_name(param1.get(5).toString());
  10995. qjog.setOperate_type("公差待判");
  10996. qjog.setParams(param1.get(0).toString());
  10997. qjog.setBatchno(qjl.getBatch_no());
  10998. qjog.setProd_line(qjl.getPline_code());
  10999. mapper.insertQcmJudgeOperateLog(qjog);
  11000. }
  11001. if(param1.get(2).toString().equals("F")){
  11002. for(HashMap lists:list3){
  11003. if(!lists.get("JUDGERESULT").toString().equals("0")){
  11004. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  11005. }
  11006. }
  11007. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  11008. zra.setCoil_no(param1.get(0).toString());
  11009. if(list3.get(0).get("SFU_IS_LOCK").toString().equals("1")){
  11010. zra.setSfu_is_lock("0");
  11011. }
  11012. if(list3.get(0).get("SFD_IS_LOCK").toString().equals("1")){
  11013. zra.setSfd_is_lock("0");
  11014. }
  11015. if(list3.get(0).get("SFE_IS_LOCK").toString().equals("1")){
  11016. zra.setSfe_is_lock("0");
  11017. }
  11018. zra.setSurfaceresult("0");
  11019. zra.setSurfaceresult_desc("");
  11020. zra.setUd_surface_result("0");
  11021. zra.setUd_surface_result_desc("");
  11022. zra.setUp_surface_result("0");
  11023. zra.setUp_surface_result_desc("");
  11024. zra.setMarginal_result("0");
  11025. zra.setMarginal_result_desc("");
  11026. mapper.UpdateJugeResultY(zra);
  11027. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11028. qjog.setOperate_name(param1.get(5).toString());
  11029. qjog.setOperate_type("表面待判");
  11030. qjog.setParams(param1.get(0).toString());
  11031. qjog.setBatchno(qjl.getBatch_no());
  11032. qjog.setProd_line(qjl.getPline_code());
  11033. mapper.insertQcmJudgeOperateLog(qjog);
  11034. }
  11035. }
  11036. else{
  11037. qjl.setUnlock_type_code("10");
  11038. qjl.setUnlock_type_desc("待判");
  11039. qjl.setUnlock_memo(param1.get(4).toString());
  11040. qjl.setUnlock_result(param1.get(8).toString());
  11041. qjl.setUnlock_name(param1.get(5).toString());
  11042. qjl.setLock_id(param1.get(6).toString());
  11043. qjl.setMaterial_no(param1.get(0).toString());
  11044. mapper.UpdateQcmJudgeLocking1(qjl);
  11045. int count = 0;
  11046. String condition = " and MATERIAL_NO = '"+param1.get(0).toString()+"' order by LOCK_SEQ desc ";
  11047. List<QCMJudgeLocking> qjlk = mapper.queryQCMJudgeLocking(condition);
  11048. if(qjlk.size() > 0){
  11049. count=qjlk.get(0).getLock_seq();
  11050. }
  11051. count++;
  11052. //锁定记录号
  11053. int lock_seq=count;
  11054. qjl.setLock_seq(lock_seq);
  11055. qjl.setUnlock_type_code("");
  11056. qjl.setUnlock_type_desc("");
  11057. qjl.setLock_memo("待判");
  11058. qjl.setTarget_design_key("");
  11059. qjl.setUnlock_name("");
  11060. mapper.insertQCMJudgeLocking(qjl);
  11061. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11062. qjog.setOperate_name(param1.get(5).toString());
  11063. qjog.setOperate_type("待判");
  11064. qjog.setParams(param1.get(0).toString());
  11065. qjog.setBatchno(qjl.getBatch_no());
  11066. qjog.setProd_line(qjl.getPline_code());
  11067. mapper.insertQcmJudgeOperateLog(qjog);
  11068. if(param1.get(0).toString().startsWith("Z") || param1.get(0).toString().startsWith("H")){
  11069. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"0");
  11070. }
  11071. }
  11072. SqlSession.commit();
  11073. }
  11074. }
  11075. catch(Exception e){
  11076. cro.setV_errCode(-1);
  11077. cro.setV_errMsg(e.getMessage());
  11078. SqlSession.rollback();
  11079. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.doInformationSureH:【" + param1.toString() + "】" + e);
  11080. }
  11081. SqlSession.close();
  11082. return cro;
  11083. }
  11084. /**param1 改判除外的异常材处置
  11085. * 产品序号、锁定记录号、封锁来源、处置去向、处置去向说明、操作人,单项判定记录号,缺陷、产线
  11086. * @param param1
  11087. * @return
  11088. * @throws Exception
  11089. */
  11090. @SuppressWarnings("rawtypes")
  11091. public CoreReturnObject doInformationSure(ArrayList param1) throws Exception{
  11092. try{
  11093. if(param1 == null || param1.size() <= 0){
  11094. throw new Exception("请传入参数!");
  11095. }
  11096. String sql = "select * from qcm_judge_locking where material_no = '"+param1.get(0).toString()+"' and lock_seq = '"+param1.get(1).toString()+"' and unlock_type_code is null ";
  11097. List<QCMJudgeLocking> qjls = mapper.queryQCMJudgeLockings(sql);
  11098. if(qjls.size() == 0){
  11099. SqlSession.close();
  11100. return cro;
  11101. }
  11102. sql = "select * from qcm_judge_locking where material_no = '"+param1.get(0).toString()+"' and lock_seq = '"+param1.get(1).toString()+"' and status <> '1' ";
  11103. qjls = mapper.queryQCMJudgeLockings(sql);
  11104. if(qjls.size() == 0){
  11105. throw new Exception("该处置信息处于申请中,不能继续操作!");
  11106. }
  11107. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  11108. /*List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(param1.get(0).toString());
  11109. if(hashmap.size() == 0){
  11110. hashmap = qjms.doQueryMaterialInfoJ(param1.get(0).toString());
  11111. }*/
  11112. QcmJudgeSurfaceServiceImpl qjft = new QcmJudgeSurfaceServiceImpl();
  11113. QCMJudgeLocking qjl = qjls.get(0);
  11114. sql = "select * from zj_result_all@xgcx where BILLETID = '"+param1.get(0).toString()+"'";
  11115. List<HashMap> list1 = mapper.query(sql);
  11116. sql = "select * from QCM_JUDGE_COIL_RESULT where coil_no = '"+param1.get(0).toString()+"'";
  11117. List<HashMap> list2 = mapper.query(sql);
  11118. sql = "select * from QCM_JUDGE_YT_COIL_RESULT where coil_no = '"+param1.get(0).toString()+"'";
  11119. List<HashMap> list3 = mapper.query(sql);
  11120. //放行
  11121. if(param1.get(3).toString().equals("0")){
  11122. qjl.setUnlock_type_code("0");
  11123. qjl.setUnlock_type_desc("放行");
  11124. qjl.setUnlock_memo(param1.get(4).toString());
  11125. qjl.setUnlock_result(param1.get(9).toString());
  11126. //判断产线是不是卷板,是的话调用存储过程COILJUDGE_STATUS
  11127. if(list2.size() > 0) {
  11128. //List<HashMap> hashmap2 = qjms.doQueryMaterialInfoJ(param1.get(0).toString());
  11129. //if (hashmap2.size() > 0) {
  11130. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  11131. if(param1.get(2).toString().equals("C")){
  11132. coiljudge_status_call(param1.get(8).toString(), param1.get(0).toString(), "1", null, null, null, null, null, null,"");
  11133. } /*else if(param1.get(2).toString().equals("P")){
  11134. coiljudge_status_call(param1.get(8).toString(), param1.get(0).toString(), null, "1", null, null, null, null, null,"");
  11135. }*/ else if(param1.get(2).toString().equals("S")){
  11136. coiljudge_status_call(param1.get(8).toString(), param1.get(0).toString(), null, null, "1", null, null, null, null,"");
  11137. } else if(param1.get(2).toString().equals("F")){
  11138. coiljudge_status_call(param1.get(8).toString(), param1.get(0).toString(), null, null, null, "1", null, null, null,"");
  11139. }
  11140. //}
  11141. }
  11142. //材质放行
  11143. if(param1.get(2).toString().equals("P")){
  11144. qjl.setPic_locking("0");
  11145. //更改合同试样表
  11146. List<QcmJhySampleROrd> qjst = mapper.queryQcmJhySampleROrd1("select * from qcm_jhy_sample_r_ord where phy_id = '"+param1.get(6).toString()+"'");
  11147. QcmJhySampleROrd qjsr = new QcmJhySampleROrd();
  11148. qjsr.setPhy_id(param1.get(6).toString());
  11149. qjsr.setJudge_result_code("1");
  11150. qjsr.setJudge_result_desc("合格");
  11151. qjsr.setJudge_name(param1.get(5).toString());
  11152. qjsr.setJudge_time(new Date());
  11153. qjsr.setDesign_key(qjl.getDesign_key());
  11154. qjsr.setPsc(qjst.get(0).getPsc());
  11155. qjsr.setSmp_no(qjst.get(0).getSmp_no());
  11156. mapper.updateQcmJhySampleROrds(qjsr);
  11157. /*sql = "select * from qcm_judge_physical where phy_id = '"+param1.get(6).toString()+"' order by judge_ttime desc";
  11158. List<QcmJudgePhysical> qjps = mapper.queryQcmJudgePhysical(sql);
  11159. QcmJudgePhysical qjsf = new QcmJudgePhysical();
  11160. qjsf.setPhy_id(qjps.get(0).getPhy_id());
  11161. qjsf.setPhy_result_code("1");
  11162. qjsf.setPhy_result_desc("合格");
  11163. mapper.updateQcmJudgePhysical(qjsf);*/
  11164. //更新库存表放行
  11165. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  11166. if(list1.size()>0){
  11167. for(HashMap lists:list1){
  11168. if(!lists.get("JUDGERESULT").toString().equals("0")){
  11169. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  11170. }
  11171. }
  11172. ZjResultAll zra = new ZjResultAll();
  11173. if(param1.get(6).toString().equals(list1.get(0).get("PHYFSTSID"))){
  11174. zra.setPhyfstsresult("1");
  11175. zra.setPhyfstsresult_desc("合格");
  11176. }
  11177. zra.setBilletid(list1.get(0).get("BILLETID").toString());
  11178. zra.setPic_is_lock("2");
  11179. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list1.get(0).get("BILLETID_JY").toString()+"' and JUDGE_STATUS = '0'");
  11180. if(qjsrt.size() > 0){
  11181. throw new Exception("该检验号下存在未判信息,不能放行!");
  11182. }
  11183. mapper.UpdateJugeResultB(zra);
  11184. PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  11185. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  11186. for(HashMap lists:list1){
  11187. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11188. qjog.setOperate_name(param1.get(5).toString());
  11189. qjog.setOperate_type("材质放行");
  11190. qjog.setParams(lists.get("BILLETID_JY").toString());
  11191. qjog.setBatchno(qjl.getBatch_no());
  11192. qjog.setProd_line(qjl.getPline_code());
  11193. mapper.insertQcmJudgeOperateLog(qjog);
  11194. //质量异常材处置
  11195. qjl = new QCMJudgeLocking();
  11196. qjl.setUnlock_type_code("0");
  11197. qjl.setUnlock_type_desc("放行");
  11198. qjl.setUnlock_memo(param1.get(4).toString());
  11199. qjl.setUnlock_result(param1.get(9).toString());
  11200. qjl.setPic_locking("2");
  11201. qjl.setBatch_no(qjls.get(0).getBatch_no());
  11202. qjl.setMaterial_no(lists.get("BILLETID").toString());
  11203. qjl.setUnlock_name(param1.get(5).toString());
  11204. qjl.setLock_id(param1.get(6).toString());
  11205. qjl.setReason_code(param1.get(7).toString());
  11206. qjl.setLock_type_code(param1.get(2).toString());
  11207. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  11208. if(listsu.size() >0)
  11209. {
  11210. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  11211. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  11212. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  11213. }
  11214. mapper.UpdateQcmJudgeLocking3(qjl);
  11215. QcmJudgeLog qjlt = new QcmJudgeLog();
  11216. qjlt.setJudge_type("U");
  11217. qjlt.setMaterial_no(lists.get("BILLETID").toString());
  11218. qjlt.setCreate_name("system");
  11219. qjlt.setProd_line(qjl.getPline_code());
  11220. mapper.insertQcmJudgeLog(qjlt);
  11221. }
  11222. SqlSession.commit();
  11223. }else if(list2.size() >0){
  11224. for(HashMap lists:list2){
  11225. if(!lists.get("JUDGERESULT").toString().equals("0")){
  11226. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  11227. }
  11228. }
  11229. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  11230. if(param1.get(6).toString().equals(list2.get(0).get("PHYFSTSID"))){
  11231. zra.setPhyfstsresult("1");
  11232. zra.setPhyfstsresult_desc("合格");
  11233. }
  11234. zra.setInspection_lot(list2.get(0).get("INSPECTION_LOT").toString());
  11235. zra.setPic_is_lock("2");
  11236. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  11237. if(qjsrt.size() > 0){
  11238. throw new Exception("该检验号下存在未判信息,不能放行!");
  11239. }
  11240. mapper.UpdateJugeResultJ(zra);
  11241. PhyUtmJudge(qjl.getDesign_key(),list2.get(0).get("INSPECTION_LOT").toString() , param1.get(5).toString());
  11242. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  11243. for(HashMap lists:list2){
  11244. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11245. qjog.setOperate_name(param1.get(5).toString());
  11246. qjog.setOperate_type("材质放行");
  11247. qjog.setParams(lists.get("INSPECTION_LOT").toString());
  11248. qjog.setBatchno(qjl.getBatch_no());
  11249. qjog.setProd_line(qjl.getPline_code());
  11250. mapper.insertQcmJudgeOperateLog(qjog);
  11251. //质量异常材处置
  11252. qjl = new QCMJudgeLocking();
  11253. qjl.setUnlock_type_code("0");
  11254. qjl.setUnlock_type_desc("放行");
  11255. qjl.setUnlock_memo(param1.get(4).toString());
  11256. qjl.setUnlock_result(param1.get(9).toString());
  11257. qjl.setPic_locking("2");
  11258. qjl.setBatch_no(qjls.get(0).getBatch_no());
  11259. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  11260. qjl.setUnlock_name(param1.get(5).toString());
  11261. qjl.setLock_id(param1.get(6).toString());
  11262. qjl.setReason_code(param1.get(7).toString());
  11263. qjl.setLock_type_code(param1.get(2).toString());
  11264. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  11265. if(listsu.size() >0)
  11266. {
  11267. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  11268. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  11269. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  11270. }
  11271. mapper.UpdateQcmJudgeLocking3(qjl);
  11272. QcmJudgeLog qjlt = new QcmJudgeLog();
  11273. qjlt.setJudge_type("R");
  11274. qjlt.setMaterial_no(lists.get("INSPECTION_LOT").toString());
  11275. qjlt.setCreate_name("system");
  11276. qjlt.setMaterial_type("1");
  11277. qjlt.setProd_line(qjl.getPline_code());
  11278. mapper.insertQcmJudgeLog(qjlt);
  11279. }
  11280. sql = "select * from qcm_judge_coil_result where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and judgeresult = '0' ";
  11281. List<HashMap> listq1 = mapper.query(sql);
  11282. for(HashMap listq2 :listq1){
  11283. coiljudge_status_call(param1.get(8).toString(), listq2.get("COIL_NO").toString(), null, "1", null, null, null, null, null,"");
  11284. }
  11285. SqlSession.commit();
  11286. }else{
  11287. for(HashMap lists:list3){
  11288. if(!lists.get("JUDGERESULT").toString().equals("0")){
  11289. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  11290. }
  11291. }
  11292. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  11293. if(param1.get(6).toString().equals(list3.get(0).get("PHYFSTSID"))){
  11294. zra.setPhyfstsresult("1");
  11295. zra.setPhyfstsresult_desc("合格");
  11296. }
  11297. zra.setInspection_lot(list3.get(0).get("INSPECTION_LOT").toString());
  11298. zra.setPic_is_lock("2");
  11299. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  11300. if(qjsrt.size() > 0){
  11301. throw new Exception("该检验号下存在未判信息,不能放行!");
  11302. }
  11303. mapper.UpdateJugeResultY(zra);
  11304. PhyUtmJudge(qjl.getDesign_key(),list3.get(0).get("INSPECTION_LOT").toString() , param1.get(5).toString());
  11305. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  11306. for(HashMap lists:list3){
  11307. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11308. qjog.setOperate_name(param1.get(5).toString());
  11309. qjog.setOperate_type("材质放行");
  11310. qjog.setParams(lists.get("INSPECTION_LOT").toString());
  11311. qjog.setBatchno(qjl.getBatch_no());
  11312. qjog.setProd_line(qjl.getPline_code());
  11313. mapper.insertQcmJudgeOperateLog(qjog);
  11314. //质量异常材处置
  11315. qjl = new QCMJudgeLocking();
  11316. qjl.setUnlock_type_code("0");
  11317. qjl.setUnlock_type_desc("放行");
  11318. qjl.setUnlock_memo(param1.get(4).toString());
  11319. qjl.setUnlock_result(param1.get(9).toString());
  11320. qjl.setPic_locking("2");
  11321. qjl.setBatch_no(qjls.get(0).getBatch_no());
  11322. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  11323. qjl.setUnlock_name(param1.get(5).toString());
  11324. qjl.setLock_id(param1.get(6).toString());
  11325. qjl.setReason_code(param1.get(7).toString());
  11326. qjl.setLock_type_code(param1.get(2).toString());
  11327. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  11328. if(listsu.size() >0)
  11329. {
  11330. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  11331. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  11332. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  11333. }
  11334. mapper.UpdateQcmJudgeLocking3(qjl);
  11335. QcmJudgeLog qjlt = new QcmJudgeLog();
  11336. qjlt.setJudge_type("R");
  11337. qjlt.setMaterial_no(lists.get("INSPECTION_LOT").toString());
  11338. qjlt.setCreate_name("system");
  11339. qjlt.setMaterial_type("1");
  11340. qjlt.setProd_line(qjl.getPline_code());
  11341. mapper.insertQcmJudgeLog(qjlt);
  11342. }
  11343. SqlSession.commit();
  11344. }
  11345. }else{
  11346. throw new Exception("未找到库存信息!");
  11347. }
  11348. }
  11349. if(param1.get(2).toString().equals("C")){
  11350. qjl.setCic_locking("0");
  11351. if(param1.get(6).toString().contains("C")){
  11352. //更改合同试样表
  11353. List<QcmJhySampleROrd> qjst = mapper.queryQcmJhySampleROrd1("select * from qcm_jhy_sample_r_ord where cic_id = '"+param1.get(6).toString()+"'");
  11354. QcmJhySampleROrd qjsr = new QcmJhySampleROrd();
  11355. qjsr.setCic_id(param1.get(6).toString());
  11356. qjsr.setJudge_result_code("1");
  11357. qjsr.setJudge_result_desc("合格");
  11358. qjsr.setJudge_name(param1.get(5).toString());
  11359. qjsr.setJudge_time(new Date());
  11360. qjsr.setDesign_key(qjl.getDesign_key());
  11361. qjsr.setPsc(qjst.get(0).getPsc());
  11362. qjsr.setSmp_no(qjst.get(0).getSmp_no());
  11363. mapper.updateQcmJhySampleROrds(qjsr);
  11364. /*sql = "select * from qcm_judge_chemical where cic_id = '"+param1.get(6).toString()+"' order by judge_ttime desc";
  11365. List<QcmJudgeChemical> qjps = mapper.queryQcmJudgeChemical(sql);
  11366. QcmJudgeChemical qjsf = new QcmJudgeChemical();
  11367. qjsf.setCic_id(qjps.get(0).getCic_id());
  11368. qjsf.setCic_result_code("1");
  11369. qjsf.setCic_result_desc("合格");
  11370. mapper.updateQcmJudgeChemical(qjsf);*/
  11371. }
  11372. //更改合同与试样表
  11373. if(list1.size() >0 || list2.size() >0 || list3.size()>0){
  11374. if(list1.size()>0){
  11375. for(HashMap lists:list1){
  11376. if(!lists.get("JUDGERESULT").toString().equals("0")){
  11377. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  11378. }
  11379. }
  11380. ZjResultAll zra = new ZjResultAll();
  11381. if(param1.get(6).toString().contains("C")){
  11382. zra.setBilletid_jy(list1.get(0).get("BILLETID_JY").toString());
  11383. zra.setCic_is_lock("2");
  11384. zra.setChemresult("1");
  11385. zra.setChemresult_desc("合格");
  11386. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list1.get(0).get("BILLETID_JY").toString()+"' and JUDGE_STATUS = '0'");
  11387. if(qjsrt.size() > 0){
  11388. throw new Exception("该检验号下存在未判信息,不能放行!");
  11389. }
  11390. mapper.UpdateJugeResultB(zra);
  11391. //PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  11392. //QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  11393. for(HashMap lists:list1){
  11394. //质量异常材处置
  11395. qjl = new QCMJudgeLocking();
  11396. qjl.setUnlock_type_code("0");
  11397. qjl.setUnlock_type_desc("放行");
  11398. qjl.setUnlock_memo(param1.get(4).toString());
  11399. qjl.setUnlock_result(param1.get(9).toString());
  11400. qjl.setCic_locking("2");
  11401. qjl.setBatch_no(qjls.get(0).getBatch_no());
  11402. //qjl.setMaterial_no(lists.get("BILLETID").toString());
  11403. qjl.setUnlock_name(param1.get(5).toString());
  11404. qjl.setLock_id(param1.get(6).toString());
  11405. qjl.setReason_code(param1.get(7).toString());
  11406. qjl.setLock_type_code(param1.get(2).toString());
  11407. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  11408. if(listsu.size() >0)
  11409. {
  11410. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  11411. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  11412. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  11413. }
  11414. mapper.UpdateQcmJudgeLocking3(qjl);
  11415. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11416. qjog.setOperate_name(param1.get(5).toString());
  11417. qjog.setOperate_type("成分放行");
  11418. qjog.setParams(param1.get(0).toString());
  11419. qjog.setBatchno(qjl.getBatch_no());
  11420. qjog.setProd_line(qjl.getPline_code());
  11421. mapper.insertQcmJudgeOperateLog(qjog);
  11422. QcmJudgeLog qjlt = new QcmJudgeLog();
  11423. qjlt.setJudge_type("R");
  11424. qjlt.setMaterial_no(lists.get("BILLETID_JY").toString());
  11425. qjlt.setCreate_name("system");
  11426. qjlt.setMaterial_type("1");
  11427. qjlt.setProd_line(qjl.getPline_code());
  11428. mapper.insertQcmJudgeLog(qjlt);
  11429. }
  11430. SqlSession.commit();
  11431. }else{
  11432. zra.setBilletid(param1.get(0).toString());
  11433. zra.setR_cic_is_lock("2");
  11434. zra.setR_chemresult("1");
  11435. zra.setR_chemresult_desc("合格");
  11436. mapper.UpdateJugeResultB(zra);
  11437. qjl.setUnlock_name(param1.get(5).toString());
  11438. qjl.setReason_code(param1.get(7).toString());
  11439. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  11440. if(listsu.size() >0)
  11441. {
  11442. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  11443. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  11444. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  11445. }
  11446. mapper.UpdateQcmJudgeLocking(qjl);
  11447. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11448. qjog.setOperate_name(param1.get(5).toString());
  11449. qjog.setOperate_type("成分放行");
  11450. qjog.setParams(param1.get(0).toString());
  11451. qjog.setBatchno(qjl.getBatch_no());
  11452. qjog.setProd_line(qjl.getPline_code());
  11453. mapper.insertQcmJudgeOperateLog(qjog);
  11454. QcmJudgeLog qjlt = new QcmJudgeLog();
  11455. qjlt.setJudge_type("U");
  11456. qjlt.setMaterial_no(param1.get(0).toString());
  11457. qjlt.setCreate_name("system");
  11458. qjlt.setProd_line(qjl.getPline_code());
  11459. qjlt.setProd_line(qjl.getPline_code());
  11460. mapper.insertQcmJudgeLog(qjlt);
  11461. SqlSession.commit();
  11462. }
  11463. }else if(list2.size() >0){
  11464. for(HashMap lists:list2){
  11465. if(!lists.get("JUDGERESULT").toString().equals("0")){
  11466. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  11467. }
  11468. }
  11469. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  11470. zra.setCoil_no(param1.get(0).toString());
  11471. if(param1.get(6).toString().contains("C")){
  11472. zra.setCic_is_lock("2");
  11473. zra.setChemresult("1");
  11474. zra.setChemresult_desc("合格");
  11475. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  11476. if(qjsrt.size() > 0){
  11477. throw new Exception("该检验号下存在未判信息,不能放行!");
  11478. }
  11479. mapper.UpdateJugeResultJ(zra);
  11480. //PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  11481. //QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  11482. for(HashMap lists:list2){
  11483. //质量异常材处置
  11484. qjl = new QCMJudgeLocking();
  11485. qjl.setUnlock_type_code("0");
  11486. qjl.setUnlock_type_desc("放行");
  11487. qjl.setUnlock_memo(param1.get(4).toString());
  11488. qjl.setUnlock_result(param1.get(9).toString());
  11489. qjl.setCic_locking("2");
  11490. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  11491. qjl.setBatch_no(qjls.get(0).getBatch_no());
  11492. qjl.setUnlock_name(param1.get(5).toString());
  11493. qjl.setLock_id(param1.get(6).toString());
  11494. qjl.setReason_code(param1.get(7).toString());
  11495. qjl.setLock_type_code(param1.get(2).toString());
  11496. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  11497. if(listsu.size() >0)
  11498. {
  11499. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  11500. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  11501. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  11502. }
  11503. mapper.UpdateQcmJudgeLocking3(qjl);
  11504. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11505. qjog.setOperate_name(param1.get(5).toString());
  11506. qjog.setOperate_type("成分放行");
  11507. qjog.setParams(param1.get(0).toString());
  11508. qjog.setBatchno(qjl.getBatch_no());
  11509. qjog.setProd_line(qjl.getPline_code());
  11510. mapper.insertQcmJudgeOperateLog(qjog);
  11511. QcmJudgeLog qjlt = new QcmJudgeLog();
  11512. qjlt.setJudge_type("R");
  11513. qjlt.setMaterial_no(lists.get("INSPECTION_LOT").toString());
  11514. qjlt.setCreate_name("system");
  11515. qjlt.setMaterial_type("1");
  11516. qjlt.setProd_line(qjl.getPline_code());
  11517. mapper.insertQcmJudgeLog(qjlt);
  11518. }
  11519. SqlSession.commit();
  11520. }else{
  11521. zra.setR_cic_is_lock("2");
  11522. zra.setR_chemresult("1");
  11523. zra.setR_chemresult_desc("合格");
  11524. mapper.UpdateJugeResultJ(zra);
  11525. qjl.setUnlock_name(param1.get(5).toString());
  11526. qjl.setReason_code(param1.get(7).toString());
  11527. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  11528. if(listsu.size() >0)
  11529. {
  11530. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  11531. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  11532. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  11533. }
  11534. mapper.UpdateQcmJudgeLocking(qjl);
  11535. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11536. qjog.setOperate_name(param1.get(5).toString());
  11537. qjog.setOperate_type("成分放行");
  11538. qjog.setParams(param1.get(0).toString());
  11539. qjog.setBatchno(qjl.getBatch_no());
  11540. qjog.setProd_line(qjl.getPline_code());
  11541. mapper.insertQcmJudgeOperateLog(qjog);
  11542. QcmJudgeLog qjlt = new QcmJudgeLog();
  11543. qjlt.setJudge_type("U");
  11544. qjlt.setMaterial_no(param1.get(0).toString());
  11545. qjlt.setCreate_name("system");
  11546. qjlt.setProd_line(qjl.getPline_code());
  11547. mapper.insertQcmJudgeLog(qjlt);
  11548. SqlSession.commit();
  11549. }
  11550. }else{
  11551. for(HashMap lists:list3){
  11552. if(!lists.get("JUDGERESULT").toString().equals("0")){
  11553. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  11554. }
  11555. }
  11556. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  11557. zra.setCoil_no(param1.get(0).toString());
  11558. if(param1.get(6).toString().contains("C")){
  11559. zra.setCic_is_lock("2");
  11560. zra.setChemresult("1");
  11561. zra.setChemresult_desc("合格");
  11562. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  11563. if(qjsrt.size() > 0){
  11564. throw new Exception("该检验号下存在未判信息,不能放行!");
  11565. }
  11566. mapper.UpdateJugeResultY(zra);
  11567. //PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  11568. //QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  11569. for(HashMap lists:list2){
  11570. //质量异常材处置
  11571. qjl = new QCMJudgeLocking();
  11572. qjl.setUnlock_type_code("0");
  11573. qjl.setUnlock_type_desc("放行");
  11574. qjl.setUnlock_memo(param1.get(4).toString());
  11575. qjl.setUnlock_result(param1.get(9).toString());
  11576. qjl.setCic_locking("2");
  11577. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  11578. qjl.setBatch_no(qjls.get(0).getBatch_no());
  11579. qjl.setUnlock_name(param1.get(5).toString());
  11580. qjl.setLock_id(param1.get(6).toString());
  11581. qjl.setReason_code(param1.get(7).toString());
  11582. qjl.setLock_type_code(param1.get(2).toString());
  11583. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  11584. if(listsu.size() >0)
  11585. {
  11586. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  11587. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  11588. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  11589. }
  11590. mapper.UpdateQcmJudgeLocking3(qjl);
  11591. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11592. qjog.setOperate_name(param1.get(5).toString());
  11593. qjog.setOperate_type("成分放行");
  11594. qjog.setParams(param1.get(0).toString());
  11595. qjog.setBatchno(qjl.getBatch_no());
  11596. qjog.setProd_line(qjl.getPline_code());
  11597. mapper.insertQcmJudgeOperateLog(qjog);
  11598. QcmJudgeLog qjlt = new QcmJudgeLog();
  11599. qjlt.setJudge_type("R");
  11600. qjlt.setMaterial_no(lists.get("INSPECTION_LOT").toString());
  11601. qjlt.setCreate_name("system");
  11602. qjlt.setMaterial_type("1");
  11603. qjlt.setProd_line(qjl.getPline_code());
  11604. mapper.insertQcmJudgeLog(qjlt);
  11605. }
  11606. SqlSession.commit();
  11607. }else{
  11608. zra.setR_cic_is_lock("2");
  11609. zra.setR_chemresult("1");
  11610. zra.setR_chemresult_desc("合格");
  11611. mapper.UpdateJugeResultY(zra);
  11612. qjl.setUnlock_name(param1.get(5).toString());
  11613. qjl.setReason_code(param1.get(7).toString());
  11614. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  11615. if(listsu.size() >0)
  11616. {
  11617. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  11618. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  11619. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  11620. }
  11621. mapper.UpdateQcmJudgeLocking(qjl);
  11622. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11623. qjog.setOperate_name(param1.get(5).toString());
  11624. qjog.setOperate_type("成分放行");
  11625. qjog.setParams(param1.get(0).toString());
  11626. qjog.setBatchno(qjl.getBatch_no());
  11627. qjog.setProd_line(qjl.getPline_code());
  11628. mapper.insertQcmJudgeOperateLog(qjog);
  11629. QcmJudgeLog qjlt = new QcmJudgeLog();
  11630. qjlt.setJudge_type("U");
  11631. qjlt.setMaterial_no(param1.get(0).toString());
  11632. qjlt.setCreate_name("system");
  11633. qjlt.setProd_line(qjl.getPline_code());
  11634. mapper.insertQcmJudgeLog(qjlt);
  11635. SqlSession.commit();
  11636. }
  11637. }
  11638. }else{
  11639. throw new Exception("未找到库存信息!");
  11640. }
  11641. }
  11642. }
  11643. //复样
  11644. if(param1.get(3).toString().equals("1")){
  11645. List<HashMap> hashmap = mapper.doQueryMaterialInfoHB(param1.get(0).toString());
  11646. if(hashmap.size() == 0){
  11647. hashmap = mapper.doQueryMaterialInfoZB(param1.get(0).toString());
  11648. }
  11649. if(hashmap.size() == 0){
  11650. hashmap = mapper.doQueryMaterialInfoX(param1.get(0).toString());
  11651. }
  11652. if(hashmap.size() == 0){
  11653. hashmap = mapper.doQueryMaterialInfoJ(param1.get(0).toString());
  11654. }
  11655. if(hashmap.size() ==0){
  11656. hashmap = mapper.doQueryMaterialInfoY(param1.get(0).toString());
  11657. }
  11658. if(hashmap.size() == 0){
  11659. throw new Exception("找不到库存,不能复样!");
  11660. }
  11661. //重新
  11662. //质量锁定解锁
  11663. sql = "select * from qcm_judge_locking where material_no = '"+param1.get(0).toString()+"' and lock_type_code = '"+param1.get(2).toString()+"' and steel_name = '"+hashmap.get(0).get("STEEL_NAME").toString()+"' and unlock_type_code = '1' ";
  11664. List<QCMJudgeLocking> qjlt = mapper.queryQCMJudgeLockings(sql);
  11665. /*if(qjlt.size() > 0){
  11666. throw new Exception("该产品序号["+param1.get(0).toString()+"]已经做了复样,不能重复复样!");
  11667. }*/
  11668. qjl.setUnlock_type_code("1");
  11669. qjl.setUnlock_type_desc("复样");
  11670. qjl.setUnlock_memo(param1.get(4).toString());
  11671. qjl.setUnlock_name(param1.get(5).toString());
  11672. if(param1.get(2).toString().equals("C") && param1.get(6).toString().contains("C")){
  11673. qjl.setCic_locking("0");
  11674. //更改合同与试样表
  11675. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  11676. if(list1.size()>0){
  11677. for(HashMap lists:list1){
  11678. if(!lists.get("JUDGERESULT").toString().equals("0")){
  11679. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能复样!");
  11680. }
  11681. }
  11682. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list1.get(0).get("BILLETID_JY").toString()+"' and JUDGE_STATUS = '0'");
  11683. if(qjsrt.size() > 0){
  11684. throw new Exception("该检验号下存在未判信息,不能复样!");
  11685. }
  11686. sql = "select * from qcm_judge_locking where batch_no = '"+qjls.get(0).getBatch_no()+"'";
  11687. List<QCMJudgeLocking> qjlf = mapper.queryQCMJudgeLockings(sql);
  11688. for(QCMJudgeLocking qjll:qjlf){
  11689. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11690. qjog.setOperate_name(param1.get(5).toString());
  11691. qjog.setOperate_type("复样");
  11692. qjog.setParams(qjll.getMaterial_no());
  11693. qjog.setBatchno(qjls.get(0).getBatch_no());
  11694. qjog.setProd_line(qjll.getPline_code());
  11695. mapper.insertQcmJudgeOperateLog(qjog);
  11696. }
  11697. ZjResultAll zra = new ZjResultAll();
  11698. zra.setChemresult("0");
  11699. zra.setChemresult_desc("待判");
  11700. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  11701. for(HashMap lists:list1){
  11702. //质量异常材处置
  11703. qjl = new QCMJudgeLocking();
  11704. qjl.setUnlock_type_code("1");
  11705. qjl.setUnlock_type_desc("复样");
  11706. qjl.setUnlock_memo(param1.get(4).toString());
  11707. qjl.setUnlock_result(param1.get(9).toString());
  11708. qjl.setPic_locking("0");
  11709. //qjl.setMaterial_no(lists.get("BILLETID").toString());
  11710. qjl.setBatch_no(qjls.get(0).getBatch_no());
  11711. qjl.setUnlock_name(param1.get(5).toString());
  11712. qjl.setLock_id(param1.get(6).toString());
  11713. qjl.setReason_code(param1.get(7).toString());
  11714. qjl.setLock_type_code(param1.get(2).toString());
  11715. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  11716. if(listsu.size() >0)
  11717. {
  11718. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  11719. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  11720. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  11721. }
  11722. mapper.UpdateQcmJudgeLocking1(qjl);
  11723. }
  11724. SendGenerationSampleInfo("",hashmap,param1,"1","0","");
  11725. mapper.UpdateJugeResultB(zra);
  11726. SqlSession.commit();
  11727. }else if(list2.size() >0){
  11728. for(HashMap lists:list2){
  11729. if(!lists.get("JUDGERESULT").toString().equals("0")){
  11730. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能复样!");
  11731. }
  11732. }
  11733. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("COIL_NO").toString()+"' and JUDGE_STATUS = '0'");
  11734. if(qjsrt.size() > 0){
  11735. throw new Exception("该检验号下存在未判信息,不能复样!");
  11736. }
  11737. sql = "select * from qcm_judge_locking where batch_no = '"+qjls.get(0).getBatch_no()+"'";
  11738. List<QCMJudgeLocking> qjlf = mapper.queryQCMJudgeLockings(sql);
  11739. for(QCMJudgeLocking qjll:qjlf){
  11740. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11741. qjog.setOperate_name(param1.get(5).toString());
  11742. qjog.setOperate_type("复样");
  11743. qjog.setParams(qjll.getMaterial_no());
  11744. qjog.setBatchno(qjls.get(0).getBatch_no());
  11745. qjog.setProd_line(qjll.getPline_code());
  11746. mapper.insertQcmJudgeOperateLog(qjog);
  11747. }
  11748. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  11749. zra.setChemresult("0");
  11750. zra.setChemresult_desc("待判");
  11751. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  11752. for(HashMap lists:list2){
  11753. //质量异常材处置
  11754. qjl = new QCMJudgeLocking();
  11755. qjl.setUnlock_type_code("1");
  11756. qjl.setUnlock_type_desc("复样");
  11757. qjl.setUnlock_memo(param1.get(4).toString());
  11758. qjl.setUnlock_result(param1.get(9).toString());
  11759. qjl.setPic_locking("0");
  11760. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  11761. qjl.setBatch_no(qjls.get(0).getBatch_no());
  11762. qjl.setUnlock_name(param1.get(5).toString());
  11763. qjl.setLock_id(param1.get(6).toString());
  11764. qjl.setReason_code(param1.get(7).toString());
  11765. qjl.setLock_type_code(param1.get(2).toString());
  11766. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  11767. if(listsu.size() >0)
  11768. {
  11769. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  11770. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  11771. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  11772. }
  11773. mapper.UpdateQcmJudgeLocking1(qjl);
  11774. }
  11775. SendGenerationSampleInfo("",hashmap,param1,"1","0","");
  11776. mapper.UpdateJugeResultJ(zra);
  11777. SqlSession.commit();
  11778. }else{
  11779. for(HashMap lists:list3){
  11780. if(!lists.get("JUDGERESULT").toString().equals("0")){
  11781. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能复样!");
  11782. }
  11783. }
  11784. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list3.get(0).get("COIL_NO").toString()+"' and JUDGE_STATUS = '0'");
  11785. if(qjsrt.size() > 0){
  11786. throw new Exception("该检验号下存在未判信息,不能复样!");
  11787. }
  11788. sql = "select * from qcm_judge_locking where batch_no = '"+qjls.get(0).getBatch_no()+"'";
  11789. List<QCMJudgeLocking> qjlf = mapper.queryQCMJudgeLockings(sql);
  11790. for(QCMJudgeLocking qjll:qjlf){
  11791. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11792. qjog.setOperate_name(param1.get(5).toString());
  11793. qjog.setOperate_type("复样");
  11794. qjog.setParams(qjll.getMaterial_no());
  11795. qjog.setBatchno(qjls.get(0).getBatch_no());
  11796. qjog.setProd_line(qjll.getPline_code());
  11797. mapper.insertQcmJudgeOperateLog(qjog);
  11798. }
  11799. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  11800. zra.setChemresult("0");
  11801. zra.setChemresult_desc("待判");
  11802. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  11803. for(HashMap lists:list3){
  11804. //质量异常材处置
  11805. qjl = new QCMJudgeLocking();
  11806. qjl.setUnlock_type_code("1");
  11807. qjl.setUnlock_type_desc("复样");
  11808. qjl.setUnlock_memo(param1.get(4).toString());
  11809. qjl.setUnlock_result(param1.get(9).toString());
  11810. qjl.setPic_locking("0");
  11811. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  11812. qjl.setBatch_no(qjls.get(0).getBatch_no());
  11813. qjl.setUnlock_name(param1.get(5).toString());
  11814. qjl.setLock_id(param1.get(6).toString());
  11815. qjl.setReason_code(param1.get(7).toString());
  11816. qjl.setLock_type_code(param1.get(2).toString());
  11817. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  11818. if(listsu.size() >0)
  11819. {
  11820. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  11821. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  11822. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  11823. }
  11824. mapper.UpdateQcmJudgeLocking1(qjl);
  11825. }
  11826. SendGenerationSampleInfo("",hashmap,param1,"1","0","");
  11827. mapper.UpdateJugeResultY(zra);
  11828. SqlSession.commit();
  11829. }
  11830. }else{
  11831. throw new Exception("未找到库存信息!");
  11832. }
  11833. }else if(param1.get(2).toString().equals("P")){
  11834. qjl.setPic_locking("0");
  11835. List<QcmJudgePhysical> list = mapper.queryQcmJudgePhysical("select * from qcm_judge_physical where phy_id = '"+param1.get(6).toString()+"'");
  11836. //更新库存表
  11837. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  11838. if(list1.size()>0){
  11839. for(HashMap lists:list1){
  11840. if(!lists.get("JUDGERESULT").toString().equals("0")){
  11841. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能复样!");
  11842. }
  11843. }
  11844. ZjResultAll zra = new ZjResultAll();
  11845. if(list.get(0).getCert_inst_name().equals("检测中心"))
  11846. {
  11847. zra.setPhyfstsresult("0");
  11848. zra.setPhyfstsresult_desc("");
  11849. }
  11850. zra.setPhysresult("0");
  11851. zra.setPhysresult_desc("");
  11852. zra.setPic_is_lock("0");
  11853. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list1.get(0).get("BILLETID_JY").toString()+"' and JUDGE_STATUS = '0'");
  11854. if(qjsrt.size() > 0 && !param1.get(0).toString().startsWith("Z") && !param1.get(0).toString().startsWith("H")){
  11855. throw new Exception("该检验号下存在未判信息,不能复样!");
  11856. }
  11857. sql = "select * from qcm_jhy_sample_r_ord z where z.smp_no in (select a.smp_no from qcm_judge_physical a where a.phy_id = '"+param1.get(6).toString()+"') and z.duplicate_sample = '复样'";
  11858. List<HashMap> listF= mapper.query(sql);
  11859. if(listF.size() >0){
  11860. throw new Exception("已复样的不能复样!");
  11861. }
  11862. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  11863. sql = "SELECT * FROM QCM_JHY_SAMPLE_CONSIGN_D A WHERE A.INSPECTION_LOT = '"+list1.get(0).get("BILLETID_JY").toString()+"' and a.phy_item like '%夹杂%'";
  11864. List<HashMap> listd1 = mapper.query(sql);
  11865. for(HashMap lists:list1){
  11866. if((param1.get(0).toString().startsWith("H") || param1.get(0).toString().startsWith("Z")) && qjl.getLock_memo().contains("夹杂") && listd1.get(0).get("FREQ_CODE").equals("D")){
  11867. List<HashMap> listd = mapper.query("select t.* from QCM_JHY_SAMPLE_CONSIGN_D t where substr(t.HEAT_NO,0,9) = substr('"+list.get(0).getHeat_no()+"',0,9) and t.FREQ_CODE = 'D' and t.smp_type_code = '0' and T.QUOTE_CONSIGN_NO is null and rownum <=1");
  11868. /*if(listd.get(0).get("BATCH_NO").toString().equals(qjl.getBatch_no())){
  11869. throw new Exception("夹杂不能选择初样不合格的轧批进行复样!");
  11870. }*/
  11871. //非初样轧批质量异常材处置
  11872. qjl = new QCMJudgeLocking();
  11873. qjl.setUnlock_type_code("1");
  11874. qjl.setUnlock_type_desc("复样");
  11875. qjl.setUnlock_memo(param1.get(4).toString());
  11876. qjl.setUnlock_result(param1.get(9).toString());
  11877. qjl.setPic_locking("0");
  11878. qjl.setHeat_no(list.get(0).getHeat_no());
  11879. //qjl.setMaterial_no(lists.get("BILLETID").toString());
  11880. qjl.setBatch_no(listd.get(0).get("BATCH_NO").toString());
  11881. qjl.setUnlock_name(param1.get(5).toString());
  11882. qjl.setLock_id(param1.get(6).toString());
  11883. qjl.setReason_code(param1.get(7).toString());
  11884. qjl.setLock_type_code(param1.get(2).toString());
  11885. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  11886. if(listsu.size() >0)
  11887. {
  11888. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  11889. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  11890. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  11891. }
  11892. mapper.UpdateQcmJudgeLocking7(qjl);
  11893. sql = "select * from qcm_judge_locking where batch_no = '"+qjls.get(0).getBatch_no()+"'";
  11894. List<QCMJudgeLocking> qjlf = mapper.queryQCMJudgeLockings(sql);
  11895. for(QCMJudgeLocking qjll:qjlf){
  11896. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11897. qjog.setOperate_name(param1.get(5).toString());
  11898. qjog.setOperate_type("复样");
  11899. qjog.setParams(qjll.getMaterial_no());
  11900. qjog.setBatchno(qjls.get(0).getBatch_no());
  11901. qjog.setProd_line(qjll.getPline_code());
  11902. mapper.insertQcmJudgeOperateLog(qjog);
  11903. }
  11904. //初样质量异常材处置
  11905. qjl = new QCMJudgeLocking();
  11906. qjl.setUnlock_type_code("0");
  11907. qjl.setUnlock_type_desc("待判");
  11908. qjl.setUnlock_memo("初样取样批号不可复样");
  11909. qjl.setPic_locking("0");
  11910. //qjl.setMaterial_no(lists.get("BILLETID").toString());
  11911. qjl.setBatch_no(listd.get(0).get("BATCH_NO").toString());
  11912. qjl.setUnlock_name(param1.get(5).toString());
  11913. qjl.setLock_id(param1.get(6).toString());
  11914. qjl.setReason_code(param1.get(7).toString());
  11915. qjl.setLock_type_code(param1.get(2).toString());
  11916. qjl.setLock_name(param1.get(5).toString());
  11917. listsu = qjft.finddefecttype(param1.get(7).toString());
  11918. if(listsu.size() >0)
  11919. {
  11920. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  11921. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  11922. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  11923. }
  11924. List<QCMJudgeLocking> qjl2 = mapper.queryQCMJudgeLockings("select * from qcm_judge_locking x where substr(x.heat_no,0,9) = substr('"+list.get(0).getHeat_no()+"',0,9) and batch_no <> '"+list.get(0).getBatch_no()+"' and unlock_type_code is null");
  11925. for(QCMJudgeLocking qjl22 : qjl2){
  11926. zra.setBilletid(qjl22.getMaterial_no());
  11927. mapper.UpdateJugeResultB(zra);
  11928. }
  11929. List<QCMJudgeLocking> qjl3 = mapper.queryQCMJudgeLockings("select * from qcm_judge_locking x where substr(x.heat_no,0,9) = substr('"+list.get(0).getHeat_no()+"',0,9) and batch_no = '"+list.get(0).getBatch_no()+"' and unlock_type_code is null");
  11930. mapper.UpdateQcmJudgeLocking1(qjl);
  11931. for(QCMJudgeLocking qjl22 : qjl3){
  11932. int count = 0;
  11933. String condition = " and MATERIAL_NO = '"+qjl22.getMaterial_no()+"' order by LOCK_SEQ desc ";
  11934. List<QCMJudgeLocking> qjlk = mapper.queryQCMJudgeLocking(condition);
  11935. if(qjlk.size() > 0){
  11936. count=qjlk.get(0).getLock_seq();
  11937. }
  11938. count++;
  11939. //锁定记录号
  11940. int lock_seq=count;
  11941. qjl22.setLock_seq(lock_seq);
  11942. qjl22.setUnlock_type_code("");
  11943. qjl22.setUnlock_type_desc("");
  11944. qjl22.setLock_memo("待判");
  11945. qjl22.setTarget_design_key("");
  11946. qjl22.setUnlock_name("");
  11947. mapper.insertQCMJudgeLocking(qjl22);
  11948. }
  11949. //param1.set(6, listd.get(0).get("SMP_NO").toString());
  11950. SendGenerationSampleInfo2(listd.get(0).get("BATCH_NO").toString(),hashmap,param1,"1","1",listd.get(0).get("SMP_NO").toString(),"1");
  11951. }else{
  11952. //质量异常材处置
  11953. qjl = new QCMJudgeLocking();
  11954. qjl.setUnlock_type_code("1");
  11955. qjl.setUnlock_type_desc("复样");
  11956. qjl.setUnlock_memo(param1.get(4).toString());
  11957. qjl.setUnlock_result(param1.get(9).toString());
  11958. qjl.setPic_locking("0");
  11959. //qjl.setMaterial_no(lists.get("BILLETID").toString());
  11960. qjl.setBatch_no(qjls.get(0).getBatch_no());
  11961. qjl.setUnlock_name(param1.get(5).toString());
  11962. if(param1.get(0).toString().startsWith("H") || param1.get(0).toString().startsWith("Z")){
  11963. qjl.setLock_id(param1.get(6).toString());
  11964. }
  11965. qjl.setReason_code(param1.get(7).toString());
  11966. qjl.setLock_type_code(param1.get(2).toString());
  11967. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  11968. if(listsu.size() >0)
  11969. {
  11970. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  11971. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  11972. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  11973. }
  11974. mapper.UpdateQcmJudgeLocking1(qjl);
  11975. SendGenerationSampleInfo("",hashmap,param1,"1","1","2");
  11976. zra.setBilletid_jy(list1.get(0).get("BILLETID_JY").toString());
  11977. mapper.UpdateJugeResultB(zra);
  11978. sql = "select * from qcm_judge_locking where batch_no = '"+qjls.get(0).getBatch_no()+"'";
  11979. List<QCMJudgeLocking> qjlf = mapper.queryQCMJudgeLockings(sql);
  11980. for(QCMJudgeLocking qjll:qjlf){
  11981. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  11982. qjog.setOperate_name(param1.get(5).toString());
  11983. qjog.setOperate_type("复样");
  11984. qjog.setParams(qjll.getMaterial_no());
  11985. qjog.setBatchno(qjls.get(0).getBatch_no());
  11986. qjog.setProd_line(qjll.getPline_code());
  11987. mapper.insertQcmJudgeOperateLog(qjog);
  11988. }
  11989. }
  11990. }
  11991. SqlSession.commit();
  11992. }else if(list2.size() >0){
  11993. for(HashMap lists:list2){
  11994. if(!lists.get("JUDGERESULT").toString().equals("0")){
  11995. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能复样!");
  11996. }
  11997. }
  11998. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  11999. if(list.get(0).getCert_inst_name().equals("检测中心"))
  12000. {
  12001. zra.setPhyfstsresult("0");
  12002. zra.setPhyfstsresult_desc("");
  12003. }
  12004. zra.setPhysresult("0");
  12005. zra.setPhysresult_desc("");
  12006. zra.setInspection_lot(list2.get(0).get("INSPECTION_LOT").toString());
  12007. zra.setPic_is_lock("0");
  12008. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("COIL_NO").toString()+"' and JUDGE_STATUS = '0'");
  12009. if(qjsrt.size() > 0){
  12010. throw new Exception("该检验号下存在未判信息,不能复样!");
  12011. }
  12012. sql = "select * from qcm_jhy_sample_r_ord z where z.smp_no in (select a.smp_no from qcm_judge_physical a where a.phy_id = '"+param1.get(6).toString()+"') and z.duplicate_sample = '复样'";
  12013. List<HashMap> listF= mapper.query(sql);
  12014. if(listF.size() >0){
  12015. throw new Exception("已复样的不能复样!");
  12016. }
  12017. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  12018. for(HashMap lists:list2){
  12019. //质量异常材处置
  12020. qjl = new QCMJudgeLocking();
  12021. qjl.setUnlock_type_code("1");
  12022. qjl.setUnlock_type_desc("复样");
  12023. qjl.setUnlock_memo(param1.get(4).toString());
  12024. qjl.setUnlock_result(param1.get(9).toString());
  12025. qjl.setPic_locking("0");
  12026. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  12027. qjl.setBatch_no(qjls.get(0).getBatch_no());
  12028. qjl.setUnlock_name(param1.get(5).toString());
  12029. qjl.setLock_id(param1.get(6).toString());
  12030. qjl.setReason_code(param1.get(7).toString());
  12031. qjl.setLock_type_code(param1.get(2).toString());
  12032. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12033. if(listsu.size() >0)
  12034. {
  12035. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12036. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12037. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12038. }
  12039. mapper.UpdateQcmJudgeLocking1(qjl);
  12040. sql = "select * from qcm_judge_locking where batch_no = '"+qjls.get(0).getBatch_no()+"'";
  12041. List<QCMJudgeLocking> qjlf = mapper.queryQCMJudgeLockings(sql);
  12042. for(QCMJudgeLocking qjll:qjlf){
  12043. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  12044. qjog.setOperate_name(param1.get(5).toString());
  12045. qjog.setOperate_type("复样");
  12046. qjog.setParams(qjll.getMaterial_no());
  12047. qjog.setBatchno(qjls.get(0).getBatch_no());
  12048. qjog.setProd_line(qjll.getPline_code());
  12049. mapper.insertQcmJudgeOperateLog(qjog);
  12050. }
  12051. }
  12052. //QcmJhyPhyresultServiceImpl qjps = new QcmJhyPhyresultServiceImpl();
  12053. SendGenerationSampleInfo("",hashmap,param1,"1","1","");
  12054. mapper.UpdateJugeResultJ(zra);
  12055. SqlSession.commit();
  12056. }else{
  12057. for(HashMap lists:list3){
  12058. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12059. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能复样!");
  12060. }
  12061. }
  12062. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  12063. if(list.get(0).getCert_inst_name().equals("检测中心"))
  12064. {
  12065. zra.setPhyfstsresult("0");
  12066. zra.setPhyfstsresult_desc("");
  12067. }
  12068. zra.setPhysresult("0");
  12069. zra.setPhysresult_desc("");
  12070. zra.setInspection_lot(list3.get(0).get("INSPECTION_LOT").toString());
  12071. zra.setPic_is_lock("0");
  12072. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list3.get(0).get("COIL_NO").toString()+"' and JUDGE_STATUS = '0'");
  12073. if(qjsrt.size() > 0){
  12074. throw new Exception("该检验号下存在未判信息,不能复样!");
  12075. }
  12076. sql = "select * from qcm_jhy_sample_r_ord z where z.smp_no in (select a.smp_no from qcm_judge_physical a where a.phy_id = '"+param1.get(6).toString()+"') and z.duplicate_sample = '复样'";
  12077. List<HashMap> listF= mapper.query(sql);
  12078. if(listF.size() >0){
  12079. throw new Exception("已复样的不能复样!");
  12080. }
  12081. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  12082. for(HashMap lists:list3){
  12083. //质量异常材处置
  12084. qjl = new QCMJudgeLocking();
  12085. qjl.setUnlock_type_code("1");
  12086. qjl.setUnlock_type_desc("复样");
  12087. qjl.setUnlock_memo(param1.get(4).toString());
  12088. qjl.setUnlock_result(param1.get(9).toString());
  12089. qjl.setPic_locking("0");
  12090. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  12091. qjl.setBatch_no(qjls.get(0).getBatch_no());
  12092. qjl.setUnlock_name(param1.get(5).toString());
  12093. qjl.setLock_id(param1.get(6).toString());
  12094. qjl.setReason_code(param1.get(7).toString());
  12095. qjl.setLock_type_code(param1.get(2).toString());
  12096. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12097. if(listsu.size() >0)
  12098. {
  12099. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12100. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12101. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12102. }
  12103. mapper.UpdateQcmJudgeLocking1(qjl);
  12104. sql = "select * from qcm_judge_locking where batch_no = '"+qjls.get(0).getBatch_no()+"'";
  12105. List<QCMJudgeLocking> qjlf = mapper.queryQCMJudgeLockings(sql);
  12106. for(QCMJudgeLocking qjll:qjlf){
  12107. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  12108. qjog.setOperate_name(param1.get(5).toString());
  12109. qjog.setOperate_type("复样");
  12110. qjog.setParams(qjll.getMaterial_no());
  12111. qjog.setBatchno(qjls.get(0).getBatch_no());
  12112. qjog.setProd_line(qjll.getPline_code());
  12113. mapper.insertQcmJudgeOperateLog(qjog);
  12114. }
  12115. }
  12116. //QcmJhyPhyresultServiceImpl qjps = new QcmJhyPhyresultServiceImpl();
  12117. SendGenerationSampleInfo("",hashmap,param1,"1","1","");
  12118. mapper.UpdateJugeResultY(zra);
  12119. SqlSession.commit();
  12120. }
  12121. }else{
  12122. throw new Exception("未找到库存信息!");
  12123. }
  12124. }else{
  12125. throw new Exception("封锁来源与所选的异常材处置操作不一致,请重新选择处置操作!");
  12126. }
  12127. //
  12128. }
  12129. //判次
  12130. if(param1.get(3).toString().equals("4")){
  12131. qjl.setUnlock_type_code("4");
  12132. qjl.setUnlock_type_desc("判次");
  12133. qjl.setUnlock_memo(param1.get(4).toString());
  12134. qjl.setUnlock_name(param1.get(5).toString());
  12135. //判断产线是不是卷板,是的话调用存储过程COILJUDGE_STATUS
  12136. if(list2.size() > 0) {
  12137. /*List<HashMap> hashmap2 = qjms.doQueryMaterialInfoJ(param1.get(0).toString());
  12138. if (hashmap2.size() > 0) {
  12139. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  12140. if(param1.get(2).toString().equals("C")){
  12141. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), "3", null, null, null, "3", null, null,"");
  12142. } else if(param1.get(2).toString().equals("P")){
  12143. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), null, "3", null, null, "3", null, null,"");
  12144. } else if(param1.get(2).toString().equals("S")){
  12145. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), null, null, "3", null, "3", null, null,"");
  12146. } else if(param1.get(2).toString().equals("F")){
  12147. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), null, null, null, "3", "3", null, null,"");
  12148. }
  12149. }*/
  12150. if(param1.get(2).toString().equals("C")){
  12151. coiljudge_status_call(qjl.getPline_code().toString(), param1.get(0).toString(), "1", null, null, null, null, null, null,"");
  12152. } else if(param1.get(2).toString().equals("P")){
  12153. coiljudge_status_call(qjl.getPline_code().toString().toString(), param1.get(0).toString(), null, "1", null, null, null, null, null,"");
  12154. } else if(param1.get(2).toString().equals("S")){
  12155. coiljudge_status_call(qjl.getPline_code().toString().toString(), param1.get(0).toString(), null, null, "1", null, null, null, null,"");
  12156. } else if(param1.get(2).toString().equals("F")){
  12157. coiljudge_status_call(qjl.getPline_code().toString().toString(), param1.get(0).toString(), null, null, null, "1", null, null, null,"");
  12158. }
  12159. }
  12160. if(param1.get(2).toString().equals("P")){
  12161. qjl.setPic_locking("0");
  12162. //修改库存锁定
  12163. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  12164. if(list1.size()>0){
  12165. for(HashMap lists:list1){
  12166. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12167. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判次!");
  12168. }
  12169. }
  12170. ZjResultAll zra = new ZjResultAll();
  12171. if(param1.get(6).toString().equals(list1.get(0).get("PHYFSTSID"))){
  12172. zra.setPhyfstsresult("3");
  12173. zra.setPhyfstsresult_desc("判次");
  12174. }
  12175. zra.setPhysresult("3");
  12176. zra.setPhysresult_desc("判次");
  12177. zra.setBilletid(param1.get(0).toString());
  12178. //zra.setBilletid_jy(list1.get(0).get("BILLETID_JY").toString());
  12179. zra.setPic_is_lock("0");
  12180. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list1.get(0).get("BILLETID_JY").toString()+"' and JUDGE_STATUS = '0'");
  12181. if(qjsrt.size() > 0){
  12182. throw new Exception("该检验号下存在未判信息,不能判次!");
  12183. }
  12184. mapper.UpdateJugeResultB(zra);
  12185. qjl.setMaterial_no(param1.get(0).toString());
  12186. //qjl.setLock_id(param1.get(6).toString());
  12187. qjl.setReason_code(param1.get(7).toString());
  12188. qjl.setLock_type_code(param1.get(2).toString());
  12189. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12190. if(listsu.size() >0)
  12191. {
  12192. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12193. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12194. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12195. }
  12196. mapper.UpdateQcmJudgeLocking8(qjl);
  12197. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  12198. qjog.setOperate_name(param1.get(5).toString());
  12199. qjog.setOperate_type("判次");
  12200. qjog.setParams(param1.get(0).toString());
  12201. qjog.setBatchno(qjls.get(0).getBatch_no());
  12202. qjog.setProd_line(qjl.getPline_code());
  12203. mapper.insertQcmJudgeOperateLog(qjog);
  12204. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"3");
  12205. //脱单
  12206. order_down(param1.get(0).toString(),"判次");
  12207. SqlSession.commit();
  12208. }else if(list2.size() >0){
  12209. for(HashMap lists:list2){
  12210. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12211. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  12212. }
  12213. }
  12214. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  12215. if(param1.get(6).toString().equals(list2.get(0).get("PHYFSTSID").toString())){
  12216. zra.setPhyfstsresult("3");
  12217. zra.setPhyfstsresult_desc("判次");
  12218. }
  12219. zra.setCoil_no(param1.get(0).toString());
  12220. //zra.setInspection_lot(list2.get(0).get("INSPECTION_LOT").toString());
  12221. zra.setPic_is_lock("0");
  12222. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  12223. if(qjsrt.size() > 0){
  12224. throw new Exception("该检验号下存在未判信息,不能判次!");
  12225. }
  12226. mapper.UpdateJugeResultJ(zra);
  12227. PhyUtmJudge(qjl.getDesign_key(),list2.get(0).get("INSPECTION_LOT").toString() , param1.get(5).toString());
  12228. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  12229. qjl.setMaterial_no(param1.get(0).toString());
  12230. //qjl.setLock_id(param1.get(6).toString());
  12231. qjl.setReason_code(param1.get(7).toString());
  12232. qjl.setLock_type_code(param1.get(2).toString());
  12233. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12234. if(listsu.size() >0)
  12235. {
  12236. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12237. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12238. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12239. }
  12240. mapper.UpdateQcmJudgeLocking8(qjl);
  12241. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  12242. qjog.setOperate_name(param1.get(5).toString());
  12243. qjog.setOperate_type("判次");
  12244. qjog.setParams(param1.get(0).toString());
  12245. qjog.setBatchno(qjls.get(0).getBatch_no());
  12246. qjog.setProd_line(qjl.getPline_code());
  12247. mapper.insertQcmJudgeOperateLog(qjog);
  12248. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"3");
  12249. //脱单
  12250. SqlSession.commit();
  12251. }else{
  12252. for(HashMap lists:list3){
  12253. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12254. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  12255. }
  12256. }
  12257. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  12258. if(param1.get(6).toString().equals(list2.get(0).get("PHYFSTSID").toString())){
  12259. zra.setPhyfstsresult("3");
  12260. zra.setPhyfstsresult_desc("判次");
  12261. }
  12262. zra.setCoil_no(param1.get(0).toString());
  12263. //zra.setInspection_lot(list2.get(0).get("INSPECTION_LOT").toString());
  12264. zra.setPic_is_lock("0");
  12265. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  12266. if(qjsrt.size() > 0){
  12267. throw new Exception("该检验号下存在未判信息,不能判次!");
  12268. }
  12269. mapper.UpdateJugeResultY(zra);
  12270. PhyUtmJudge(qjl.getDesign_key(),list2.get(0).get("INSPECTION_LOT").toString() , param1.get(5).toString());
  12271. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  12272. qjl.setMaterial_no(param1.get(0).toString());
  12273. //qjl.setLock_id(param1.get(6).toString());
  12274. qjl.setReason_code(param1.get(7).toString());
  12275. qjl.setLock_type_code(param1.get(2).toString());
  12276. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12277. if(listsu.size() >0)
  12278. {
  12279. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12280. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12281. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12282. }
  12283. mapper.UpdateQcmJudgeLocking8(qjl);
  12284. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  12285. qjog.setOperate_name(param1.get(5).toString());
  12286. qjog.setOperate_type("判次");
  12287. qjog.setParams(param1.get(0).toString());
  12288. qjog.setBatchno(qjls.get(0).getBatch_no());
  12289. qjog.setProd_line(qjl.getPline_code());
  12290. mapper.insertQcmJudgeOperateLog(qjog);
  12291. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"3");
  12292. //脱单
  12293. SqlSession.commit();
  12294. }
  12295. }else{
  12296. throw new Exception("未找到库存信息!");
  12297. }
  12298. }
  12299. if(param1.get(2).toString().equals("C")){
  12300. qjl.setCic_locking("0");
  12301. //更改合同与试样表
  12302. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  12303. if(list1.size()>0){
  12304. for(HashMap lists:list1){
  12305. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12306. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判次!");
  12307. }
  12308. }
  12309. ZjResultAll zra = new ZjResultAll();
  12310. zra.setBilletid(param1.get(0).toString());
  12311. if(param1.get(6).toString().contains("C")){
  12312. zra.setCic_is_lock("0");
  12313. zra.setChemresult("3");
  12314. zra.setChemresult_desc("判次");
  12315. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list1.get(0).get("BILLET_ID").toString()+"' and JUDGE_STATUS = '0'");
  12316. if(qjsrt.size() > 0){
  12317. throw new Exception("该检验号下存在未判信息,不能判次!");
  12318. }
  12319. mapper.UpdateJugeResultB(zra);
  12320. PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  12321. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  12322. //质量异常材处置
  12323. qjl.setMaterial_no(param1.get(0).toString());
  12324. qjl.setUnlock_name(param1.get(5).toString());
  12325. qjl.setUnlock_result(param1.get(9).toString());
  12326. //qjl.setLock_id(param1.get(6).toString());
  12327. qjl.setReason_code(param1.get(7).toString());
  12328. qjl.setLock_type_code(param1.get(2).toString());
  12329. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12330. if(listsu.size() >0)
  12331. {
  12332. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12333. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12334. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12335. }
  12336. mapper.UpdateQcmJudgeLocking8(qjl);
  12337. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"3");
  12338. //脱单
  12339. order_down(param1.get(0).toString(),"判次");
  12340. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  12341. qjog.setOperate_name(param1.get(5).toString());
  12342. qjog.setOperate_type("判次");
  12343. qjog.setParams(param1.get(0).toString());
  12344. qjog.setBatchno(qjls.get(0).getBatch_no());
  12345. qjog.setProd_line(qjl.getPline_code());
  12346. mapper.insertQcmJudgeOperateLog(qjog);
  12347. SqlSession.commit();
  12348. }else{
  12349. zra.setR_cic_is_lock("0");
  12350. zra.setR_chemresult("3");
  12351. zra.setR_chemresult_desc("判次");
  12352. mapper.UpdateJugeResultB(zra);
  12353. qjl.setUnlock_name(param1.get(5).toString());
  12354. qjl.setReason_code(param1.get(7).toString());
  12355. qjl.setLock_id(param1.get(6).toString());
  12356. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12357. if(listsu.size() >0)
  12358. {
  12359. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12360. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12361. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12362. }
  12363. mapper.UpdateQcmJudgeLocking(qjl);
  12364. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"3");
  12365. //脱单
  12366. order_down(param1.get(0).toString(),"判次");
  12367. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  12368. qjog.setOperate_name(param1.get(5).toString());
  12369. qjog.setOperate_type("判次");
  12370. qjog.setParams(param1.get(0).toString());
  12371. qjog.setBatchno(qjls.get(0).getBatch_no());
  12372. qjog.setProd_line(qjl.getPline_code());
  12373. mapper.insertQcmJudgeOperateLog(qjog);
  12374. SqlSession.commit();
  12375. }
  12376. }else if(list2.size() >0){
  12377. throw new Exception("卷板成分不合格不允许判次!");
  12378. /*for(HashMap lists:list2){
  12379. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12380. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  12381. }
  12382. }
  12383. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  12384. zra.setCoil_no(param1.get(0).toString());
  12385. if(param1.get(6).toString().contains("C")){
  12386. zra.setCic_is_lock("0");
  12387. zra.setChemresult("3");
  12388. zra.setChemresult_desc("判次");
  12389. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  12390. if(qjsrt.size() > 0){
  12391. throw new Exception("该检验号下存在未判信息,不能判次!");
  12392. }
  12393. mapper.UpdateJugeResultJ(zra);
  12394. PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  12395. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  12396. qjl.setMaterial_no(param1.get(0).toString());
  12397. qjl.setUnlock_name(param1.get(5).toString());
  12398. //qjl.setLock_id(param1.get(6).toString());
  12399. qjl.setReason_code(param1.get(7).toString());
  12400. qjl.setLock_type_code(param1.get(2).toString());
  12401. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12402. if(listsu.size() >0)
  12403. {
  12404. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12405. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12406. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12407. }
  12408. mapper.UpdateQcmJudgeLocking1(qjl);
  12409. //脱单
  12410. SqlSession.commit();
  12411. }else{
  12412. zra.setR_cic_is_lock("0");
  12413. zra.setR_chemresult("3");
  12414. zra.setR_chemresult_desc("判次");
  12415. mapper.UpdateJugeResultJ(zra);
  12416. qjl.setUnlock_name(param1.get(5).toString());
  12417. qjl.setLock_id(param1.get(6).toString());
  12418. qjl.setMaterial_no(param1.get(0).toString());
  12419. qjl.setReason_code(param1.get(7).toString());
  12420. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12421. if(listsu.size() >0)
  12422. {
  12423. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12424. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12425. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12426. }
  12427. mapper.UpdateQcmJudgeLocking(qjl);
  12428. //脱单
  12429. SqlSession.commit();
  12430. }*/
  12431. }else{
  12432. throw new Exception("卷板成分不合格不允许判次!");
  12433. /*for(HashMap lists:list2){
  12434. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12435. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  12436. }
  12437. }
  12438. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  12439. zra.setCoil_no(param1.get(0).toString());
  12440. if(param1.get(6).toString().contains("C")){
  12441. zra.setCic_is_lock("0");
  12442. zra.setChemresult("3");
  12443. zra.setChemresult_desc("判次");
  12444. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  12445. if(qjsrt.size() > 0){
  12446. throw new Exception("该检验号下存在未判信息,不能判次!");
  12447. }
  12448. mapper.UpdateJugeResultJ(zra);
  12449. PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  12450. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  12451. qjl.setMaterial_no(param1.get(0).toString());
  12452. qjl.setUnlock_name(param1.get(5).toString());
  12453. //qjl.setLock_id(param1.get(6).toString());
  12454. qjl.setReason_code(param1.get(7).toString());
  12455. qjl.setLock_type_code(param1.get(2).toString());
  12456. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12457. if(listsu.size() >0)
  12458. {
  12459. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12460. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12461. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12462. }
  12463. mapper.UpdateQcmJudgeLocking1(qjl);
  12464. //脱单
  12465. SqlSession.commit();
  12466. }else{
  12467. zra.setR_cic_is_lock("0");
  12468. zra.setR_chemresult("3");
  12469. zra.setR_chemresult_desc("判次");
  12470. mapper.UpdateJugeResultJ(zra);
  12471. qjl.setUnlock_name(param1.get(5).toString());
  12472. qjl.setLock_id(param1.get(6).toString());
  12473. qjl.setMaterial_no(param1.get(0).toString());
  12474. qjl.setReason_code(param1.get(7).toString());
  12475. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12476. if(listsu.size() >0)
  12477. {
  12478. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12479. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12480. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12481. }
  12482. mapper.UpdateQcmJudgeLocking(qjl);
  12483. //脱单
  12484. SqlSession.commit();
  12485. }*/
  12486. }
  12487. }else{
  12488. throw new Exception("未找到库存信息!");
  12489. }
  12490. }
  12491. }
  12492. //判废
  12493. if(param1.get(3).toString().equals("5")){
  12494. qjl.setUnlock_type_code("5");
  12495. qjl.setUnlock_type_desc("判废");
  12496. qjl.setUnlock_memo(param1.get(4).toString());
  12497. qjl.setUnlock_result(param1.get(9).toString());
  12498. qjl.setUnlock_name(param1.get(5).toString());
  12499. //判断产线是不是卷板,是的话调用存储过程COILJUDGE_STATUS
  12500. if(list2.size() > 0) {
  12501. /*List<HashMap> hashmap2 = qjms.doQueryMaterialInfoJ(param1.get(0).toString());
  12502. if (hashmap2.size() > 0) {
  12503. //C-成分判定,P-材质判定,S-公差检验,D-探伤检验,F-表面检验
  12504. if(param1.get(2).toString().equals("C")){
  12505. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), "4", null, null, null, "4", null, null,"");
  12506. } else if(param1.get(2).toString().equals("P")){
  12507. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), null, "4", null, null, "4", null, null,"");
  12508. } else if(param1.get(2).toString().equals("S")){
  12509. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), null, null, "4", null, "4", null, null,"");
  12510. } else if(param1.get(2).toString().equals("F")){
  12511. coiljudge_status_call(hashmap2.get(0).get("PLINE_CODE").toString(), param1.get(0).toString(), null, null, null, "4", "4", null, null,"");
  12512. }
  12513. }*/
  12514. if(param1.get(2).toString().equals("C")){
  12515. coiljudge_status_call(qjl.getPline_code().toString(), param1.get(0).toString(), "1", null, null, null, null, null, null,"");
  12516. } else if(param1.get(2).toString().equals("P")){
  12517. coiljudge_status_call(qjl.getPline_code().toString().toString(), param1.get(0).toString(), null, "1", null, null, null, null, null,"");
  12518. } else if(param1.get(2).toString().equals("S")){
  12519. coiljudge_status_call(qjl.getPline_code().toString().toString(), param1.get(0).toString(), null, null, "1", null, null, null, null,"");
  12520. } else if(param1.get(2).toString().equals("F")){
  12521. coiljudge_status_call(qjl.getPline_code().toString().toString(), param1.get(0).toString(), null, null, null, "1", null, null, null,"");
  12522. }
  12523. }
  12524. if(param1.get(2).toString().equals("P")){
  12525. qjl.setPic_locking("0");
  12526. //修改库存锁定
  12527. //更新库存表放行
  12528. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  12529. if(list1.size()>0){
  12530. for(HashMap lists:list1){
  12531. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12532. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判废!");
  12533. }
  12534. }
  12535. ZjResultAll zra = new ZjResultAll();
  12536. if(param1.get(6).toString().equals(list1.get(0).get("PHYFSTSID"))){
  12537. zra.setPhyfstsresult("4");
  12538. zra.setPhyfstsresult_desc("判废");
  12539. }
  12540. zra.setPhysresult("4");
  12541. zra.setPhysresult_desc("判废");
  12542. zra.setBilletid(param1.get(0).toString());
  12543. //zra.setBilletid_jy(list1.get(0).get("BILLETID_JY").toString());
  12544. zra.setPic_is_lock("0");
  12545. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list1.get(0).get("BILLETID_JY").toString()+"' and JUDGE_STATUS = '0'");
  12546. if(qjsrt.size() > 0){
  12547. throw new Exception("该检验号下存在未判信息,不能判废!");
  12548. }
  12549. mapper.UpdateJugeResultB(zra);
  12550. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  12551. qjl.setMaterial_no(param1.get(0).toString());
  12552. qjl.setUnlock_name(param1.get(5).toString());
  12553. //qjl.setLock_id(param1.get(6).toString());
  12554. qjl.setReason_code(param1.get(7).toString());
  12555. qjl.setLock_type_code(param1.get(2).toString());
  12556. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12557. if(listsu.size() >0)
  12558. {
  12559. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12560. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12561. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12562. }
  12563. mapper.UpdateQcmJudgeLocking8(qjl);
  12564. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"4");
  12565. //脱单
  12566. order_down(param1.get(0).toString(),"判废");
  12567. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  12568. qjog.setOperate_name(param1.get(5).toString());
  12569. qjog.setOperate_type("判废");
  12570. qjog.setParams(param1.get(0).toString());
  12571. qjog.setBatchno(qjls.get(0).getBatch_no());
  12572. qjog.setProd_line(qjl.getPline_code());
  12573. mapper.insertQcmJudgeOperateLog(qjog);
  12574. SqlSession.commit();
  12575. }else if(list2.size() >0){
  12576. for(HashMap lists:list2){
  12577. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12578. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  12579. }
  12580. }
  12581. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  12582. if(param1.get(6).toString().equals(list2.get(0).get("PHYFSTSID"))){
  12583. zra.setPhyfstsresult("4");
  12584. zra.setPhyfstsresult_desc("判废");
  12585. }
  12586. zra.setPhysresult("4");
  12587. zra.setPhysresult_desc("判废");
  12588. zra.setCoil_no(param1.get(0).toString());
  12589. //zra.setInspection_lot(list2.get(0).get("INSPECTION_LOT").toString());
  12590. zra.setPic_is_lock("0");
  12591. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  12592. if(qjsrt.size() > 0){
  12593. throw new Exception("该检验号下存在未判信息,不能判废!");
  12594. }
  12595. mapper.UpdateJugeResultJ(zra);
  12596. PhyUtmJudge(qjl.getDesign_key(),list2.get(0).get("INSPECTION_LOT").toString() , param1.get(5).toString());
  12597. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  12598. qjl.setMaterial_no(param1.get(0).toString());
  12599. qjl.setUnlock_name(param1.get(5).toString());
  12600. //qjl.setLock_id(param1.get(6).toString());
  12601. qjl.setReason_code(param1.get(7).toString());
  12602. qjl.setLock_type_code(param1.get(2).toString());
  12603. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12604. if(listsu.size() >0)
  12605. {
  12606. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12607. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12608. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12609. }
  12610. mapper.UpdateQcmJudgeLocking8(qjl);
  12611. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  12612. qjog.setOperate_name(param1.get(5).toString());
  12613. qjog.setOperate_type("判废");
  12614. qjog.setParams(param1.get(0).toString());
  12615. qjog.setBatchno(qjls.get(0).getBatch_no());
  12616. qjog.setProd_line(qjl.getPline_code());
  12617. mapper.insertQcmJudgeOperateLog(qjog);
  12618. //脱单
  12619. SqlSession.commit();
  12620. }else{
  12621. for(HashMap lists:list3){
  12622. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12623. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  12624. }
  12625. }
  12626. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  12627. if(param1.get(6).toString().equals(list2.get(0).get("PHYFSTSID"))){
  12628. zra.setPhyfstsresult("4");
  12629. zra.setPhyfstsresult_desc("判废");
  12630. }
  12631. zra.setPhysresult("4");
  12632. zra.setPhysresult_desc("判废");
  12633. zra.setCoil_no(param1.get(0).toString());
  12634. //zra.setInspection_lot(list2.get(0).get("INSPECTION_LOT").toString());
  12635. zra.setPic_is_lock("0");
  12636. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  12637. if(qjsrt.size() > 0){
  12638. throw new Exception("该检验号下存在未判信息,不能判废!");
  12639. }
  12640. mapper.UpdateJugeResultY(zra);
  12641. PhyUtmJudge(qjl.getDesign_key(),list2.get(0).get("INSPECTION_LOT").toString() , param1.get(5).toString());
  12642. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  12643. qjl.setMaterial_no(param1.get(0).toString());
  12644. qjl.setUnlock_name(param1.get(5).toString());
  12645. //qjl.setLock_id(param1.get(6).toString());
  12646. qjl.setReason_code(param1.get(7).toString());
  12647. qjl.setLock_type_code(param1.get(2).toString());
  12648. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12649. if(listsu.size() >0)
  12650. {
  12651. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12652. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12653. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12654. }
  12655. mapper.UpdateQcmJudgeLocking8(qjl);
  12656. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  12657. qjog.setOperate_name(param1.get(5).toString());
  12658. qjog.setOperate_type("判废");
  12659. qjog.setParams(param1.get(0).toString());
  12660. qjog.setBatchno(qjls.get(0).getBatch_no());
  12661. qjog.setProd_line(qjl.getPline_code());
  12662. mapper.insertQcmJudgeOperateLog(qjog);
  12663. //脱单
  12664. SqlSession.commit();
  12665. }
  12666. }else{
  12667. throw new Exception("未找到库存信息!");
  12668. }
  12669. }
  12670. if(param1.get(2).toString().equals("C")){
  12671. qjl.setCic_locking("0");
  12672. //更改合同与试样表
  12673. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  12674. if(list1.size()>0){
  12675. for(HashMap lists:list1){
  12676. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12677. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能判废!");
  12678. }
  12679. }
  12680. ZjResultAll zra = new ZjResultAll();
  12681. zra.setBilletid(param1.get(0).toString());
  12682. if(param1.get(6).toString().contains("C")){
  12683. zra.setCic_is_lock("0");
  12684. zra.setChemresult("4");
  12685. zra.setChemresult_desc("判废");
  12686. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list1.get(0).get("BILLET_ID").toString()+"' and JUDGE_STATUS = '0'");
  12687. if(qjsrt.size() > 0){
  12688. throw new Exception("该检验号下存在未判信息,不能判废!");
  12689. }
  12690. mapper.UpdateJugeResultB(zra);
  12691. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  12692. qjl.setMaterial_no(param1.get(0).toString());
  12693. qjl.setUnlock_name(param1.get(5).toString());
  12694. //qjl.setLock_id(param1.get(6).toString());
  12695. qjl.setReason_code(param1.get(7).toString());
  12696. qjl.setLock_type_code(param1.get(2).toString());
  12697. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12698. if(listsu.size() >0)
  12699. {
  12700. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12701. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12702. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12703. }
  12704. mapper.UpdateQcmJudgeLocking8(qjl);
  12705. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"4");
  12706. //脱单
  12707. order_down(param1.get(0).toString(),"判废");
  12708. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  12709. qjog.setOperate_name(param1.get(5).toString());
  12710. qjog.setOperate_type("判废");
  12711. qjog.setParams(param1.get(0).toString());
  12712. qjog.setBatchno(qjls.get(0).getBatch_no());
  12713. qjog.setProd_line(qjl.getPline_code());
  12714. mapper.insertQcmJudgeOperateLog(qjog);
  12715. SqlSession.commit();
  12716. }else{
  12717. zra.setR_cic_is_lock("0");
  12718. zra.setR_chemresult("4");
  12719. zra.setR_chemresult_desc("判废");
  12720. mapper.UpdateJugeResultB(zra);
  12721. qjl.setUnlock_name(param1.get(5).toString());
  12722. qjl.setLock_id(param1.get(6).toString());
  12723. qjl.setMaterial_no(param1.get(0).toString());
  12724. qjl.setReason_code(param1.get(7).toString());
  12725. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12726. if(listsu.size() >0)
  12727. {
  12728. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12729. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12730. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12731. }
  12732. mapper.UpdateQcmJudgeLocking(qjl);
  12733. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"4");
  12734. //脱单
  12735. order_down(param1.get(0).toString(),"判废");
  12736. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  12737. qjog.setOperate_name(param1.get(5).toString());
  12738. qjog.setOperate_type("判废");
  12739. qjog.setParams(param1.get(0).toString());
  12740. qjog.setBatchno(qjls.get(0).getBatch_no());
  12741. qjog.setProd_line(qjl.getPline_code());
  12742. mapper.insertQcmJudgeOperateLog(qjog);
  12743. SqlSession.commit();
  12744. }
  12745. }else if(list2.size() >0){
  12746. throw new Exception("卷板成分不合格不允许判废!");
  12747. /*for(HashMap lists:list2){
  12748. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12749. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  12750. }
  12751. }
  12752. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  12753. zra.setCoil_no(param1.get(0).toString());
  12754. if(param1.get(6).toString().contains("C")){
  12755. zra.setCic_is_lock("0");
  12756. zra.setChemresult("4");
  12757. zra.setChemresult_desc("判废");
  12758. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  12759. if(qjsrt.size() > 0){
  12760. throw new Exception("该检验号下存在未判信息,不能判废!");
  12761. }
  12762. mapper.UpdateJugeResultJ(zra);
  12763. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  12764. qjl.setMaterial_no(param1.get(0).toString());
  12765. qjl.setUnlock_name(param1.get(5).toString());
  12766. //.setLock_id(param1.get(6).toString());
  12767. qjl.setReason_code(param1.get(7).toString());
  12768. qjl.setLock_type_code(param1.get(2).toString());
  12769. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12770. if(listsu.size() >0)
  12771. {
  12772. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12773. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12774. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12775. }
  12776. mapper.UpdateQcmJudgeLocking1(qjl);
  12777. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"4");
  12778. //脱单
  12779. SqlSession.commit();
  12780. }else{
  12781. zra.setR_cic_is_lock("0");
  12782. zra.setR_chemresult("4");
  12783. zra.setR_chemresult_desc("判废");
  12784. mapper.UpdateJugeResultJ(zra);
  12785. qjl.setUnlock_name(param1.get(5).toString());
  12786. qjl.setLock_id(param1.get(6).toString());
  12787. qjl.setMaterial_no(param1.get(0).toString());
  12788. qjl.setReason_code(param1.get(7).toString());
  12789. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12790. if(listsu.size() >0)
  12791. {
  12792. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12793. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12794. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12795. }
  12796. mapper.UpdateQcmJudgeLocking(qjl);
  12797. //脱单
  12798. SqlSession.commit();
  12799. }*/
  12800. }else{
  12801. throw new Exception("卷板成分不合格不允许判废!");
  12802. /*for(HashMap lists:list2){
  12803. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12804. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  12805. }
  12806. }
  12807. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  12808. zra.setCoil_no(param1.get(0).toString());
  12809. if(param1.get(6).toString().contains("C")){
  12810. zra.setCic_is_lock("0");
  12811. zra.setChemresult("4");
  12812. zra.setChemresult_desc("判废");
  12813. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list2.get(0).get("INSPECTION_LOT").toString()+"' and JUDGE_STATUS = '0'");
  12814. if(qjsrt.size() > 0){
  12815. throw new Exception("该检验号下存在未判信息,不能判废!");
  12816. }
  12817. mapper.UpdateJugeResultJ(zra);
  12818. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  12819. qjl.setMaterial_no(param1.get(0).toString());
  12820. qjl.setUnlock_name(param1.get(5).toString());
  12821. //.setLock_id(param1.get(6).toString());
  12822. qjl.setReason_code(param1.get(7).toString());
  12823. qjl.setLock_type_code(param1.get(2).toString());
  12824. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12825. if(listsu.size() >0)
  12826. {
  12827. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12828. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12829. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12830. }
  12831. mapper.UpdateQcmJudgeLocking1(qjl);
  12832. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"4");
  12833. //脱单
  12834. SqlSession.commit();
  12835. }else{
  12836. zra.setR_cic_is_lock("0");
  12837. zra.setR_chemresult("4");
  12838. zra.setR_chemresult_desc("判废");
  12839. mapper.UpdateJugeResultJ(zra);
  12840. qjl.setUnlock_name(param1.get(5).toString());
  12841. qjl.setLock_id(param1.get(6).toString());
  12842. qjl.setMaterial_no(param1.get(0).toString());
  12843. qjl.setReason_code(param1.get(7).toString());
  12844. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12845. if(listsu.size() >0)
  12846. {
  12847. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12848. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12849. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12850. }
  12851. mapper.UpdateQcmJudgeLocking(qjl);
  12852. //脱单
  12853. SqlSession.commit();
  12854. }*/
  12855. }
  12856. }else{
  12857. throw new Exception("未找到库存信息!");
  12858. }
  12859. }
  12860. }
  12861. //脱单 根据产线划分 中厚板保留原有判定结果,只是进行解锁,热卷 进行充当清除判定记录
  12862. if(param1.get(3).toString().equals("6")){
  12863. qjl.setUnlock_type_code("6");
  12864. qjl.setUnlock_type_desc("脱单");
  12865. qjl.setUnlock_memo(param1.get(4).toString());
  12866. qjl.setUnlock_result(param1.get(9).toString());
  12867. qjl.setUnlock_name(param1.get(5).toString());
  12868. mapper.UpdateQcmJudgeLocking(qjl);
  12869. if(qjl.getPline_code().equals("ZB1") || qjl.getPline_code().equals("HB1")){
  12870. //材质
  12871. if(param1.get(2).toString().equals("P")){
  12872. qjl.setPic_locking("0");
  12873. if(list1.size() >0 || list2.size() >0){
  12874. if(list1.size()>0){
  12875. for(HashMap lists:list1){
  12876. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12877. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  12878. }
  12879. }
  12880. ZjResultAll zra = new ZjResultAll();
  12881. zra.setBilletid_jy(list1.get(0).get("BILLETID_JY").toString());
  12882. zra.setPic_is_lock("0");
  12883. mapper.UpdateJugeResultB(zra);
  12884. qjl.setUnlock_name(param1.get(5).toString());
  12885. qjl.setLock_id(param1.get(6).toString());
  12886. qjl.setMaterial_no(param1.get(0).toString());
  12887. qjl.setReason_code(param1.get(7).toString());
  12888. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12889. if(listsu.size() >0)
  12890. {
  12891. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12892. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12893. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12894. }
  12895. mapper.UpdateQcmJudgeLocking(qjl);
  12896. //脱单
  12897. order_down(param1.get(0).toString(),"异常处置脱单");
  12898. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  12899. qjog.setOperate_name(param1.get(5).toString());
  12900. qjog.setOperate_type("异常处置脱单");
  12901. qjog.setParams(param1.get(0).toString());
  12902. qjog.setBatchno(qjls.get(0).getBatch_no());
  12903. qjog.setProd_line(qjl.getPline_code());
  12904. mapper.insertQcmJudgeOperateLog(qjog);
  12905. SqlSession.commit();
  12906. }else{
  12907. for(HashMap lists:list2){
  12908. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12909. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  12910. }
  12911. }
  12912. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  12913. zra.setInspection_lot(list2.get(0).get("INSPECTION_LOT").toString());
  12914. zra.setPic_is_lock("0");
  12915. mapper.UpdateJugeResultJ(zra);
  12916. qjl.setUnlock_name(param1.get(5).toString());
  12917. qjl.setLock_id(param1.get(6).toString());
  12918. qjl.setMaterial_no(param1.get(0).toString());
  12919. qjl.setReason_code(param1.get(7).toString());
  12920. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12921. if(listsu.size() >0)
  12922. {
  12923. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12924. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12925. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12926. }
  12927. mapper.UpdateQcmJudgeLocking(qjl);
  12928. //脱单
  12929. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  12930. qjog.setOperate_name(param1.get(5).toString());
  12931. qjog.setOperate_type("异常处置脱单");
  12932. qjog.setParams(param1.get(0).toString());
  12933. qjog.setBatchno(qjls.get(0).getBatch_no());
  12934. qjog.setProd_line(qjl.getPline_code());
  12935. mapper.insertQcmJudgeOperateLog(qjog);
  12936. SqlSession.commit();
  12937. }
  12938. }else{
  12939. throw new Exception("未找到库存信息!");
  12940. }
  12941. }
  12942. if(param1.get(2).toString().equals("C")){
  12943. qjl.setCic_locking("0");
  12944. if(list1.size() >0 || list2.size() >0){
  12945. if(list1.size()>0){
  12946. for(HashMap lists:list1){
  12947. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12948. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  12949. }
  12950. }
  12951. ZjResultAll zra = new ZjResultAll();
  12952. zra.setBilletid(param1.get(0).toString());
  12953. if(param1.get(6).toString().contains("C")){
  12954. zra.setCic_is_lock("0");
  12955. }else{
  12956. zra.setR_cic_is_lock("0");
  12957. }
  12958. mapper.UpdateJugeResultB(zra);
  12959. qjl.setUnlock_name(param1.get(5).toString());
  12960. qjl.setLock_id(param1.get(6).toString());
  12961. qjl.setMaterial_no(param1.get(0).toString());
  12962. qjl.setReason_code(param1.get(7).toString());
  12963. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  12964. if(listsu.size() >0)
  12965. {
  12966. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  12967. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  12968. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  12969. }
  12970. mapper.UpdateQcmJudgeLocking(qjl);
  12971. //脱单
  12972. order_down(param1.get(0).toString(),"异常处置脱单");
  12973. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  12974. qjog.setOperate_name(param1.get(5).toString());
  12975. qjog.setOperate_type("异常处置脱单");
  12976. qjog.setParams(param1.get(0).toString());
  12977. qjog.setBatchno(qjls.get(0).getBatch_no());
  12978. qjog.setProd_line(qjl.getPline_code());
  12979. mapper.insertQcmJudgeOperateLog(qjog);
  12980. SqlSession.commit();
  12981. }else{
  12982. for(HashMap lists:list2){
  12983. if(!lists.get("JUDGERESULT").toString().equals("0")){
  12984. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能脱单!");
  12985. }
  12986. }
  12987. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  12988. zra.setCoil_no(param1.get(0).toString());
  12989. if(param1.get(6).toString().contains("C")){
  12990. zra.setCic_is_lock("0");
  12991. }else{
  12992. zra.setR_cic_is_lock("0");
  12993. }
  12994. mapper.UpdateJugeResultJ(zra);
  12995. qjl.setUnlock_name(param1.get(5).toString());
  12996. qjl.setLock_id(param1.get(6).toString());
  12997. qjl.setMaterial_no(param1.get(0).toString());
  12998. qjl.setReason_code(param1.get(7).toString());
  12999. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13000. if(listsu.size() >0)
  13001. {
  13002. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13003. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13004. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13005. }
  13006. mapper.UpdateQcmJudgeLocking(qjl);
  13007. //脱单
  13008. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13009. qjog.setOperate_name(param1.get(5).toString());
  13010. qjog.setOperate_type("异常处置脱单");
  13011. qjog.setParams(param1.get(0).toString());
  13012. qjog.setBatchno(qjls.get(0).getBatch_no());
  13013. qjog.setProd_line(qjl.getPline_code());
  13014. mapper.insertQcmJudgeOperateLog(qjog);
  13015. SqlSession.commit();
  13016. }
  13017. }else{
  13018. throw new Exception("未找到库存信息!");
  13019. }
  13020. }
  13021. }else if(qjl.getPline_code().equals("RZ1") || qjl.getPline_code().equals("LT1") || qjl.getPline_code().equals("SZ1")){
  13022. //材质
  13023. if(!qjl.getDesign_key().startsWith("39") && !qjl.getDesign_key().startsWith("49") && !qjl.getDesign_key().startsWith("59")){
  13024. throw new Exception("改判订单才能选择脱单处置去向!");
  13025. }
  13026. if(param1.get(2).toString().equals("P")){
  13027. qjl.setPic_locking("0");
  13028. }
  13029. if(param1.get(2).toString().equals("C")){
  13030. qjl.setCic_locking("0");
  13031. }
  13032. //调用脱单接口
  13033. qjl.setUnlock_name(param1.get(5).toString());
  13034. qjl.setLock_id(param1.get(6).toString());
  13035. qjl.setMaterial_no(param1.get(0).toString());
  13036. qjl.setReason_code(param1.get(7).toString());
  13037. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13038. if(listsu.size() >0)
  13039. {
  13040. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13041. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13042. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13043. }
  13044. mapper.UpdateQcmJudgeLocking(qjl);
  13045. //脱单
  13046. Coil_updateOrdreNo("","",qjl.getMaterial_no(),qjl.getPline_code());
  13047. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13048. qjog.setOperate_name(param1.get(5).toString());
  13049. qjog.setOperate_type("异常处置脱单");
  13050. qjog.setParams(param1.get(0).toString());
  13051. qjog.setBatchno(qjls.get(0).getBatch_no());
  13052. qjog.setProd_line(qjl.getPline_code());
  13053. mapper.insertQcmJudgeOperateLog(qjog);
  13054. SqlSession.commit();
  13055. }
  13056. }
  13057. if(param1.get(3).toString().equals("8")){
  13058. List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(param1.get(0).toString());
  13059. if(hashmap.size() == 0){
  13060. hashmap = qjms.doQueryMaterialInfoJ(param1.get(0).toString());
  13061. }
  13062. if(hashmap.size()==0){
  13063. hashmap = mapper.doQueryMaterialInfoY(param1.get(0).toString());
  13064. }
  13065. qjl.setUnlock_type_code("8");
  13066. if(param1.get(0).toString().startsWith("H") || param1.get(0).toString().startsWith("Z")){
  13067. qjl.setUnlock_type_desc("按子板件件取样");
  13068. }else{
  13069. qjl.setUnlock_type_desc("件件取样");
  13070. }
  13071. qjl.setUnlock_memo(param1.get(4).toString());
  13072. qjl.setUnlock_result(param1.get(9).toString());
  13073. qjl.setUnlock_name(param1.get(5).toString());
  13074. //qjl.setLock_id(param1.get(6).toString());
  13075. if(param1.get(2).toString().equals("C")){
  13076. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  13077. if(list1.size()>0){
  13078. for(HashMap lists:list1){
  13079. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13080. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  13081. }
  13082. }
  13083. qjl.setCic_locking("0");
  13084. //qjl.setMaterial_no(param1.get(0).toString());
  13085. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13086. qjl.setLock_id(param1.get(6).toString());
  13087. qjl.setReason_code(param1.get(7).toString());
  13088. qjl.setLock_type_code(param1.get(2).toString());
  13089. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13090. if(listsu.size() >0)
  13091. {
  13092. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13093. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13094. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13095. }
  13096. mapper.UpdateQcmJudgeLocking3(qjl);
  13097. ZjResultAll zra = new ZjResultAll();
  13098. SendGenerationSampleInfo("",hashmap,param1,"3","0","");
  13099. //zra.setBilletid(param1.get(0).toString());
  13100. zra.setBilletid_jy(list1.get(0).get("BILLETID_JY").toString());
  13101. zra.setChemresult("0");
  13102. zra.setChemresult_desc("待判");
  13103. zra.setCic_is_lock("0");
  13104. mapper.UpdateJugeResultB(zra);
  13105. sql = "select * from qcm_judge_locking where batch_no = '"+qjls.get(0).getBatch_no()+"'";
  13106. List<QCMJudgeLocking> qjlf = mapper.queryQCMJudgeLockings(sql);
  13107. for(QCMJudgeLocking qjll:qjlf){
  13108. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13109. qjog.setOperate_name(param1.get(5).toString());
  13110. qjog.setOperate_type("件件取样");
  13111. qjog.setParams(qjll.getMaterial_no());
  13112. qjog.setBatchno(qjls.get(0).getBatch_no());
  13113. qjog.setProd_line(qjl.getPline_code());
  13114. mapper.insertQcmJudgeOperateLog(qjog);
  13115. }
  13116. SqlSession.commit();
  13117. }else if(list2.size() >0){
  13118. for(HashMap lists:list2){
  13119. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13120. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  13121. }
  13122. }
  13123. qjl.setCic_locking("0");
  13124. //qjl.setMaterial_no(param1.get(0).toString());
  13125. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13126. qjl.setLock_id(param1.get(6).toString());
  13127. qjl.setReason_code(param1.get(7).toString());
  13128. qjl.setLock_type_code(param1.get(2).toString());
  13129. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13130. if(listsu.size() >0)
  13131. {
  13132. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13133. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13134. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13135. }
  13136. mapper.UpdateQcmJudgeLocking3(qjl);
  13137. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  13138. SendGenerationSampleInfo("",hashmap,param1,"3","0","");
  13139. zra.setInspection_lot(list1.get(0).get("INSPECTION_LOT").toString());
  13140. //zra.setCoil_no(param1.get(0).toString());
  13141. zra.setChemresult("0");
  13142. zra.setChemresult_desc("待判");
  13143. zra.setCic_is_lock("0");
  13144. mapper.UpdateJugeResultJ(zra);
  13145. sql = "select * from qcm_judge_locking where batch_no = '"+qjls.get(0).getBatch_no()+"'";
  13146. List<QCMJudgeLocking> qjlf = mapper.queryQCMJudgeLockings(sql);
  13147. for(QCMJudgeLocking qjll:qjlf){
  13148. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13149. qjog.setOperate_name(param1.get(5).toString());
  13150. qjog.setOperate_type("件件取样");
  13151. qjog.setParams(qjll.getMaterial_no());
  13152. qjog.setBatchno(qjls.get(0).getBatch_no());
  13153. qjog.setProd_line(qjl.getPline_code());
  13154. mapper.insertQcmJudgeOperateLog(qjog);
  13155. }
  13156. SqlSession.commit();
  13157. }else{
  13158. for(HashMap lists:list3){
  13159. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13160. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  13161. }
  13162. }
  13163. qjl.setCic_locking("0");
  13164. //qjl.setMaterial_no(param1.get(0).toString());
  13165. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13166. qjl.setLock_id(param1.get(6).toString());
  13167. qjl.setReason_code(param1.get(7).toString());
  13168. qjl.setLock_type_code(param1.get(2).toString());
  13169. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13170. if(listsu.size() >0)
  13171. {
  13172. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13173. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13174. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13175. }
  13176. mapper.UpdateQcmJudgeLocking3(qjl);
  13177. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  13178. SendGenerationSampleInfo("",hashmap,param1,"3","0","");
  13179. zra.setInspection_lot(list1.get(0).get("INSPECTION_LOT").toString());
  13180. //zra.setCoil_no(param1.get(0).toString());
  13181. zra.setChemresult("0");
  13182. zra.setChemresult_desc("待判");
  13183. zra.setCic_is_lock("0");
  13184. mapper.UpdateJugeResultY(zra);
  13185. sql = "select * from qcm_judge_locking where batch_no = '"+qjls.get(0).getBatch_no()+"'";
  13186. List<QCMJudgeLocking> qjlf = mapper.queryQCMJudgeLockings(sql);
  13187. for(QCMJudgeLocking qjll:qjlf){
  13188. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13189. qjog.setOperate_name(param1.get(5).toString());
  13190. qjog.setOperate_type("件件取样");
  13191. qjog.setParams(qjll.getMaterial_no());
  13192. qjog.setBatchno(qjls.get(0).getBatch_no());
  13193. qjog.setProd_line(qjl.getPline_code());
  13194. mapper.insertQcmJudgeOperateLog(qjog);
  13195. }
  13196. SqlSession.commit();
  13197. }
  13198. }
  13199. }
  13200. if(param1.get(2).toString().equals("P")){
  13201. List<QcmJudgePhysical> list = mapper.queryQcmJudgePhysical("select * from qcm_judge_physical where phy_id = '"+param1.get(6).toString()+"'");
  13202. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  13203. if(list1.size()>0){
  13204. for(HashMap lists:list1){
  13205. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13206. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能件件取样!");
  13207. }
  13208. }
  13209. qjl.setPic_locking("0");
  13210. //qjl.setMaterial_no(param1.get(0).toString());
  13211. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13212. qjl.setLock_id(param1.get(6).toString());
  13213. qjl.setReason_code(param1.get(7).toString());
  13214. qjl.setLock_type_code(param1.get(2).toString());
  13215. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13216. if(listsu.size() >0)
  13217. {
  13218. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13219. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13220. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13221. }
  13222. mapper.UpdateQcmJudgeLocking3(qjl);
  13223. ZjResultAll zra = new ZjResultAll();
  13224. SendGenerationSampleInfo("",hashmap,param1,"3","1","");
  13225. //zra.setBilletid(param1.get(0).toString());
  13226. zra.setBilletid_jy(list1.get(0).get("BILLETID_JY").toString());
  13227. if(list.get(0).getCert_inst_name().equals("检测中心"))
  13228. {
  13229. zra.setPhyfstsresult("0");
  13230. zra.setPhyfstsresult_desc("");
  13231. }
  13232. zra.setPhysresult("0");
  13233. zra.setPic_is_lock("0");
  13234. zra.setPhysresult_desc("");
  13235. mapper.UpdateJugeResultB(zra);
  13236. sql = "select * from qcm_judge_locking where batch_no = '"+qjls.get(0).getBatch_no()+"'";
  13237. List<QCMJudgeLocking> qjlf = mapper.queryQCMJudgeLockings(sql);
  13238. for(QCMJudgeLocking qjll:qjlf){
  13239. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13240. qjog.setOperate_name(param1.get(5).toString());
  13241. qjog.setOperate_type("件件取样");
  13242. qjog.setParams(qjll.getMaterial_no());
  13243. qjog.setBatchno(qjls.get(0).getBatch_no());
  13244. qjog.setProd_line(qjl.getPline_code());
  13245. mapper.insertQcmJudgeOperateLog(qjog);
  13246. }
  13247. SqlSession.commit();
  13248. }else if(list2.size() >0){
  13249. for(HashMap lists:list2){
  13250. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13251. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能件件取样!");
  13252. }
  13253. }
  13254. qjl.setPic_locking("0");
  13255. //qjl.setMaterial_no(param1.get(0).toString());
  13256. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13257. qjl.setLock_id(param1.get(6).toString());
  13258. qjl.setReason_code(param1.get(7).toString());
  13259. qjl.setLock_type_code(param1.get(2).toString());
  13260. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13261. if(listsu.size() >0)
  13262. {
  13263. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13264. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13265. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13266. }
  13267. mapper.UpdateQcmJudgeLocking3(qjl);
  13268. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  13269. SendGenerationSampleInfo("",hashmap,param1,"3","1","");
  13270. //zra.setInspection_lot(list1.get(0).get("INSPECTION_LOT").toString());
  13271. zra.setCoil_no(param1.get(0).toString());
  13272. if(list.get(0).getCert_inst_name().equals("检测中心"))
  13273. {
  13274. zra.setPhyfstsresult("0");
  13275. zra.setPhyfstsresult_desc("");
  13276. }
  13277. zra.setPhysresult("0");
  13278. zra.setPic_is_lock("0");
  13279. zra.setPhysresult_desc("");
  13280. mapper.UpdateJugeResultJ(zra);
  13281. sql = "select * from qcm_judge_locking where batch_no = '"+qjls.get(0).getBatch_no()+"'";
  13282. List<QCMJudgeLocking> qjlf = mapper.queryQCMJudgeLockings(sql);
  13283. for(QCMJudgeLocking qjll:qjlf){
  13284. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13285. qjog.setOperate_name(param1.get(5).toString());
  13286. qjog.setOperate_type("件件取样");
  13287. qjog.setParams(qjll.getMaterial_no());
  13288. qjog.setBatchno(qjls.get(0).getBatch_no());
  13289. qjog.setProd_line(qjl.getPline_code());
  13290. mapper.insertQcmJudgeOperateLog(qjog);
  13291. }
  13292. SqlSession.commit();
  13293. }else{
  13294. for(HashMap lists:list3){
  13295. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13296. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能件件取样!");
  13297. }
  13298. }
  13299. qjl.setPic_locking("0");
  13300. //qjl.setMaterial_no(param1.get(0).toString());
  13301. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13302. qjl.setLock_id(param1.get(6).toString());
  13303. qjl.setReason_code(param1.get(7).toString());
  13304. qjl.setLock_type_code(param1.get(2).toString());
  13305. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13306. if(listsu.size() >0)
  13307. {
  13308. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13309. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13310. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13311. }
  13312. mapper.UpdateQcmJudgeLocking3(qjl);
  13313. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  13314. SendGenerationSampleInfo("",hashmap,param1,"3","1","");
  13315. //zra.setInspection_lot(list1.get(0).get("INSPECTION_LOT").toString());
  13316. zra.setCoil_no(param1.get(0).toString());
  13317. if(list.get(0).getCert_inst_name().equals("检测中心"))
  13318. {
  13319. zra.setPhyfstsresult("0");
  13320. zra.setPhyfstsresult_desc("");
  13321. }
  13322. zra.setPhysresult("0");
  13323. zra.setPic_is_lock("0");
  13324. zra.setPhysresult_desc("");
  13325. mapper.UpdateJugeResultY(zra);
  13326. sql = "select * from qcm_judge_locking where batch_no = '"+qjls.get(0).getBatch_no()+"'";
  13327. List<QCMJudgeLocking> qjlf = mapper.queryQCMJudgeLockings(sql);
  13328. for(QCMJudgeLocking qjll:qjlf){
  13329. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13330. qjog.setOperate_name(param1.get(5).toString());
  13331. qjog.setOperate_type("件件取样");
  13332. qjog.setParams(qjll.getMaterial_no());
  13333. qjog.setBatchno(qjls.get(0).getBatch_no());
  13334. qjog.setProd_line(qjl.getPline_code());
  13335. mapper.insertQcmJudgeOperateLog(qjog);
  13336. }
  13337. SqlSession.commit();
  13338. }
  13339. }
  13340. }
  13341. }
  13342. if(param1.get(3).toString().equals("9")){
  13343. qjl.setUnlock_type_code("9");
  13344. qjl.setUnlock_type_desc("解除");
  13345. qjl.setUnlock_memo(param1.get(4).toString());
  13346. qjl.setUnlock_result(param1.get(9).toString());
  13347. //材质放行
  13348. if(param1.get(2).toString().equals("P")){
  13349. qjl.setPic_locking("0");
  13350. //更新库存表放行
  13351. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  13352. if(list1.size()>0){
  13353. for(HashMap lists:list1){
  13354. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13355. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能解锁!");
  13356. }
  13357. }
  13358. ZjResultAll zra = new ZjResultAll();
  13359. if(list1.get(0).get("BILLETID").toString().startsWith("H") || list1.get(0).get("BILLETID").toString().startsWith("Z")){
  13360. zra.setBilletid_jy(list1.get(0).get("BILLETID_JY").toString());
  13361. }
  13362. else{
  13363. zra.setBilletid_jy(list1.get(0).get("BILLETID_JY").toString());
  13364. }
  13365. zra.setPic_is_lock("0");
  13366. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list1.get(0).get("BILLETID_JY").toString()+"' and JUDGE_STATUS = '0'");
  13367. mapper.UpdateJugeResultB(zra);
  13368. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  13369. for(HashMap lists:list1){
  13370. //质量异常材处置
  13371. qjl = new QCMJudgeLocking();
  13372. qjl.setUnlock_type_code("9");
  13373. qjl.setUnlock_type_desc("解除");
  13374. qjl.setUnlock_memo(param1.get(4).toString());
  13375. qjl.setUnlock_result(param1.get(9).toString());
  13376. qjl.setPic_locking("0");
  13377. if(lists.get("BILLETID").toString().startsWith("H") || lists.get("BILLETID").toString().startsWith("Z")){
  13378. qjl.setLock_id(param1.get(6).toString());
  13379. //qjl.setMaterial_no(lists.get("BILLETID").toString());
  13380. }
  13381. //qjl.setMaterial_no(lists.get("BILLETID").toString());
  13382. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13383. qjl.setUnlock_name(param1.get(5).toString());
  13384. qjl.setLock_id(param1.get(6).toString());
  13385. qjl.setReason_code(param1.get(7).toString());
  13386. qjl.setLock_type_code(param1.get(2).toString());
  13387. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13388. if(listsu.size() >0)
  13389. {
  13390. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13391. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13392. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13393. }
  13394. mapper.UpdateQcmJudgeLocking1(qjl);
  13395. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13396. qjog.setOperate_name(param1.get(5).toString());
  13397. qjog.setOperate_type("异常处置解除");
  13398. qjog.setParams(param1.get(0).toString());
  13399. qjog.setBatchno(qjls.get(0).getBatch_no());
  13400. qjog.setProd_line(qjl.getPline_code());
  13401. mapper.insertQcmJudgeOperateLog(qjog);
  13402. }
  13403. SqlSession.commit();
  13404. }else if(list2.size() >0){
  13405. for(HashMap lists:list2){
  13406. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13407. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能解除!");
  13408. }
  13409. }
  13410. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  13411. zra.setInspection_lot(list2.get(0).get("INSPECTION_LOT").toString());
  13412. zra.setCoil_no(list2.get(0).get("COIL_NO").toString());
  13413. zra.setPic_is_lock("0");
  13414. mapper.UpdateJugeResultJ(zra);
  13415. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  13416. String design_key = qjl.getDesign_key();
  13417. String prod_line = "";
  13418. if(qjl.getPline_code().equals("RZ1")){
  13419. prod_line = "R";
  13420. }else if(qjl.getPline_code().equals("LT1")){
  13421. prod_line = "L";
  13422. }
  13423. for(HashMap lists:list2){
  13424. //质量异常材处置
  13425. qjl = new QCMJudgeLocking();
  13426. qjl.setUnlock_type_code("9");
  13427. qjl.setUnlock_type_desc("解除");
  13428. qjl.setUnlock_memo(param1.get(4).toString());
  13429. qjl.setUnlock_result(param1.get(9).toString());
  13430. qjl.setPic_locking("0");
  13431. qjl.setMaterial_no(lists.get("COIL_NO").toString());
  13432. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13433. qjl.setUnlock_name(param1.get(5).toString());
  13434. qjl.setLock_id(param1.get(6).toString());
  13435. qjl.setReason_code(param1.get(7).toString());
  13436. qjl.setLock_type_code(param1.get(2).toString());
  13437. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13438. if(listsu.size() >0)
  13439. {
  13440. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13441. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13442. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13443. }
  13444. mapper.UpdateQcmJudgeLocking1(qjl);
  13445. QcmJudgeLog qjl1 = new QcmJudgeLog();
  13446. qjl1.setJudge_type("R");
  13447. qjl1.setMaterial_no(lists.get("INSPECTION_LOT").toString());
  13448. qjl1.setMaterial_type("1");
  13449. qjl1.setCreate_name("system");
  13450. qjl1.setProd_line("RZ1");
  13451. mapper.insertQcmJudgeLog(qjl1);
  13452. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13453. qjog.setOperate_name(param1.get(5).toString());
  13454. qjog.setOperate_type("异常处置解锁");
  13455. qjog.setParams(param1.get(0).toString());
  13456. qjog.setBatchno(qjls.get(0).getBatch_no());
  13457. qjog.setProd_line(qjl.getPline_code());
  13458. mapper.insertQcmJudgeOperateLog(qjog);
  13459. /*if(design_key.startsWith("39") || design_key.startsWith("49") || design_key.startsWith("59")){
  13460. Td(lists.get("COIL_NO").toString(),prod_line);
  13461. }*/
  13462. }
  13463. SqlSession.commit();
  13464. }else{
  13465. for(HashMap lists:list3){
  13466. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13467. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能解除!");
  13468. }
  13469. }
  13470. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  13471. zra.setInspection_lot(list3.get(0).get("INSPECTION_LOT").toString());
  13472. zra.setPic_is_lock("0");
  13473. mapper.UpdateJugeResultY(zra);
  13474. for(HashMap lists:list3){
  13475. //质量异常材处置
  13476. qjl = new QCMJudgeLocking();
  13477. qjl.setUnlock_type_code("9");
  13478. qjl.setUnlock_type_desc("解除");
  13479. qjl.setUnlock_memo(param1.get(4).toString());
  13480. qjl.setUnlock_result(param1.get(9).toString());
  13481. qjl.setPic_locking("0");
  13482. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  13483. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13484. qjl.setUnlock_name(param1.get(5).toString());
  13485. qjl.setLock_id(param1.get(6).toString());
  13486. qjl.setReason_code(param1.get(7).toString());
  13487. qjl.setLock_type_code(param1.get(2).toString());
  13488. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13489. if(listsu.size() >0)
  13490. {
  13491. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13492. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13493. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13494. }
  13495. mapper.UpdateQcmJudgeLocking1(qjl);
  13496. QcmJudgeLog qjl1 = new QcmJudgeLog();
  13497. qjl1.setJudge_type("R");
  13498. qjl1.setMaterial_no(list3.get(0).get("INSPECTION_LOT").toString());
  13499. qjl1.setMaterial_type("1");
  13500. qjl1.setCreate_name("system");
  13501. qjl1.setProd_line("YT1");
  13502. mapper.insertQcmJudgeLog(qjl1);
  13503. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13504. qjog.setOperate_name(param1.get(5).toString());
  13505. qjog.setOperate_type("异常处置解锁");
  13506. qjog.setParams(param1.get(0).toString());
  13507. qjog.setBatchno(qjls.get(0).getBatch_no());
  13508. qjog.setProd_line(qjl.getPline_code());
  13509. mapper.insertQcmJudgeOperateLog(qjog);
  13510. }
  13511. SqlSession.commit();
  13512. }
  13513. }else{
  13514. throw new Exception("未找到库存信息!");
  13515. }
  13516. }
  13517. if(param1.get(2).toString().equals("C")){
  13518. qjl.setCic_locking("0");
  13519. //更改合同与试样表
  13520. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  13521. if(list1.size()>0){
  13522. for(HashMap lists:list1){
  13523. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13524. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能解锁!");
  13525. }
  13526. }
  13527. ZjResultAll zra = new ZjResultAll();
  13528. zra.setBilletid(param1.get(0).toString());
  13529. if(param1.get(6).toString().contains("C")){
  13530. zra.setCic_is_lock("0");
  13531. mapper.UpdateJugeResultB(zra);
  13532. //PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  13533. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  13534. for(HashMap lists:list1){
  13535. //质量异常材处置
  13536. qjl = new QCMJudgeLocking();
  13537. qjl.setUnlock_type_code("9");
  13538. qjl.setUnlock_type_desc("解除");
  13539. qjl.setUnlock_memo(param1.get(4).toString());
  13540. qjl.setUnlock_result(param1.get(9).toString());
  13541. qjl.setPic_locking("0");
  13542. qjl.setMaterial_no(lists.get("BILLETID").toString());
  13543. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13544. qjl.setUnlock_name(param1.get(5).toString());
  13545. qjl.setLock_id(param1.get(6).toString());
  13546. qjl.setReason_code(param1.get(7).toString());
  13547. qjl.setLock_type_code(param1.get(2).toString());
  13548. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13549. if(listsu.size() >0)
  13550. {
  13551. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13552. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13553. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13554. }
  13555. mapper.UpdateQcmJudgeLocking1(qjl);
  13556. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13557. qjog.setOperate_name(param1.get(5).toString());
  13558. qjog.setOperate_type("异常处置解锁");
  13559. qjog.setParams(param1.get(0).toString());
  13560. qjog.setBatchno(qjls.get(0).getBatch_no());
  13561. qjog.setProd_line(qjl.getPline_code());
  13562. mapper.insertQcmJudgeOperateLog(qjog);
  13563. }
  13564. SqlSession.commit();
  13565. }else{
  13566. zra.setR_cic_is_lock("0");
  13567. mapper.UpdateJugeResultB(zra);
  13568. qjl.setUnlock_name(param1.get(5).toString());
  13569. qjl.setReason_code(param1.get(7).toString());
  13570. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13571. if(listsu.size() >0)
  13572. {
  13573. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13574. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13575. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13576. }
  13577. mapper.UpdateQcmJudgeLocking(qjl);
  13578. SqlSession.commit();
  13579. }
  13580. }else if(list2.size() >0){
  13581. for(HashMap lists:list2){
  13582. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13583. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能解锁!");
  13584. }
  13585. }
  13586. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  13587. zra.setCoil_no(param1.get(0).toString());
  13588. if(param1.get(6).toString().contains("C")){
  13589. zra.setCic_is_lock("0");
  13590. mapper.UpdateJugeResultJ(zra);
  13591. PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  13592. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  13593. for(HashMap lists:list2){
  13594. //质量异常材处置
  13595. qjl = new QCMJudgeLocking();
  13596. qjl.setUnlock_type_code("9");
  13597. qjl.setUnlock_type_desc("解除");
  13598. qjl.setUnlock_memo(param1.get(4).toString());
  13599. qjl.setUnlock_result(param1.get(9).toString());
  13600. qjl.setPic_locking("0");
  13601. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13602. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  13603. qjl.setUnlock_name(param1.get(5).toString());
  13604. qjl.setLock_id(param1.get(6).toString());
  13605. qjl.setReason_code(param1.get(7).toString());
  13606. qjl.setLock_type_code(param1.get(2).toString());
  13607. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13608. if(listsu.size() >0)
  13609. {
  13610. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13611. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13612. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13613. }
  13614. }
  13615. mapper.UpdateQcmJudgeLocking1(qjl);
  13616. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13617. qjog.setOperate_name(param1.get(5).toString());
  13618. qjog.setOperate_type("异常处置解锁");
  13619. qjog.setParams(param1.get(0).toString());
  13620. qjog.setBatchno(qjls.get(0).getBatch_no());
  13621. qjog.setProd_line(qjl.getPline_code());
  13622. mapper.insertQcmJudgeOperateLog(qjog);
  13623. SqlSession.commit();
  13624. }else{
  13625. zra.setR_cic_is_lock("0");
  13626. mapper.UpdateJugeResultJ(zra);
  13627. qjl.setUnlock_name(param1.get(5).toString());
  13628. qjl.setReason_code(param1.get(7).toString());
  13629. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13630. if(listsu.size() >0)
  13631. {
  13632. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13633. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13634. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13635. }
  13636. mapper.UpdateQcmJudgeLocking(qjl);
  13637. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13638. qjog.setOperate_name(param1.get(5).toString());
  13639. qjog.setOperate_type("异常处置解锁");
  13640. qjog.setParams(param1.get(0).toString());
  13641. qjog.setBatchno(qjls.get(0).getBatch_no());
  13642. qjog.setProd_line(qjl.getPline_code());
  13643. mapper.insertQcmJudgeOperateLog(qjog);
  13644. QcmJudgeLog qjlt = new QcmJudgeLog();
  13645. qjlt.setJudge_type("U");
  13646. qjlt.setMaterial_no(param1.get(0).toString());
  13647. qjlt.setCreate_name("system");
  13648. qjlt.setProd_line(qjl.getPline_code());
  13649. mapper.insertQcmJudgeLog(qjlt);
  13650. SqlSession.commit();
  13651. }
  13652. }else{
  13653. for(HashMap lists:list3){
  13654. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13655. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能解锁!");
  13656. }
  13657. }
  13658. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  13659. zra.setCoil_no(param1.get(0).toString());
  13660. if(param1.get(6).toString().contains("C")){
  13661. zra.setCic_is_lock("0");
  13662. mapper.UpdateJugeResultY(zra);
  13663. PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  13664. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  13665. for(HashMap lists:list2){
  13666. //质量异常材处置
  13667. qjl = new QCMJudgeLocking();
  13668. qjl.setUnlock_type_code("9");
  13669. qjl.setUnlock_type_desc("解除");
  13670. qjl.setUnlock_memo(param1.get(4).toString());
  13671. qjl.setUnlock_result(param1.get(9).toString());
  13672. qjl.setPic_locking("0");
  13673. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13674. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  13675. qjl.setUnlock_name(param1.get(5).toString());
  13676. qjl.setLock_id(param1.get(6).toString());
  13677. qjl.setReason_code(param1.get(7).toString());
  13678. qjl.setLock_type_code(param1.get(2).toString());
  13679. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13680. if(listsu.size() >0)
  13681. {
  13682. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13683. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13684. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13685. }
  13686. }
  13687. mapper.UpdateQcmJudgeLocking1(qjl);
  13688. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13689. qjog.setOperate_name(param1.get(5).toString());
  13690. qjog.setOperate_type("异常处置解锁");
  13691. qjog.setParams(param1.get(0).toString());
  13692. qjog.setBatchno(qjls.get(0).getBatch_no());
  13693. qjog.setProd_line(qjl.getPline_code());
  13694. mapper.insertQcmJudgeOperateLog(qjog);
  13695. SqlSession.commit();
  13696. }else{
  13697. zra.setR_cic_is_lock("0");
  13698. mapper.UpdateJugeResultY(zra);
  13699. qjl.setUnlock_name(param1.get(5).toString());
  13700. qjl.setReason_code(param1.get(7).toString());
  13701. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13702. if(listsu.size() >0)
  13703. {
  13704. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13705. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13706. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13707. }
  13708. mapper.UpdateQcmJudgeLocking(qjl);
  13709. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13710. qjog.setOperate_name(param1.get(5).toString());
  13711. qjog.setOperate_type("异常处置解锁");
  13712. qjog.setParams(param1.get(0).toString());
  13713. qjog.setBatchno(qjls.get(0).getBatch_no());
  13714. qjog.setProd_line(qjl.getPline_code());
  13715. mapper.insertQcmJudgeOperateLog(qjog);
  13716. QcmJudgeLog qjlt = new QcmJudgeLog();
  13717. qjlt.setJudge_type("R");
  13718. qjlt.setMaterial_no(param1.get(0).toString());
  13719. qjlt.setCreate_name("system");
  13720. qjlt.setProd_line(qjl.getPline_code());
  13721. mapper.insertQcmJudgeLog(qjlt);
  13722. SqlSession.commit();
  13723. }
  13724. }
  13725. }else{
  13726. throw new Exception("未找到库存信息!");
  13727. }
  13728. }
  13729. }
  13730. if(param1.get(3).toString().equals("19")){
  13731. qjl.setUnlock_type_code("19");
  13732. qjl.setUnlock_type_desc("解除后不综判");
  13733. qjl.setUnlock_memo(param1.get(4).toString());
  13734. qjl.setUnlock_result(param1.get(9).toString());
  13735. //材质放行
  13736. if(param1.get(2).toString().equals("P")){
  13737. qjl.setPic_locking("0");
  13738. //更新库存表放行
  13739. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  13740. if(list1.size()>0){
  13741. for(HashMap lists:list1){
  13742. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13743. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能解锁!");
  13744. }
  13745. }
  13746. ZjResultAll zra = new ZjResultAll();
  13747. if(list1.get(0).get("BILLETID").toString().startsWith("H") || list1.get(0).get("BILLETID").toString().startsWith("Z")){
  13748. zra.setBilletid_jy(list1.get(0).get("BILLETID_JY").toString());
  13749. }
  13750. else{
  13751. zra.setBilletid_jy(list1.get(0).get("BILLETID_JY").toString());
  13752. }
  13753. zra.setPic_is_lock("0");
  13754. List<QcmJhySampleROrd> qjsrt = mapper.queryQcmJhySampleROrd1("select * from QCM_JHY_SAMPLE_R_ORD where INSPECTION_LOT = '"+list1.get(0).get("BILLETID_JY").toString()+"' and JUDGE_STATUS = '0'");
  13755. mapper.UpdateJugeResultB(zra);
  13756. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  13757. for(HashMap lists:list1){
  13758. //质量异常材处置
  13759. qjl = new QCMJudgeLocking();
  13760. qjl.setUnlock_type_code("19");
  13761. qjl.setUnlock_type_desc("解除后不综判");
  13762. qjl.setUnlock_memo(param1.get(4).toString());
  13763. qjl.setUnlock_result(param1.get(9).toString());
  13764. qjl.setPic_locking("0");
  13765. if(lists.get("BILLETID").toString().startsWith("H") || lists.get("BILLETID").toString().startsWith("Z")){
  13766. qjl.setLock_id(param1.get(6).toString());
  13767. //qjl.setMaterial_no(lists.get("BILLETID").toString());
  13768. }
  13769. //qjl.setMaterial_no(lists.get("BILLETID").toString());
  13770. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13771. qjl.setUnlock_name(param1.get(5).toString());
  13772. qjl.setLock_id(param1.get(6).toString());
  13773. qjl.setReason_code(param1.get(7).toString());
  13774. qjl.setLock_type_code(param1.get(2).toString());
  13775. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13776. if(listsu.size() >0)
  13777. {
  13778. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13779. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13780. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13781. }
  13782. mapper.UpdateQcmJudgeLocking1(qjl);
  13783. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13784. qjog.setOperate_name(param1.get(5).toString());
  13785. qjog.setOperate_type("异常处置解除");
  13786. qjog.setParams(param1.get(0).toString());
  13787. qjog.setBatchno(qjls.get(0).getBatch_no());
  13788. qjog.setProd_line(qjl.getPline_code());
  13789. mapper.insertQcmJudgeOperateLog(qjog);
  13790. }
  13791. SqlSession.commit();
  13792. }else if(list2.size() >0){
  13793. for(HashMap lists:list2){
  13794. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13795. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能解除!");
  13796. }
  13797. }
  13798. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  13799. zra.setInspection_lot(list2.get(0).get("INSPECTION_LOT").toString());
  13800. zra.setCoil_no(list2.get(0).get("COIL_NO").toString());
  13801. zra.setPic_is_lock("0");
  13802. mapper.UpdateJugeResultJ(zra);
  13803. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  13804. String design_key = qjl.getDesign_key();
  13805. String prod_line = "";
  13806. if(qjl.getPline_code().equals("RZ1")){
  13807. prod_line = "R";
  13808. }else if(qjl.getPline_code().equals("LT1")){
  13809. prod_line = "L";
  13810. }
  13811. for(HashMap lists:list2){
  13812. //质量异常材处置
  13813. qjl = new QCMJudgeLocking();
  13814. qjl.setUnlock_type_code("19");
  13815. qjl.setUnlock_type_desc("解除后不综判");
  13816. qjl.setUnlock_memo(param1.get(4).toString());
  13817. qjl.setUnlock_result(param1.get(9).toString());
  13818. qjl.setPic_locking("0");
  13819. qjl.setMaterial_no(lists.get("COIL_NO").toString());
  13820. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13821. qjl.setUnlock_name(param1.get(5).toString());
  13822. qjl.setLock_id(param1.get(6).toString());
  13823. qjl.setReason_code(param1.get(7).toString());
  13824. qjl.setLock_type_code(param1.get(2).toString());
  13825. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13826. if(listsu.size() >0)
  13827. {
  13828. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13829. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13830. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13831. }
  13832. mapper.UpdateQcmJudgeLocking1(qjl);
  13833. /*QcmJudgeLog qjl1 = new QcmJudgeLog();
  13834. qjl1.setJudge_type("R");
  13835. qjl1.setMaterial_no(lists.get("COIL_NO").toString());
  13836. qjl1.setMaterial_type("0");
  13837. qjl1.setCreate_name("system");
  13838. qjl1.setProd_line("RZ1");
  13839. mapper.insertQcmJudgeLog(qjl1);*/
  13840. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13841. qjog.setOperate_name(param1.get(5).toString());
  13842. qjog.setOperate_type("异常处置解锁");
  13843. qjog.setParams(param1.get(0).toString());
  13844. qjog.setBatchno(qjls.get(0).getBatch_no());
  13845. qjog.setProd_line(qjl.getPline_code());
  13846. mapper.insertQcmJudgeOperateLog(qjog);
  13847. /*if(design_key.startsWith("39") || design_key.startsWith("49") || design_key.startsWith("59")){
  13848. Td(lists.get("COIL_NO").toString(),prod_line);
  13849. }*/
  13850. }
  13851. SqlSession.commit();
  13852. }else{
  13853. for(HashMap lists:list3){
  13854. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13855. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能解除!");
  13856. }
  13857. }
  13858. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  13859. zra.setInspection_lot(list3.get(0).get("INSPECTION_LOT").toString());
  13860. zra.setPic_is_lock("0");
  13861. mapper.UpdateJugeResultY(zra);
  13862. for(HashMap lists:list3){
  13863. //质量异常材处置
  13864. qjl = new QCMJudgeLocking();
  13865. qjl.setUnlock_type_code("19");
  13866. qjl.setUnlock_type_desc("解除后不综判");
  13867. qjl.setUnlock_memo(param1.get(4).toString());
  13868. qjl.setUnlock_result(param1.get(9).toString());
  13869. qjl.setPic_locking("0");
  13870. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  13871. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13872. qjl.setUnlock_name(param1.get(5).toString());
  13873. qjl.setLock_id(param1.get(6).toString());
  13874. qjl.setReason_code(param1.get(7).toString());
  13875. qjl.setLock_type_code(param1.get(2).toString());
  13876. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13877. if(listsu.size() >0)
  13878. {
  13879. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13880. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13881. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13882. }
  13883. mapper.UpdateQcmJudgeLocking1(qjl);
  13884. QcmJudgeLog qjl1 = new QcmJudgeLog();
  13885. qjl1.setJudge_type("R");
  13886. qjl1.setMaterial_no(list3.get(0).get("INSPECTION_LOT").toString());
  13887. qjl1.setMaterial_type("1");
  13888. qjl1.setCreate_name("system");
  13889. qjl1.setProd_line("YT1");
  13890. mapper.insertQcmJudgeLog(qjl1);
  13891. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13892. qjog.setOperate_name(param1.get(5).toString());
  13893. qjog.setOperate_type("异常处置解锁");
  13894. qjog.setParams(param1.get(0).toString());
  13895. qjog.setBatchno(qjls.get(0).getBatch_no());
  13896. qjog.setProd_line(qjl.getPline_code());
  13897. mapper.insertQcmJudgeOperateLog(qjog);
  13898. }
  13899. SqlSession.commit();
  13900. }
  13901. }else{
  13902. throw new Exception("未找到库存信息!");
  13903. }
  13904. }
  13905. if(param1.get(2).toString().equals("C")){
  13906. qjl.setCic_locking("0");
  13907. //更改合同与试样表
  13908. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  13909. if(list1.size()>0){
  13910. for(HashMap lists:list1){
  13911. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13912. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能解锁!");
  13913. }
  13914. }
  13915. ZjResultAll zra = new ZjResultAll();
  13916. zra.setBilletid(param1.get(0).toString());
  13917. if(param1.get(6).toString().contains("C")){
  13918. zra.setCic_is_lock("0");
  13919. mapper.UpdateJugeResultB(zra);
  13920. //PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  13921. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  13922. for(HashMap lists:list1){
  13923. //质量异常材处置
  13924. qjl = new QCMJudgeLocking();
  13925. qjl.setUnlock_type_code("19");
  13926. qjl.setUnlock_type_desc("解除后不综判");
  13927. qjl.setUnlock_memo(param1.get(4).toString());
  13928. qjl.setUnlock_result(param1.get(9).toString());
  13929. qjl.setPic_locking("0");
  13930. qjl.setMaterial_no(lists.get("BILLETID").toString());
  13931. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13932. qjl.setUnlock_name(param1.get(5).toString());
  13933. qjl.setLock_id(param1.get(6).toString());
  13934. qjl.setReason_code(param1.get(7).toString());
  13935. qjl.setLock_type_code(param1.get(2).toString());
  13936. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13937. if(listsu.size() >0)
  13938. {
  13939. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13940. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13941. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13942. }
  13943. mapper.UpdateQcmJudgeLocking1(qjl);
  13944. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  13945. qjog.setOperate_name(param1.get(5).toString());
  13946. qjog.setOperate_type("异常处置解锁");
  13947. qjog.setParams(param1.get(0).toString());
  13948. qjog.setBatchno(qjls.get(0).getBatch_no());
  13949. qjog.setProd_line(qjl.getPline_code());
  13950. mapper.insertQcmJudgeOperateLog(qjog);
  13951. }
  13952. SqlSession.commit();
  13953. }else{
  13954. zra.setR_cic_is_lock("0");
  13955. mapper.UpdateJugeResultB(zra);
  13956. qjl.setUnlock_name(param1.get(5).toString());
  13957. qjl.setReason_code(param1.get(7).toString());
  13958. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13959. if(listsu.size() >0)
  13960. {
  13961. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13962. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  13963. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  13964. }
  13965. mapper.UpdateQcmJudgeLocking(qjl);
  13966. SqlSession.commit();
  13967. }
  13968. }else if(list2.size() >0){
  13969. for(HashMap lists:list2){
  13970. if(!lists.get("JUDGERESULT").toString().equals("0")){
  13971. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能解锁!");
  13972. }
  13973. }
  13974. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  13975. zra.setCoil_no(param1.get(0).toString());
  13976. if(param1.get(6).toString().contains("C")){
  13977. zra.setCic_is_lock("0");
  13978. mapper.UpdateJugeResultJ(zra);
  13979. PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  13980. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  13981. for(HashMap lists:list2){
  13982. //质量异常材处置
  13983. qjl = new QCMJudgeLocking();
  13984. qjl.setUnlock_type_code("19");
  13985. qjl.setUnlock_type_desc("解除后不综判");
  13986. qjl.setUnlock_memo(param1.get(4).toString());
  13987. qjl.setUnlock_result(param1.get(9).toString());
  13988. qjl.setPic_locking("0");
  13989. qjl.setBatch_no(qjls.get(0).getBatch_no());
  13990. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  13991. qjl.setUnlock_name(param1.get(5).toString());
  13992. qjl.setLock_id(param1.get(6).toString());
  13993. qjl.setReason_code(param1.get(7).toString());
  13994. qjl.setLock_type_code(param1.get(2).toString());
  13995. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  13996. if(listsu.size() >0)
  13997. {
  13998. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  13999. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  14000. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  14001. }
  14002. }
  14003. mapper.UpdateQcmJudgeLocking1(qjl);
  14004. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  14005. qjog.setOperate_name(param1.get(5).toString());
  14006. qjog.setOperate_type("异常处置解锁");
  14007. qjog.setParams(param1.get(0).toString());
  14008. qjog.setBatchno(qjls.get(0).getBatch_no());
  14009. qjog.setProd_line(qjl.getPline_code());
  14010. mapper.insertQcmJudgeOperateLog(qjog);
  14011. SqlSession.commit();
  14012. }else{
  14013. zra.setR_cic_is_lock("0");
  14014. mapper.UpdateJugeResultJ(zra);
  14015. qjl.setUnlock_name(param1.get(5).toString());
  14016. qjl.setReason_code(param1.get(7).toString());
  14017. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  14018. if(listsu.size() >0)
  14019. {
  14020. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  14021. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  14022. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  14023. }
  14024. mapper.UpdateQcmJudgeLocking(qjl);
  14025. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  14026. qjog.setOperate_name(param1.get(5).toString());
  14027. qjog.setOperate_type("异常处置解锁");
  14028. qjog.setParams(param1.get(0).toString());
  14029. qjog.setBatchno(qjls.get(0).getBatch_no());
  14030. qjog.setProd_line(qjl.getPline_code());
  14031. mapper.insertQcmJudgeOperateLog(qjog);
  14032. /*QcmJudgeLog qjlt = new QcmJudgeLog();
  14033. qjlt.setJudge_type("U");
  14034. qjlt.setMaterial_no(param1.get(0).toString());
  14035. qjlt.setCreate_name("system");
  14036. qjlt.setProd_line(qjl.getPline_code());
  14037. mapper.insertQcmJudgeLog(qjlt);*/
  14038. SqlSession.commit();
  14039. }
  14040. }else{
  14041. for(HashMap lists:list3){
  14042. if(!lists.get("JUDGERESULT").toString().equals("0")){
  14043. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能解锁!");
  14044. }
  14045. }
  14046. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  14047. zra.setCoil_no(param1.get(0).toString());
  14048. if(param1.get(6).toString().contains("C")){
  14049. zra.setCic_is_lock("0");
  14050. mapper.UpdateJugeResultY(zra);
  14051. PhyUtmJudge(qjl.getDesign_key(),list1.get(0).get("BILLETID_JY").toString() , param1.get(5).toString());
  14052. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  14053. for(HashMap lists:list2){
  14054. //质量异常材处置
  14055. qjl = new QCMJudgeLocking();
  14056. qjl.setUnlock_type_code("19");
  14057. qjl.setUnlock_type_desc("解除后不综判");
  14058. qjl.setUnlock_memo(param1.get(4).toString());
  14059. qjl.setUnlock_result(param1.get(9).toString());
  14060. qjl.setPic_locking("0");
  14061. qjl.setBatch_no(qjls.get(0).getBatch_no());
  14062. //qjl.setMaterial_no(lists.get("COIL_NO").toString());
  14063. qjl.setUnlock_name(param1.get(5).toString());
  14064. qjl.setLock_id(param1.get(6).toString());
  14065. qjl.setReason_code(param1.get(7).toString());
  14066. qjl.setLock_type_code(param1.get(2).toString());
  14067. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  14068. if(listsu.size() >0)
  14069. {
  14070. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  14071. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  14072. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  14073. }
  14074. }
  14075. mapper.UpdateQcmJudgeLocking1(qjl);
  14076. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  14077. qjog.setOperate_name(param1.get(5).toString());
  14078. qjog.setOperate_type("异常处置解锁");
  14079. qjog.setParams(param1.get(0).toString());
  14080. qjog.setBatchno(qjls.get(0).getBatch_no());
  14081. qjog.setProd_line(qjl.getPline_code());
  14082. mapper.insertQcmJudgeOperateLog(qjog);
  14083. SqlSession.commit();
  14084. }else{
  14085. zra.setR_cic_is_lock("0");
  14086. mapper.UpdateJugeResultY(zra);
  14087. qjl.setUnlock_name(param1.get(5).toString());
  14088. qjl.setReason_code(param1.get(7).toString());
  14089. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  14090. if(listsu.size() >0)
  14091. {
  14092. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  14093. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  14094. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  14095. }
  14096. mapper.UpdateQcmJudgeLocking(qjl);
  14097. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  14098. qjog.setOperate_name(param1.get(5).toString());
  14099. qjog.setOperate_type("异常处置解锁");
  14100. qjog.setParams(param1.get(0).toString());
  14101. qjog.setBatchno(qjls.get(0).getBatch_no());
  14102. qjog.setProd_line(qjl.getPline_code());
  14103. mapper.insertQcmJudgeOperateLog(qjog);
  14104. QcmJudgeLog qjlt = new QcmJudgeLog();
  14105. qjlt.setJudge_type("R");
  14106. qjlt.setMaterial_no(param1.get(0).toString());
  14107. qjlt.setCreate_name("system");
  14108. qjlt.setProd_line(qjl.getPline_code());
  14109. mapper.insertQcmJudgeLog(qjlt);
  14110. SqlSession.commit();
  14111. }
  14112. }
  14113. }else{
  14114. throw new Exception("未找到库存信息!");
  14115. }
  14116. }
  14117. }
  14118. if(param1.get(3).toString().equals("10")){
  14119. if(list3.size()>0){
  14120. throw new Exception("成分材质不能做待判处置!");
  14121. }
  14122. qjl.setUnlock_type_code("10");
  14123. qjl.setUnlock_type_desc("待判");
  14124. qjl.setUnlock_memo(param1.get(4).toString());
  14125. qjl.setUnlock_result(param1.get(9).toString());
  14126. qjl.setUnlock_name(param1.get(5).toString());
  14127. qjl.setLock_id(param1.get(6).toString());
  14128. qjl.setMaterial_no(param1.get(0).toString());
  14129. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  14130. if(listsu.size() >0)
  14131. {
  14132. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  14133. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  14134. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  14135. }
  14136. mapper.UpdateQcmJudgeLocking1(qjl);
  14137. int count = 0;
  14138. String condition = " and MATERIAL_NO = '"+param1.get(0).toString()+"' order by LOCK_SEQ desc ";
  14139. List<QCMJudgeLocking> qjlk = mapper.queryQCMJudgeLocking(condition);
  14140. if(qjlk.size() > 0){
  14141. count=qjlk.get(0).getLock_seq();
  14142. }
  14143. count++;
  14144. //锁定记录号
  14145. int lock_seq=count;
  14146. qjl.setLock_seq(lock_seq);
  14147. qjl.setUnlock_type_code("");
  14148. qjl.setUnlock_type_desc("");
  14149. qjl.setLock_memo("待判");
  14150. qjl.setTarget_design_key("");
  14151. qjl.setUnlock_name("");
  14152. mapper.insertQCMJudgeLocking(qjl);
  14153. if(param1.get(0).toString().startsWith("Z") || param1.get(0).toString().startsWith("H")){
  14154. sql = "select billetid from kch_turnofflist@xgcx where storagestatus = '501602' and billetid = '" + param1.get(0).toString() + "'"
  14155. + " union all select billetid from kcz_turnofflist@xgcx where storagestatus = '501602' and billetid = '" + param1.get(0).toString() + "' UNION ALL "
  14156. + " select billetid from kcj_turnofflist@xgcx where storagestatus = '501602' and billetid = '" + param1.get(0).toString() + "' union all "
  14157. + " select billetid from kcj_storagelist@xgcx where storagestatus = '501002' and billetid = '" + param1.get(0).toString() + "'";
  14158. List<HashMap> listB = mapper.query(sql);
  14159. if(listB.size() >0){
  14160. ultimateJudgeAuto(param1.get(0).toString(),param1.get(5).toString(),"0");
  14161. }
  14162. }
  14163. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  14164. qjog.setOperate_name(param1.get(5).toString());
  14165. qjog.setOperate_type("异常处置待判");
  14166. qjog.setParams(param1.get(0).toString());
  14167. qjog.setBatchno(qjls.get(0).getBatch_no());
  14168. qjog.setProd_line(qjl.getPline_code());
  14169. mapper.insertQcmJudgeOperateLog(qjog);
  14170. SqlSession.commit();
  14171. }
  14172. if(param1.get(3).toString().equals("16")){
  14173. List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(param1.get(0).toString());
  14174. qjl.setUnlock_type_code("16");
  14175. qjl.setUnlock_type_desc("按母板件件取样");
  14176. qjl.setUnlock_memo(param1.get(4).toString());
  14177. qjl.setUnlock_result(param1.get(9).toString());
  14178. qjl.setUnlock_name(param1.get(5).toString());
  14179. //qjl.setLock_id(param1.get(6).toString());
  14180. List<HashMap> listz = mapper.query("select a.motherslab from zyhb_plandetailofplate@xgcx a where a.slabno = '"+param1.get(0).toString()+"' " +
  14181. " union all " +
  14182. " select a.motherslab from ZYHB_PLANDETAILOFPLATE_ZJNEW@xgcx a where a.slabno = '"+param1.get(0).toString()+"' " +
  14183. " union all " +
  14184. " select a.motherplateid from mb_plandetailofplate@xgcx a where a.productno = '"+param1.get(0).toString()+"'");
  14185. if(param1.get(2).toString().equals("P")){
  14186. if(listz.size() == 0){
  14187. return cro;
  14188. }
  14189. /*sql = "select * from qcm_judge_locking where lock_id = '"+param1.get(6).toString()+"' and material_no like '"+listz.get(0).get("MOTHERSLAN")+"' and unlock_type_code is null and lock_type_code = 'P' ";
  14190. List<QCMJudgeLocking> qjlt = mapper.queryQCMJudgeLockings(sql);*/
  14191. List<QcmJudgePhysical> list = mapper.queryQcmJudgePhysical("select * from qcm_judge_physical where phy_id = '"+param1.get(6).toString()+"'");
  14192. if(list1.size() >0 || list2.size() >0){
  14193. if(list1.size()>0){
  14194. for(HashMap lists:list1){
  14195. if(!lists.get("JUDGERESULT").toString().equals("0")){
  14196. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能放行!");
  14197. }
  14198. }
  14199. qjl.setPic_locking("0");
  14200. qjl.setMaterial_no(listz.get(0).get("MOTHERSLAB").toString());
  14201. qjl.setBatch_no(qjls.get(0).getBatch_no());
  14202. qjl.setLock_id(param1.get(6).toString());
  14203. qjl.setReason_code(param1.get(7).toString());
  14204. qjl.setLock_type_code(param1.get(2).toString());
  14205. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  14206. if(listsu.size() >0)
  14207. {
  14208. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  14209. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  14210. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  14211. }
  14212. mapper.UpdateQcmJudgeLocking6(qjl);
  14213. ZjResultAll zra = new ZjResultAll();
  14214. SendGenerationSampleInfo("",hashmap,param1,"16","1","");
  14215. //zra.setBilletid(param1.get(0).toString());
  14216. zra.setBilletid_jy(list1.get(0).get("BILLETID_JY").toString());
  14217. zra.setBilletid(listz.get(0).get("MOTHERSLAB").toString());
  14218. if(list.get(0).getCert_inst_name().equals("检测中心"))
  14219. {
  14220. zra.setPhyfstsresult("0");
  14221. zra.setPhyfstsresult_desc("");
  14222. }
  14223. zra.setPhysresult("0");
  14224. zra.setPic_is_lock("0");
  14225. zra.setPhysresult_desc("");
  14226. mapper.UpdateJugeResultB1(zra);
  14227. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  14228. qjog.setOperate_name(param1.get(5).toString());
  14229. qjog.setOperate_type("按母板取样");
  14230. qjog.setParams(listz.get(0).get("MOTHERSLAB").toString());
  14231. qjog.setBatchno(qjls.get(0).getBatch_no());
  14232. qjog.setProd_line(qjl.getPline_code());
  14233. mapper.insertQcmJudgeOperateLog(qjog);
  14234. SqlSession.commit();
  14235. }
  14236. }
  14237. }
  14238. }
  14239. //性能改善
  14240. if(param1.get(3).toString().equals("17")){
  14241. List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(param1.get(0).toString());
  14242. //重新
  14243. //质量锁定解锁
  14244. qjl.setUnlock_type_code("17");
  14245. qjl.setUnlock_type_desc("性能改善");
  14246. qjl.setUnlock_memo(param1.get(4).toString());
  14247. qjl.setUnlock_result(param1.get(9).toString());
  14248. qjl.setUnlock_name(param1.get(5).toString());
  14249. if(param1.get(2).toString().equals("P")){
  14250. qjl.setPic_locking("0");
  14251. List<QcmJudgePhysical> list = mapper.queryQcmJudgePhysical("select * from qcm_judge_physical where phy_id = '"+param1.get(6).toString()+"'");
  14252. //更新库存表
  14253. if(list1.size() >0 || list2.size() >0){
  14254. if(list1.size()>0){
  14255. for(HashMap lists:list1){
  14256. if(!lists.get("JUDGERESULT").toString().equals("0")){
  14257. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能性能改善!");
  14258. }
  14259. }
  14260. ZjResultAll zra = new ZjResultAll();
  14261. if(list.get(0).getCert_inst_name().equals("检测中心"))
  14262. {
  14263. zra.setPhyfstsresult("0");
  14264. zra.setPhyfstsresult_desc("");
  14265. }
  14266. zra.setPhysresult("0");
  14267. zra.setPhysresult_desc("");
  14268. zra.setBilletid_jy(list1.get(0).get("BILLETID_JY").toString());
  14269. zra.setPic_is_lock("0");
  14270. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  14271. for(HashMap lists:list1){
  14272. //质量异常材处置
  14273. qjl = new QCMJudgeLocking();
  14274. qjl.setUnlock_type_code("17");
  14275. qjl.setUnlock_type_desc("性能改善");
  14276. qjl.setUnlock_memo(param1.get(4).toString());
  14277. qjl.setPic_locking("0");
  14278. //qjl.setMaterial_no(lists.get("BILLETID").toString());
  14279. qjl.setBatch_no(qjls.get(0).getBatch_no());
  14280. qjl.setUnlock_name(param1.get(5).toString());
  14281. qjl.setLock_id(param1.get(6).toString());
  14282. qjl.setReason_code(param1.get(7).toString());
  14283. qjl.setLock_type_code(param1.get(2).toString());
  14284. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  14285. if(listsu.size() >0)
  14286. {
  14287. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  14288. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  14289. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  14290. }
  14291. mapper.UpdateQcmJudgeLocking1(qjl);
  14292. }
  14293. SendGenerationSampleInfo("",hashmap,param1,"1","1","");
  14294. mapper.UpdateJugeResultB(zra);
  14295. sql = "select * from qcm_judge_locking where batch_no = '"+qjls.get(0).getBatch_no()+"'";
  14296. List<QCMJudgeLocking> qjlf = mapper.queryQCMJudgeLockings(sql);
  14297. for(QCMJudgeLocking qjll:qjlf){
  14298. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  14299. qjog.setOperate_name(param1.get(5).toString());
  14300. qjog.setOperate_type("性能改善");
  14301. qjog.setParams(qjll.getMaterial_no());
  14302. qjog.setBatchno(qjls.get(0).getBatch_no());
  14303. qjog.setProd_line(qjl.getPline_code());
  14304. mapper.insertQcmJudgeOperateLog(qjog);
  14305. }
  14306. SqlSession.commit();
  14307. }
  14308. }else{
  14309. throw new Exception("未找到库存信息!");
  14310. }
  14311. }else{
  14312. throw new Exception("封锁来源与所选的异常材处置操作不一致,请重新选择处置操作!");
  14313. }
  14314. //
  14315. }
  14316. //单吊材质判定
  14317. if(param1.get(3).toString().equals("18")){
  14318. List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(param1.get(0).toString());
  14319. //重新
  14320. //质量锁定解锁
  14321. qjl.setUnlock_type_code("18");
  14322. qjl.setUnlock_type_desc("单吊材质判定");
  14323. qjl.setUnlock_memo(param1.get(4).toString());
  14324. qjl.setUnlock_name(param1.get(5).toString());
  14325. if(param1.get(2).toString().equals("P")){
  14326. qjl.setPic_locking("0");
  14327. qjl.setMaterial_no(param1.get(0).toString());
  14328. //更新库存表
  14329. if(list1.size() >0 || list2.size() >0){
  14330. if(list1.size()>0){
  14331. for(HashMap lists:list1){
  14332. if(!lists.get("JUDGERESULT").toString().equals("0")){
  14333. throw new Exception("该产品序号["+param1.get(0).toString()+"]做了综合判定,不能单吊材质判定!");
  14334. }
  14335. }
  14336. /*ZjResultAll zra = new ZjResultAll();
  14337. zra.setPhysresult("0");
  14338. zra.setPhysresult_desc("");
  14339. zra.setBilletid(param1.get(0).toString());
  14340. zra.setPic_is_lock("0");*/
  14341. QcmJudgePhysicalServiceImpl qjpsi = new QcmJudgePhysicalServiceImpl();
  14342. for(HashMap lists:list1){
  14343. //质量异常材处置
  14344. qjl = new QCMJudgeLocking();
  14345. qjl.setUnlock_type_code("18");
  14346. qjl.setUnlock_type_desc("单吊材质判定");
  14347. qjl.setUnlock_memo(param1.get(4).toString());
  14348. qjl.setPic_locking("0");
  14349. qjl.setMaterial_no(lists.get("BILLETID").toString());
  14350. qjl.setBatch_no(qjls.get(0).getBatch_no());
  14351. qjl.setUnlock_name(param1.get(5).toString());
  14352. qjl.setLock_id(param1.get(6).toString());
  14353. qjl.setReason_code(param1.get(7).toString());
  14354. qjl.setLock_type_code(param1.get(2).toString());
  14355. List<HashMap> listsu = qjft.finddefecttype(param1.get(7).toString());
  14356. if(listsu.size() >0)
  14357. {
  14358. qjl.setReason_desc(listsu.get(0).get("DEFECT_DESC")==null?"":listsu.get(0).get("DEFECT_DESC").toString());
  14359. qjl.setFlaw_code(listsu.get(0).get("DEFECT_TYPE_CODE")==null?"":listsu.get(0).get("DEFECT_TYPE_CODE").toString());
  14360. qjl.setFlaw_desc(listsu.get(0).get("DEFECT_TYPE_DESC") == null ?"":listsu.get(0).get("DEFECT_TYPE_DESC").toString());
  14361. }
  14362. mapper.UpdateQcmJudgeLocking1(qjl);
  14363. }
  14364. List<HashMap> lists = mapper.query("select * from qcm_jhy_sample_consign_d a where a.material_no = '"+param1.get(0).toString()+"' AND A.SMP_TYPE_CODE IN ('0','1')");
  14365. String smp_no = "";
  14366. String smp_type_code = "";
  14367. if(lists.size() >0){
  14368. smp_no = lists.get(0).get("SMP_NO").toString();
  14369. smp_type_code = lists.get(0).get("SMP_TYPE_CODE").toString();
  14370. }else{
  14371. throw new Exception("未找到该物料委托实绩信息!");
  14372. }
  14373. QcmJudgeOperateLog qjog = new QcmJudgeOperateLog();
  14374. qjog.setOperate_name(param1.get(5).toString());
  14375. qjog.setOperate_type("单吊材质判定");
  14376. qjog.setParams(smp_no);
  14377. qjog.setBatchno(qjls.get(0).getBatch_no());
  14378. qjog.setProd_line(qjls.get(0).getPline_code());
  14379. mapper.insertQcmJudgeOperateLog(qjog);
  14380. /*mapper.UpdateJugeResultB(zra);*/
  14381. HashMap hs = new HashMap();
  14382. hs.put("BATCH_NO", qjls.get(0).getBatch_no());
  14383. hs.put("SMP_NO", smp_no);
  14384. hs.put("MATERIAL_NO", param1.get(0).toString());
  14385. hs.put("SMP_TYPE_CODE", smp_type_code);
  14386. hs.put("DESIGN_KEY", qjls.get(0).getDesign_key());
  14387. hs.put("PLINE_CODE", qjls.get(0).getPline_code());
  14388. hs.put("CREATE_NAME", param1.get(5).toString());
  14389. //复样
  14390. try {
  14391. String result = sentenceDuplicateSample(hs);
  14392. if(!result.equals("1")){
  14393. throw new Exception(result);
  14394. }
  14395. } catch (Exception e) {
  14396. // TODO Auto-generated catch block
  14397. throw new Exception(e.getMessage());
  14398. }
  14399. SqlSession.commit();
  14400. }
  14401. }else{
  14402. throw new Exception("未找到库存信息!");
  14403. }
  14404. }else{
  14405. throw new Exception("封锁来源与所选的异常材处置操作不一致,请重新选择处置操作!");
  14406. }
  14407. //
  14408. }
  14409. }catch(Exception e){
  14410. cro.setV_errCode(-1);
  14411. cro.setV_errMsg(e.getMessage());
  14412. SqlSession.rollback();
  14413. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.doInformationSure:【" + param1.toString() + "】" + e);
  14414. }
  14415. SqlSession.close();
  14416. return cro;
  14417. }
  14418. public String sentenceDuplicateSample(HashMap parmas) throws Exception{
  14419. if (parmas==null || "".equals(parmas)) {
  14420. return "请传入参数!";
  14421. }
  14422. if (StringUtils.isBlank(parmas.get("MATERIAL_NO").toString())) {
  14423. return "请传入参数";
  14424. }
  14425. String result = "";
  14426. WebService1Impl web = new WebService1Impl();
  14427. //复样
  14428. try {
  14429. result = web.sentenceDuplicateSample(parmas);
  14430. if(!result.equals("1")){
  14431. throw new Exception(result);
  14432. }
  14433. } catch (Exception e) {
  14434. // TODO Auto-generated catch block
  14435. throw new Exception(e.getMessage());
  14436. }
  14437. /*DuplicateSample2 sample=new DuplicateSample2();
  14438. String msg = "";
  14439. try {
  14440. msg = sample.doSentenceDuplicateSample(parmas);
  14441. } catch (Exception e) {
  14442. e.printStackTrace();
  14443. }
  14444. return result;*/
  14445. return result;
  14446. }
  14447. /**
  14448. * 比较val值,根据判定依据比较
  14449. * @param val1
  14450. * @param val2
  14451. * @param val3
  14452. * @param type
  14453. * @return
  14454. */
  14455. public String compareVal(String val1,String val2,String val3,String val4,String val5,String val6,String val7,String val8,String val9,String type){
  14456. String flag="";
  14457. String max = "";
  14458. String min = "";
  14459. //最小值
  14460. if (type.equalsIgnoreCase("A")) {
  14461. //如果val1不为空
  14462. if (!SqlJoint.IsNullOrSpace(val1)) {
  14463. flag=val1;
  14464. if (!SqlJoint.IsNullOrSpace(val2)) {
  14465. if (flag.compareTo(val2)>=0) {
  14466. flag=val2;
  14467. if (!SqlJoint.IsNullOrSpace(val3)) {
  14468. if (flag.compareTo(val3)>=0) {
  14469. flag=val3;
  14470. }
  14471. }
  14472. }else {
  14473. if (!SqlJoint.IsNullOrSpace(val3)) {
  14474. if (flag.compareTo(val3)>=0) {
  14475. flag=val3;
  14476. }
  14477. }
  14478. }
  14479. }else {
  14480. if (!SqlJoint.IsNullOrSpace(val3)) {
  14481. if (flag.compareTo(val3)>=0) {
  14482. flag=val3;
  14483. }
  14484. }
  14485. }
  14486. return flag;
  14487. }
  14488. //如果val1为空
  14489. if (!SqlJoint.IsNullOrSpace(val2)) {
  14490. flag=val2;
  14491. if (!SqlJoint.IsNullOrSpace(val3)) {
  14492. if (flag.compareTo(val3)>=0) {
  14493. flag=val3;
  14494. }
  14495. }
  14496. return flag;
  14497. }
  14498. //如果val1和val2都为空
  14499. if (!SqlJoint.IsNullOrSpace(val3)) {
  14500. flag=val3;
  14501. return flag;
  14502. }
  14503. }
  14504. //最大值
  14505. if (type.equalsIgnoreCase("B")) {
  14506. //如果val1不为空
  14507. if (!SqlJoint.IsNullOrSpace(val1)) {
  14508. flag=val1;
  14509. if (!SqlJoint.IsNullOrSpace(val2)) {
  14510. if (flag.compareTo(val2)<=0) {
  14511. flag=val2;
  14512. if (!SqlJoint.IsNullOrSpace(val3)) {
  14513. if (flag.compareTo(val3)<=0) {
  14514. flag=val3;
  14515. }
  14516. }
  14517. }else {
  14518. if (!SqlJoint.IsNullOrSpace(val3)) {
  14519. if (flag.compareTo(val3)<=0) {
  14520. flag=val3;
  14521. }
  14522. }
  14523. }
  14524. }else {
  14525. if (!SqlJoint.IsNullOrSpace(val3)) {
  14526. if (flag.compareTo(val3)<=0) {
  14527. flag=val3;
  14528. }
  14529. }
  14530. }
  14531. return flag;
  14532. }
  14533. //如果val1为空
  14534. if (!SqlJoint.IsNullOrSpace(val2)) {
  14535. flag=val2;
  14536. if (!SqlJoint.IsNullOrSpace(val3)) {
  14537. if (flag.compareTo(val3)<=0) {
  14538. flag=val3;
  14539. }
  14540. }
  14541. return flag;
  14542. }
  14543. //如果val1和val2都为空
  14544. if (!SqlJoint.IsNullOrSpace(val3)) {
  14545. flag=val3;
  14546. return flag;
  14547. }
  14548. }
  14549. //平均值判定
  14550. if (type.equalsIgnoreCase("C")) {
  14551. if (!SqlJoint.IsNullOrSpace(val1)) {
  14552. flag=val1;
  14553. if (!SqlJoint.IsNullOrSpace(val2)) {
  14554. if (!SqlJoint.IsNullOrSpace(val3)) {
  14555. Double a=(Double.parseDouble(val1)+Double.parseDouble(val2)+Double.parseDouble(val3))/3;
  14556. flag=a.toString();
  14557. }else {
  14558. Double a=(Double.parseDouble(val1)+Double.parseDouble(val2))/2;
  14559. flag=a.toString();
  14560. }
  14561. }else {
  14562. if (!SqlJoint.IsNullOrSpace(val3)) {
  14563. Double a=(Double.parseDouble(val1)+Double.parseDouble(val3))/2;
  14564. flag=a.toString();
  14565. }
  14566. }
  14567. }else {
  14568. if (!SqlJoint.IsNullOrSpace(val2)) {
  14569. flag=val2;
  14570. if (!SqlJoint.IsNullOrSpace(val3)) {
  14571. Double a=(Double.parseDouble(val2)+Double.parseDouble(val3))/2;
  14572. flag=a.toString();
  14573. }
  14574. }else {
  14575. if (!SqlJoint.IsNullOrSpace(val3)) {
  14576. flag=val3;
  14577. }
  14578. }
  14579. }
  14580. return flag;
  14581. }
  14582. //最大最小差值
  14583. if (type.equalsIgnoreCase("D")) {
  14584. //如果val1不为空
  14585. if (!SqlJoint.IsNullOrSpace(val1)) {
  14586. min=val1;
  14587. if (!SqlJoint.IsNullOrSpace(val2)) {
  14588. if (min.compareTo(val2)>=0) {
  14589. min=val2;
  14590. if (!SqlJoint.IsNullOrSpace(val3)) {
  14591. if (min.compareTo(val3)>=0) {
  14592. min=val3;
  14593. }
  14594. }
  14595. }else {
  14596. if (!SqlJoint.IsNullOrSpace(val3)) {
  14597. if (min.compareTo(val3)>=0) {
  14598. min=val3;
  14599. }
  14600. }
  14601. }
  14602. }else {
  14603. if (!SqlJoint.IsNullOrSpace(val3)) {
  14604. if (min.compareTo(val3)>=0) {
  14605. min=val3;
  14606. }
  14607. }
  14608. }
  14609. }else if (!SqlJoint.IsNullOrSpace(val2)) {
  14610. min=val2;
  14611. if (!SqlJoint.IsNullOrSpace(val3)) {
  14612. if (min.compareTo(val3)>=0) {
  14613. min=val3;
  14614. }
  14615. }
  14616. }else if (!SqlJoint.IsNullOrSpace(val3)) {
  14617. min=val3;
  14618. }
  14619. //如果val1不为空
  14620. if (!SqlJoint.IsNullOrSpace(val1)) {
  14621. max=val1;
  14622. if (!SqlJoint.IsNullOrSpace(val2)) {
  14623. if (max.compareTo(val2)<=0) {
  14624. max=val2;
  14625. if (!SqlJoint.IsNullOrSpace(val3)) {
  14626. if (max.compareTo(val3)<=0) {
  14627. max=val3;
  14628. }
  14629. }
  14630. }else {
  14631. if (!SqlJoint.IsNullOrSpace(val3)) {
  14632. if (max.compareTo(val3)<=0) {
  14633. max=val3;
  14634. }
  14635. }
  14636. }
  14637. }else {
  14638. if (!SqlJoint.IsNullOrSpace(val3)) {
  14639. if (max.compareTo(val3)<=0) {
  14640. max=val3;
  14641. }
  14642. }
  14643. }
  14644. }else if (!SqlJoint.IsNullOrSpace(val2)) {
  14645. max=val2;
  14646. if (!SqlJoint.IsNullOrSpace(val3)) {
  14647. if (max.compareTo(val3)<=0) {
  14648. max=val3;
  14649. }
  14650. }
  14651. }else if (!SqlJoint.IsNullOrSpace(val3)) {
  14652. max=val3;
  14653. }
  14654. if(!SqlJoint.IsNullOrSpace(max)){
  14655. if(SqlJoint.IsNullOrSpace(min)){
  14656. flag = max;
  14657. }else{
  14658. flag = String.valueOf(Double.parseDouble(max)-Double.parseDouble(min));
  14659. }
  14660. }
  14661. }
  14662. return flag;
  14663. }
  14664. /**
  14665. * 为前端获取对比结果好标颜色
  14666. * 0 为null
  14667. * 1 为合格
  14668. * 2为不合格
  14669. * @param sign 符号
  14670. * @param qsd 标准值
  14671. * @param val1 实测值
  14672. * @param val2
  14673. * @param val3
  14674. * @return
  14675. */
  14676. public String getJudgeColor(String sign,String qsd,String val1,String val2,String val3,String val4,String val5,String val6,String val7,String val8,String val9){
  14677. boolean min1=true;
  14678. boolean min3=true;
  14679. boolean min2=true;
  14680. boolean min4=true;
  14681. boolean min5=true;
  14682. boolean min6=true;
  14683. boolean min7=true;
  14684. boolean min8=true;
  14685. boolean min9=true;
  14686. boolean v1=true;
  14687. boolean v2=true;
  14688. boolean v3=true;
  14689. boolean v4=true;
  14690. boolean v5=true;
  14691. boolean v6=true;
  14692. boolean v7=true;
  14693. boolean v8=true;
  14694. boolean v9=true;
  14695. boolean q=true;
  14696. if (SqlJoint.IsNullOrSpace(qsd)) {
  14697. return "0";
  14698. }
  14699. if (!SqlJoint.IsNullOrSpace(qsd)) {
  14700. q=isNumeric(qsd);
  14701. }
  14702. if (!SqlJoint.IsNullOrSpace(val1)) {
  14703. v1=isNumeric(val1);
  14704. }
  14705. if (!SqlJoint.IsNullOrSpace(val2)) {
  14706. v2=isNumeric(val2);
  14707. }
  14708. if (!SqlJoint.IsNullOrSpace(val3)) {
  14709. v3=isNumeric(val3);
  14710. }
  14711. if (!SqlJoint.IsNullOrSpace(val4)) {
  14712. v4=isNumeric(val4);
  14713. }
  14714. if (!SqlJoint.IsNullOrSpace(val5)) {
  14715. v5=isNumeric(val5);
  14716. }
  14717. if (!SqlJoint.IsNullOrSpace(val6)) {
  14718. v6=isNumeric(val6);
  14719. }
  14720. if (!SqlJoint.IsNullOrSpace(val7)) {
  14721. v7=isNumeric(val7);
  14722. }
  14723. if (!SqlJoint.IsNullOrSpace(val8)) {
  14724. v8=isNumeric(val8);
  14725. }
  14726. if (!SqlJoint.IsNullOrSpace(val9)) {
  14727. v9=isNumeric(val9);
  14728. }
  14729. if (!q) {
  14730. if (!SqlJoint.IsNullOrSpace(val1)) {
  14731. min1=qsd.equals(val1);
  14732. }
  14733. if (!SqlJoint.IsNullOrSpace(val2)) {
  14734. min2=qsd.equals(val2);
  14735. }
  14736. if (!SqlJoint.IsNullOrSpace(val3)) {
  14737. min3=qsd.equals(val3);
  14738. }
  14739. if (!SqlJoint.IsNullOrSpace(val4)) {
  14740. min4=qsd.equals(val4);
  14741. }
  14742. if (!SqlJoint.IsNullOrSpace(val5)) {
  14743. min5=qsd.equals(val5);
  14744. }
  14745. if (!SqlJoint.IsNullOrSpace(val6)) {
  14746. min6=qsd.equals(val6);
  14747. }
  14748. if (!SqlJoint.IsNullOrSpace(val7)) {
  14749. min7=qsd.equals(val7);
  14750. }
  14751. if (!SqlJoint.IsNullOrSpace(val8)) {
  14752. min8=qsd.equals(val8);
  14753. }
  14754. if (!SqlJoint.IsNullOrSpace(val9)) {
  14755. min9=qsd.equals(val9);
  14756. }
  14757. if (SqlJoint.IsNullOrSpace(val1)&&SqlJoint.IsNullOrSpace(val2)&&SqlJoint.IsNullOrSpace(val3)&&SqlJoint.IsNullOrSpace(val4)&&SqlJoint.IsNullOrSpace(val5)&&SqlJoint.IsNullOrSpace(val6)&&SqlJoint.IsNullOrSpace(val7)&&SqlJoint.IsNullOrSpace(val8)&&SqlJoint.IsNullOrSpace(val9)) {
  14758. return "0";
  14759. }
  14760. if (min1&&min2&&min3&&min4&&min5&&min6&&min7&&min8&&min9) {
  14761. return "1";
  14762. }else {
  14763. return "2";
  14764. }
  14765. }
  14766. if(v1){
  14767. min1=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val1);
  14768. }else{
  14769. min1=qsd.equals(val1);
  14770. }
  14771. if(v2){
  14772. min2=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val2);
  14773. }else{
  14774. min2=qsd.equals(val2);
  14775. }
  14776. if(v3){
  14777. min3=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val3);
  14778. }else{
  14779. min3=qsd.equals(val3);
  14780. }
  14781. if(v4){
  14782. min4=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val4);
  14783. }else{
  14784. min4=qsd.equals(val4);
  14785. }
  14786. if(v5){
  14787. min5=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val5);
  14788. }else{
  14789. min5=qsd.equals(val5);
  14790. }
  14791. if(v6){
  14792. min6=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val6);
  14793. }else{
  14794. min6=qsd.equals(val6);
  14795. }
  14796. if(v7){
  14797. min7=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val7);
  14798. }else{
  14799. min7=qsd.equals(val7);
  14800. }
  14801. if(v8){
  14802. min8=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val8);
  14803. }else{
  14804. min8=qsd.equals(val8);
  14805. }
  14806. if(v9){
  14807. min9=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val9);
  14808. }else{
  14809. min9=qsd.equals(val9);
  14810. }
  14811. if (min1&&min2&&min3&&min4&&min5&&min6&&min7&&min8&&min9) {
  14812. return "1";
  14813. }else {
  14814. return "2";
  14815. }
  14816. }
  14817. /**
  14818. * 为前端获取对比结果好标颜色
  14819. * 0 为null
  14820. * 1 为合格
  14821. * 2为不合格
  14822. * @param sign 符号
  14823. * @param qsd 标准值
  14824. * @param val1 实测值
  14825. * @param val2
  14826. * @param val3
  14827. * @return
  14828. */
  14829. public String getJudgeColor1(String sign,String qsd,String val1,String val2,String val3){
  14830. boolean min1=true;
  14831. boolean min3=true;
  14832. boolean min2=true;
  14833. boolean v1=true;
  14834. boolean v2=true;
  14835. boolean v3=true;
  14836. boolean q=true;
  14837. if (SqlJoint.IsNullOrSpace(qsd)) {
  14838. return "0";
  14839. }
  14840. if (!SqlJoint.IsNullOrSpace(qsd)) {
  14841. q=isNumeric(qsd);
  14842. }
  14843. if (!SqlJoint.IsNullOrSpace(val1)) {
  14844. v1=isNumeric(val1);
  14845. }
  14846. if (!SqlJoint.IsNullOrSpace(val2)) {
  14847. v2=isNumeric(val2);
  14848. }
  14849. if (!SqlJoint.IsNullOrSpace(val3)) {
  14850. v3=isNumeric(val3);
  14851. }
  14852. if (!q) {
  14853. if (!SqlJoint.IsNullOrSpace(val1)) {
  14854. min1=qsd.equals(val1);
  14855. }
  14856. if (!SqlJoint.IsNullOrSpace(val2)) {
  14857. min2=qsd.equals(val2);
  14858. }
  14859. if (!SqlJoint.IsNullOrSpace(val3)) {
  14860. min3=qsd.equals(val3);
  14861. }
  14862. if (SqlJoint.IsNullOrSpace(val1)&&SqlJoint.IsNullOrSpace(val2)&&SqlJoint.IsNullOrSpace(val3)) {
  14863. return "0";
  14864. }
  14865. if (min1&&min2&&min3) {
  14866. return "1";
  14867. }else {
  14868. return "2";
  14869. }
  14870. }
  14871. ////111111111111111
  14872. if (!v1) {
  14873. if (v2) {
  14874. if (v3) {
  14875. min1=qsd.equals(val1);
  14876. min2=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val2);
  14877. min3=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val3);
  14878. }else {
  14879. min1=qsd.equals(val1);
  14880. min2=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val2);
  14881. min3=qsd.equals(val3);
  14882. }
  14883. }else {
  14884. if (v3) {
  14885. min1=qsd.equals(val1);
  14886. min2=qsd.equals(val2);
  14887. min3=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val3);
  14888. }else {
  14889. min1=qsd.equals(val1);
  14890. min2=qsd.equals(val2);
  14891. min3=qsd.equals(val3);
  14892. }
  14893. }
  14894. if (min1&&min2&&min3) {
  14895. return "1";
  14896. }else {
  14897. return "2";
  14898. }
  14899. }
  14900. //2222222222222222222222222
  14901. if (!v2) {
  14902. if (v1) {
  14903. if (v3) {
  14904. min2=qsd.equals(val2);
  14905. min1=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val1);
  14906. min3=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val3);
  14907. }else {
  14908. min2=qsd.equals(val2);
  14909. min1=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val1);
  14910. min3=qsd.equals(val3);
  14911. }
  14912. }else {
  14913. if (v3) {
  14914. min1=qsd.equals(val1);
  14915. min2=qsd.equals(val2);
  14916. min3=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val3);
  14917. }else {
  14918. min1=qsd.equals(val1);
  14919. min2=qsd.equals(val2);
  14920. min3=qsd.equals(val3);
  14921. }
  14922. }
  14923. if (min1&&min2&&min3) {
  14924. return "1";
  14925. }else {
  14926. return "2";
  14927. }
  14928. }
  14929. //3333333333333333333333333
  14930. if (!v3) {
  14931. if (v1) {
  14932. if (v2) {
  14933. min3=qsd.equals(val3);
  14934. min1=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val1);
  14935. min2=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val2);
  14936. }else {
  14937. min2=qsd.equals(val2);
  14938. min1=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val1);
  14939. min3=qsd.equals(val3);
  14940. }
  14941. }else {
  14942. if (v2) {
  14943. min1=qsd.equals(val1);
  14944. min3=qsd.equals(val3);
  14945. min2=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val2);
  14946. }else {
  14947. min1=qsd.equals(val1);
  14948. min2=qsd.equals(val2);
  14949. min3=qsd.equals(val3);
  14950. }
  14951. }
  14952. if (min1&&min2&&min3) {
  14953. return "1";
  14954. }else {
  14955. return "2";
  14956. }
  14957. }
  14958. if (qsd!=null) {
  14959. min1=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val1);
  14960. min2=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val2);
  14961. min3=SqlJoint.checkSignAndValue(sign, Double.parseDouble(qsd), val3);
  14962. if (min1&&min2&&min3) {
  14963. return "1";
  14964. }else {
  14965. return "2";
  14966. }
  14967. }else {
  14968. return "0";
  14969. }
  14970. }
  14971. /**
  14972. * 判断字符串是否为数字
  14973. * @param str
  14974. * @return
  14975. */
  14976. public boolean isNumeric(String str){
  14977. Pattern pattern = Pattern.compile("[0-9]+([.]{1}[0-9]+){0,1}");
  14978. Matcher isNum = pattern.matcher(str);
  14979. if( !isNum.matches() ){
  14980. return false;
  14981. }
  14982. return true;
  14983. }
  14984. /**
  14985. * 拼接val值----异常材料处理用---2019.1.8
  14986. * @param jyx
  14987. * @param val1
  14988. * @param val2
  14989. * @param val3
  14990. * @return
  14991. */
  14992. public String connectVal(String jyx,String val1,String val2,String val3){
  14993. if (!SqlJoint.IsNullOrSpace(val1)) {
  14994. if (!SqlJoint.IsNullOrSpace(val2)) {
  14995. if (!SqlJoint.IsNullOrSpace(val3)) {
  14996. jyx=jyx+":"+val1+"-"+val2+"-"+val3;
  14997. }else {
  14998. jyx=jyx+":"+val1+"-"+val2;
  14999. }
  15000. }else {
  15001. if (!SqlJoint.IsNullOrSpace(val3)) {
  15002. jyx=jyx+":"+val1+"-"+val3;
  15003. }else {
  15004. jyx=jyx+":"+val1;
  15005. }
  15006. }
  15007. }
  15008. if (!SqlJoint.IsNullOrSpace(val2)) {
  15009. if (!SqlJoint.IsNullOrSpace(val1)) {
  15010. if (!SqlJoint.IsNullOrSpace(val3)) {
  15011. jyx=jyx+":"+val1+"-"+val2+"-"+val3;
  15012. }else {
  15013. jyx=jyx+":"+val1+"-"+val2;
  15014. }
  15015. }else {
  15016. if (!SqlJoint.IsNullOrSpace(val3)) {
  15017. jyx=jyx+":"+val2+"-"+val3;
  15018. }else {
  15019. jyx=jyx+":"+val2;
  15020. }
  15021. }
  15022. }
  15023. if (!SqlJoint.IsNullOrSpace(val3)) {
  15024. if (!SqlJoint.IsNullOrSpace(val1)) {
  15025. if (!SqlJoint.IsNullOrSpace(val2)) {
  15026. jyx=jyx+":"+val1+"-"+val2+"-"+val3;
  15027. }else {
  15028. jyx=jyx+":"+val1+"-"+val3;
  15029. }
  15030. }else {
  15031. if (!SqlJoint.IsNullOrSpace(val2)) {
  15032. jyx=jyx+":"+val2+"-"+val3;
  15033. }else {
  15034. jyx=jyx+":"+val3;
  15035. }
  15036. }
  15037. }
  15038. return jyx;
  15039. }
  15040. @SuppressWarnings("rawtypes")
  15041. public CoreReturnObject GetElementsInfo1(String assay_no) {
  15042. try {
  15043. String sql = "select a.assay_no,a.heat_no,a.batch_no,a.inspection_lot,a.smp_no,a.specimen_no, "
  15044. + " a.material_no, a.pline_code, a.pline_name,a.steel_code,a.steel_name,a.assay_type, "
  15045. + " a.chem_code,a.chem_name,case when a.chem_value > -1 and a.chem_value < 1 and a.chem_value != 0 then '0' || round(a.chem_value,7) else '' || round(a.chem_value,7) end chem_value,a.coil_sort, "
  15046. + " a.source,a.sample_type,a.memo, a.create_id, a.create_name, a.create_time from QCM_JHY_INSP_ELEMENTS a where assay_no = '" + assay_no + "' order by length(chem_name) desc";
  15047. List<QcmJhyInspElements> listEle = mapper.queryQcmJhyInspElements(sql);
  15048. cro.setResult(listEle);
  15049. } catch (Exception ex) {
  15050. cro.setV_errCode(-1);
  15051. cro.setV_errMsg("获取成分检验信息出错" + ex.getMessage());
  15052. SqlSession.rollback();
  15053. }
  15054. return cro;
  15055. }
  15056. /**
  15057. * 根据炉号获取成分检验实绩信息
  15058. * @param com
  15059. * @return
  15060. */
  15061. public CoreReturnObject GetElementsInfos(String heatno,String design_key){
  15062. try{
  15063. //"length(chem_name) desc" 这个排序对复合元素计算有用,慎重更改
  15064. String sql = "select a.assay_no,a.heat_no,a.batch_no,a.inspection_lot,a.smp_no,a.specimen_no, "
  15065. + " a.material_no, a.pline_code, a.pline_name,a.steel_code,a.steel_name,a.assay_type, "
  15066. + " a.chem_code,a.chem_name,case when a.chem_value > -1 and a.chem_value < 1 and a.chem_value != 0 then '0' || round(a.chem_value,7) else '' || round(a.chem_value,7) end chem_value,a.coil_sort, "
  15067. + " a.source,a.sample_type,a.memo, a.create_id, a.create_name, a.create_time from QCM_JHY_INSP_ELEMENTS a where assay_no in (select assay_no from (select * from (select a.assay_no, max(a.create_time) create_time "
  15068. + " from QCM_JHY_INSP_ELEMENTS a where a.heat_no = '"+heatno+"' AND ASSAY_TYPE = 'L' group by a.assay_no) order by create_time desc) "
  15069. + " where rownum <= CASE WHEN (select case when z.SMELTING_CNT is null then 1 else z.SMELTING_CNT end from QCM_ORD_DESIGN_STD_CIC_SMP z where z.design_key = '"+design_key+" ' AND STD_TYPE_CODE = 'GA') IS NULL THEN 1 ELSE (select case when z.SMELTING_CNT is null then 1 else z.SMELTING_CNT end from QCM_ORD_DESIGN_STD_CIC_SMP z where z.design_key = '"+design_key+"' AND STD_TYPE_CODE = 'GA') END) order by length(chem_name) desc";
  15070. List<QcmJhyInspElements> listEle=mapper.queryQcmJhyInspElements(sql);
  15071. cro.setResult(listEle);
  15072. }catch(Exception ex){
  15073. cro.setV_errCode(-1);
  15074. cro.setV_errMsg("获取成分检验信息出错"+ex.getMessage());
  15075. SqlSession.rollback();
  15076. }
  15077. return cro;
  15078. }
  15079. public CoreReturnObject GetElementsInfo2(String heatno,String design_key,String board_no){
  15080. try{
  15081. //"length(chem_name) desc" 这个排序对复合元素计算有用,慎重更改
  15082. String sql = "select a.assay_no,a.heat_no,a.batch_no,a.inspection_lot,a.smp_no,a.specimen_no, "
  15083. + " a.material_no, a.pline_code, a.pline_name,a.steel_code,a.steel_name,a.assay_type, "
  15084. + " a.chem_code,a.chem_name,case when a.chem_value > -1 and a.chem_value < 1 and a.chem_value != 0 then '0' || round(a.chem_value,7) else '' || round(a.chem_value,7) end chem_value,a.coil_sort, "
  15085. + " a.source,a.sample_type,a.memo, a.create_id, a.create_name, a.create_time from QCM_JHY_INSP_ELEMENTS a where instr ((select * from (select a.assay_no_rl from qcm_judge_chemical a where a.heat_no = '"+heatno+"' and a.material_no = '"+board_no+"' order by judge_ttime desc) where rownum <= 1), assay_no) > 0 order by length(chem_name) desc";
  15086. List<QcmJhyInspElements> listEle=mapper.queryQcmJhyInspElements(sql);
  15087. cro.setResult(listEle);
  15088. }catch(Exception ex){
  15089. cro.setV_errCode(-1);
  15090. cro.setV_errMsg("获取成分检验信息出错"+ex.getMessage());
  15091. SqlSession.rollback();
  15092. }
  15093. return cro;
  15094. }
  15095. /**
  15096. * 根据炉号获取成分检验实绩信息
  15097. * @param com
  15098. * @return
  15099. */
  15100. public CoreReturnObject GetElementsInfos1(String heatno,String design_key){
  15101. try{
  15102. //"length(chem_name) desc" 这个排序对复合元素计算有用,慎重更改
  15103. String sql = "select assay_no from (select a.assay_no,a.heat_no,a.batch_no,a.inspection_lot,a.smp_no,a.specimen_no, "
  15104. + " a.material_no, a.pline_code, a.pline_name,a.steel_code,a.steel_name,a.assay_type, "
  15105. + " a.chem_code,a.chem_name,case when a.chem_value > -1 and a.chem_value < 1 and a.chem_value != 0 then '0' || round(a.chem_value,7) else '' || round(a.chem_value,7) end chem_value,a.coil_sort, "
  15106. + " a.source,a.sample_type,a.memo, a.create_id, a.create_name, a.create_time from QCM_JHY_INSP_ELEMENTS a where assay_no in (select assay_no from (select * from (select a.assay_no, max(a.create_time) create_time "
  15107. + " from QCM_JHY_INSP_ELEMENTS a where a.heat_no = '"+heatno+"' AND ASSAY_TYPE = 'L' group by a.assay_no) order by create_time desc)) order by length(chem_name) desc) group by assay_no";
  15108. List<QcmJhyInspElements> listEle=mapper.queryQcmJhyInspElements(sql);
  15109. cro.setResult(listEle);
  15110. }catch(Exception ex){
  15111. cro.setV_errCode(-1);
  15112. cro.setV_errMsg("获取成分检验信息出错"+ex.getMessage());
  15113. SqlSession.rollback();
  15114. }
  15115. return cro;
  15116. }
  15117. public CoreReturnObject JfJudge(String material_no,String lock_seq) throws Exception{
  15118. boolean pass=true;
  15119. List<QcmJhyInspElements> listEle=(List<QcmJhyInspElements>)cro.getResult();
  15120. String sql = "select * from qcm_judge_chemical z where z.cic_id in (select a.lock_id from qcm_judge_locking a where material_no = '"+material_no+"' and a.lock_seq = '"+lock_seq+"') ";
  15121. List<HashMap> list = mapper.query(sql);
  15122. String design_key = list.get(0).get("DESIGN_KEY")==null?"":list.get(0).get("DESIGN_KEY").toString();
  15123. cro=GetElementsInfo1(list.get(0).get("ASSAY_NO_RL").toString());
  15124. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15125. //查询判定标准,最后一个参数需要调用生产计划相关接口获取当前使用的制程号
  15126. CoreReturnObject cicModel=GetOrdJudgeStdCicR1(design_key);
  15127. OrdJudgeStd<QCMOrdDesignStdCic> stdCic=(OrdJudgeStd<QCMOrdDesignStdCic>)cicModel.getResult();
  15128. if (pass) {
  15129. if (stdCic.getListStdGB() != null && pass) {
  15130. pass = CompareResult(stdCic.getListStdGB(), listEle);
  15131. if (stdCic.getListStdKH()!=null&&pass) {
  15132. pass=CompareResult(stdCic.getListStdKH(),listEle);
  15133. }
  15134. }
  15135. }
  15136. if(!pass){
  15137. SqlSession.close();
  15138. cro.setV_errCode(-2);
  15139. cro.setV_errMsg("交付标准或特殊标准不合格!");
  15140. return cro;
  15141. }
  15142. SqlSession.close();
  15143. cro.setV_errCode(1);
  15144. return cro;
  15145. }
  15146. /**
  15147. * 物料、订单号匹配接口 11111
  15148. * @param design_key
  15149. * @param materail_no
  15150. * @return
  15151. * @throws Exception
  15152. */
  15153. @SuppressWarnings({ "unchecked", "rawtypes" })
  15154. public String JudgeCheckP01(String param1) throws Exception{
  15155. JSONArray ttmaps = new JSONArray();
  15156. JSONObject jsobj2 = new JSONObject();
  15157. ArrayList heat = new ArrayList();
  15158. try{
  15159. JSONObject jsonObject = (JSONObject) JSON.parse(param1);
  15160. String design_key = jsonObject.getString("ORDER");
  15161. JSONArray heat_no1 = jsonObject.getJSONArray("HEAT_NO");
  15162. for(Object param2 :heat_no1){
  15163. String heat_no = param2.toString();
  15164. //比较成分
  15165. boolean pass=true;
  15166. CoreReturnObject cro = new CoreReturnObject();
  15167. List<QcmJhyInspElements> listEle=(List<QcmJhyInspElements>)cro.getResult();
  15168. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15169. List<HashMap> listz = mapper.query("SELECT T.ASSAYNO,MAX(T.CUTSTARTTIME),MAX(T.GOWHERE) FROM KCG_STUFFLIST@XGCX T WHERE T.HEATNO LIKE '"+heat_no+"'||'%' GROUP BY T.ASSAYNO");
  15170. List<HashMap> listz1 = mapper.query("SELECT NVL(T.ASK_CFM_QY_DESC,T.CHARGE_NO || '-CP' || TO_NUMBER(SUBSTR(T1.LST_INGR_CD, 3)) || '-2') ASSAYNO1, "
  15171. + " T.CHARGE_NO || '-' || T2.CHEM_L2_PROC_CD || '-2' ASSAYNO2 "
  15172. + " FROM (SELECT ASK_CFM_QY_DESC, CHARGE_NO, MAX(SLAB_CUT_DTIME) SLAB_CUT_DTIME "
  15173. + " FROM TBG02_SLAB_COMM "
  15174. + " WHERE SLAB_NO LIKE '"+heat_no+"'||'%' "
  15175. + " GROUP BY CHARGE_NO, ASK_CFM_QY_DESC) T "
  15176. + " LEFT JOIN TBG02_CHARGE_COMM_D T1 "
  15177. + " ON T.CHARGE_NO = T1.CHARGE_NO "
  15178. + " LEFT JOIN (SELECT CHEM_L2_PROC_CD,CHEM_SEQ,CHARGE_NO FROM TBB02_WORK_INGR WHERE PROC_CD = 'JJ' AND CHEM_CD = 'C') T2 "
  15179. + " ON T.CHARGE_NO = T2.CHARGE_NO AND SUBSTR(T1.LST_INGR_CD, 3) = T2.CHEM_SEQ");
  15180. if(listz.size()==1){
  15181. cro=GetElementsInfo1(listz.get(0).get("ASSAYNO").toString());
  15182. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15183. }else
  15184. {
  15185. if(listz1.size() == 1){
  15186. cro=GetElementsInfo1(listz1.get(0).get("ASSAYNO1").toString());
  15187. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15188. if(listEle.size()<1){
  15189. cro=GetElementsInfo1(listz1.get(0).get("ASSAYNO2").toString());
  15190. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15191. if(listEle.size()<1){
  15192. continue;
  15193. }
  15194. }
  15195. }else{
  15196. continue;
  15197. }
  15198. }
  15199. //查询判定标准,最后一个参数需要调用生产计划相关接口获取当前使用的制程号
  15200. CoreReturnObject cicModel=GetOrdJudgeStdCicR1(design_key);
  15201. OrdJudgeStd<QCMOrdDesignStdCic> stdCic=(OrdJudgeStd<QCMOrdDesignStdCic>)cicModel.getResult();
  15202. List<ArrayList> list = new ArrayList();
  15203. //开始判定:内控>客户>交付
  15204. if(stdCic.getListStdLG().size() == 0){
  15205. continue;
  15206. }
  15207. //判定客户、交付标准
  15208. if (pass) {
  15209. if (stdCic.getListStdLG() != null && pass) {
  15210. pass = CompareResult(stdCic.getListStdLG(), listEle);
  15211. if (stdCic.getListStdKH()!=null&&pass) {
  15212. pass=CompareResult(stdCic.getListStdKH(),listEle);
  15213. }
  15214. }
  15215. }
  15216. if(!pass){
  15217. continue;
  15218. }else{
  15219. heat.add(heat_no);
  15220. }
  15221. }
  15222. jsobj2.put("data", heat);
  15223. jsobj2.put("code", "1000");
  15224. jsobj2.put("msg", "");
  15225. ttmaps.add(jsobj2);
  15226. }catch(Exception ex){
  15227. jsobj2.put("data", heat);
  15228. jsobj2.put("code", "3000");
  15229. jsobj2.put("msg", "");
  15230. ttmaps.add(jsobj2);
  15231. }
  15232. SqlSession.close();
  15233. return ttmaps.toString().substring(1, ttmaps.toString().length()-1);
  15234. }
  15235. /**
  15236. * 物料、订单号匹配接口 11111
  15237. * @param design_key
  15238. * @param materail_no
  15239. * @return
  15240. * @throws Exception
  15241. */
  15242. @SuppressWarnings({ "unchecked", "rawtypes" })
  15243. public String JudgeCheckP(String heat_no,String design_key,String material_no,String prod_line,String steel_name) throws Exception{
  15244. //比较成分
  15245. boolean pass=true;
  15246. CoreReturnObject cro=GetElementsInfo2(heat_no,design_key,material_no);
  15247. List<QcmJhyInspElements> listEle=(List<QcmJhyInspElements>)cro.getResult();
  15248. if(listEle.size()<1){
  15249. cro = GetElementsInfos1(heat_no,design_key);
  15250. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15251. if(listEle.size() > 1){
  15252. List<HashMap> listz = mapper.query("SELECT T.ASSAYNO,MAX(T.CUTSTARTTIME),MAX(T.GOWHERE) FROM KCG_STUFFLIST@XGCX T WHERE T.HEATNO LIKE '"+material_no+"'||'%' GROUP BY T.ASSAYNO");
  15253. List<HashMap> listz1 = mapper.query("SELECT NVL(T.ASK_CFM_QY_DESC, "
  15254. + " T.CHARGE_NO || '-CP' || TO_NUMBER(SUBSTR(T1.LST_INGR_CD, 3)) || '-2') ASSAYNO "
  15255. + " FROM (SELECT ASK_CFM_QY_DESC, CHARGE_NO, MAX(SLAB_CUT_DTIME) SLAB_CUT_DTIME "
  15256. + " FROM TBG02_SLAB_COMM "
  15257. + " WHERE SLAB_NO LIKE '"+heat_no+"%' "
  15258. + " GROUP BY CHARGE_NO, ASK_CFM_QY_DESC) T "
  15259. + " LEFT JOIN TBG02_CHARGE_COMM_D T1 "
  15260. + " ON T.CHARGE_NO = T1.CHARGE_NO");
  15261. if(listz.size()==1){
  15262. cro=GetElementsInfo1(listz.get(0).get("ASSAYNO").toString());
  15263. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15264. }else
  15265. {
  15266. if(listz1.size() == 1){
  15267. cro=GetElementsInfo1(listz1.get(0).get("ASSAYNO").toString());
  15268. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15269. }else{
  15270. return "N";
  15271. }
  15272. }
  15273. }else
  15274. {
  15275. cro=GetElementsInfos(heat_no,design_key);
  15276. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15277. if(listEle.size()<1){
  15278. return "N";
  15279. }
  15280. }
  15281. }
  15282. /*QcmJhyElementsServiceImpl qes = new QcmJhyElementsServiceImpl();
  15283. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  15284. QcmJhyPhyresultServiceImpl qjp = new QcmJhyPhyresultServiceImpl();
  15285. List<QcmJhyInspElements> listEle = new ArrayList<QcmJhyInspElements>();
  15286. JSONObject jsobj2 = new JSONObject();
  15287. JSONArray ttmaps = new JSONArray();
  15288. JSONObject jsobj1 = new JSONObject();
  15289. jsobj1.put("START_TIME", "");
  15290. jsobj1.put("END_TIME","");
  15291. jsobj1.put("HEAT_NO",material_no);
  15292. jsobj1.put("PROD_LINE",prod_line);
  15293. jsobj1.put("PROD_TYPE","板坯");
  15294. jsobj1.put("JUDGE_TYPE","C");
  15295. jsobj1.put("ISJUDGE","1");
  15296. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  15297. String result = qjes.callWebserviceASMX(url,"getBilletInfo",JSON.toJSONString(jsobj1));
  15298. if(result.contains("DATA")){
  15299. JSONObject jo = JSONObject.parseObject(result);
  15300. JSONArray ja = jo.getJSONArray("DATA");
  15301. if(ja.size()>0){
  15302. QcmJhySampleConsignD _consignD=new QcmJhySampleConsignD();
  15303. CoreReturnObject cro=qjes.GetElementsInfos(ja.getJSONObject(0).get("HEATNO") == null?"":ja.getJSONObject(0).get("HEATNO").toString(),design_key);
  15304. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15305. if(listEle.size()<1){
  15306. return "N";
  15307. }}else{
  15308. return "N";
  15309. }
  15310. String results = "";
  15311. String[] orderno = design_key.split(",");
  15312. for(String x :orderno){
  15313. if(results.equals("")){
  15314. results = "('"+x+"'";
  15315. }else{
  15316. results = result+",'"+x+"'";
  15317. }
  15318. }
  15319. if(results == ""){
  15320. return "N";
  15321. }else{
  15322. results = results +")";
  15323. }*/
  15324. String results = "";
  15325. String[] orderno = design_key.split(",");
  15326. for(String x :orderno){
  15327. if(results.equals("")){
  15328. results = "('"+x+"'";
  15329. }else{
  15330. results = results+",'"+x+"'";
  15331. }
  15332. }
  15333. if(results == ""){
  15334. return "N";
  15335. }else{
  15336. results = results +")";
  15337. }
  15338. //查询判定标准,最后一个参数需要调用生产计划相关接口获取当前使用的制程号
  15339. CoreReturnObject cicModel=GetOrdJudgeStdCicLgR(results,steel_name,prod_line);
  15340. OrdJudgeStd<QCMOrdDesignStdCic> stdCic=(OrdJudgeStd<QCMOrdDesignStdCic>)cicModel.getResult();
  15341. List<ArrayList> list = new ArrayList();
  15342. //开始判定:内控>客户>交付
  15343. if(stdCic.getListStdLG().size() == 0){
  15344. return "N";
  15345. }
  15346. //判定客户、交付标准
  15347. if (pass) {
  15348. if (stdCic.getListStdLG() != null && pass) {
  15349. pass = CompareResult(stdCic.getListStdLG(), listEle);
  15350. }
  15351. }
  15352. if(!pass){
  15353. return "N";
  15354. }else{
  15355. return "Y";
  15356. }
  15357. }
  15358. /**
  15359. * 物料、订单号匹配接口 11111
  15360. * @param design_key
  15361. * @param materail_no
  15362. * @return
  15363. * @throws Exception
  15364. */
  15365. @SuppressWarnings({ "unchecked", "rawtypes" })
  15366. public String JudgeCheckC01(String param1) throws Exception{
  15367. JSONObject jsonObject = (JSONObject) JSON.parse(param1);
  15368. JSONArray displays = jsonObject.getJSONArray("PARAMS");
  15369. JSONArray ttmaps = new JSONArray();
  15370. for(Object param2 :displays){
  15371. JSONObject jsobj2 = new JSONObject();
  15372. JSONObject object = JSONObject.parseObject(param2.toString());
  15373. String material_no = object.getString("MATERIAL_NO");
  15374. String design_key = object.getString("DESIGN_KEY");
  15375. //比较成分
  15376. /*QcmJhyElementsServiceImpl qes = new QcmJhyElementsServiceImpl();
  15377. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  15378. QcmJhyPhyresultServiceImpl qjp = new QcmJhyPhyresultServiceImpl();*/
  15379. List<HashMap> hashmap = new ArrayList<HashMap>();
  15380. if(material_no.startsWith("H")){
  15381. hashmap = mapper.doQueryMaterialInfoHB(material_no);
  15382. }
  15383. else if(material_no.startsWith("Z")){
  15384. hashmap = mapper.doQueryMaterialInfoZB(material_no);
  15385. }
  15386. else if (material_no.startsWith("G") || material_no.startsWith("E") || material_no.startsWith("Y")){
  15387. hashmap = mapper.doQueryMaterialInfoX(material_no);
  15388. }else{
  15389. hashmap = mapper.doQueryMaterialInfoJ1(material_no);
  15390. }
  15391. if(hashmap.size() == 0){
  15392. hashmap = mapper.doQueryMaterialInfoZHB1(material_no);
  15393. if(hashmap.size()==0){
  15394. hashmap = mapper.doQueryMaterialInfoY(material_no);
  15395. }
  15396. }
  15397. if(hashmap.size() == 0){
  15398. continue;
  15399. }
  15400. QcmJhySampleConsignD _consignD=new QcmJhySampleConsignD();
  15401. String board_no = hashmap.get(0).get("BOARD_NO") == null?"":hashmap.get(0).get("BOARD_NO").toString();
  15402. String heat_no = hashmap.get(0).get("HEAT_NO").toString();
  15403. CoreReturnObject cro=GetElementsInfo2(heat_no,design_key,board_no);
  15404. List<QcmJhyInspElements> listEle=(List<QcmJhyInspElements>)cro.getResult();
  15405. if(listEle.size()<1){
  15406. cro = GetElementsInfos1(heat_no,design_key);
  15407. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15408. if(listEle.size() > 0){
  15409. List<HashMap> listz = mapper.query("select * from (SELECT T.ASSAYNO,MAX(T.CUTSTARTTIME),MAX(T.GOWHERE) FROM KCG_STUFFLIST@XGCX T WHERE T.HEATNO LIKE '"+heat_no+"'||'%' GROUP BY T.ASSAYNO) where ASSAYNO is not null");
  15410. List<HashMap> listz2 = new ArrayList<HashMap>();
  15411. if(!board_no.equals("")){
  15412. listz2 = mapper.query("select * from (SELECT T.ASSAYNO,MAX(T.CUTSTARTTIME),MAX(T.GOWHERE) FROM KCG_STUFFLIST@XGCX T WHERE T.HEATNO LIKE '"+board_no+"'||'%' GROUP BY T.ASSAYNO) where ASSAYNO is not null");
  15413. }
  15414. List<HashMap> listz1 = mapper.query("SELECT * FROM (SELECT NVL(T.ASK_CFM_QY_DESC,T.CHARGE_NO || '-CP' || TO_NUMBER(SUBSTR(T1.LST_INGR_CD, 3)) || '-2') ASSAYNO1, "
  15415. + " T.CHARGE_NO || '-' || T2.CHEM_L2_PROC_CD || '-2' ASSAYNO2 "
  15416. + " FROM (SELECT ASK_CFM_QY_DESC, CHARGE_NO, MAX(SLAB_CUT_DTIME) SLAB_CUT_DTIME "
  15417. + " FROM TBG02_SLAB_COMM "
  15418. + " WHERE SLAB_NO LIKE '"+heat_no+"'||'%' "
  15419. //+ " AND ASK_CFM_QY_DESC IS NOT NULL "
  15420. + " GROUP BY CHARGE_NO, ASK_CFM_QY_DESC) T "
  15421. + " LEFT JOIN TBG02_CHARGE_COMM_D T1 "
  15422. + " ON T.CHARGE_NO = T1.CHARGE_NO "
  15423. + " LEFT JOIN (SELECT CHEM_L2_PROC_CD,CHEM_SEQ,CHARGE_NO FROM TBB02_WORK_INGR WHERE PROC_CD = 'JJ' AND CHEM_CD = 'C') T2 "
  15424. + " ON T.CHARGE_NO = T2.CHARGE_NO AND SUBSTR(T1.LST_INGR_CD, 3) = T2.CHEM_SEQ) WHERE ROWNUM <= 1");
  15425. if(listz.size()==1){
  15426. cro=GetElementsInfo1(listz.get(0).get("ASSAYNO").toString());
  15427. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15428. if(listEle.size()<1){
  15429. continue;
  15430. }
  15431. }else if(listz2.size() == 1){
  15432. cro=GetElementsInfo1(listz2.get(0).get("ASSAYNO").toString());
  15433. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15434. if(listEle.size()<1){
  15435. continue;
  15436. }
  15437. }
  15438. else
  15439. {
  15440. if(listz1.size() == 1){
  15441. cro=GetElementsInfo1(listz1.get(0).get("ASSAYNO1").toString());
  15442. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15443. if(listEle.size()<1){
  15444. cro=GetElementsInfo1(listz1.get(0).get("ASSAYNO2").toString());
  15445. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15446. if(listEle.size()<1){
  15447. continue;
  15448. }
  15449. }
  15450. }else{
  15451. continue;
  15452. }
  15453. }
  15454. }else
  15455. {
  15456. cro=GetElementsInfos(heat_no,design_key);
  15457. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15458. if(listEle.size()<1){
  15459. continue;
  15460. }
  15461. }
  15462. }
  15463. //查询判定标准,最后一个参数需要调用生产计划相关接口获取当前使用的制程号
  15464. CoreReturnObject cicModel=GetOrdJudgeStdCicR(design_key,hashmap.get(0).get("GRADE_NAME")==null?"":hashmap.get(0).get("GRADE_NAME").toString());
  15465. OrdJudgeStd<QCMOrdDesignStdCic> stdCic=(OrdJudgeStd<QCMOrdDesignStdCic>)cicModel.getResult();
  15466. List<ArrayList> list = new ArrayList();
  15467. //开始判定:内控>客户>交付
  15468. if(stdCic.getListStdNK().size() == 0 || stdCic.getListStdLG().size() == 0){
  15469. continue;
  15470. }
  15471. boolean pass=true;
  15472. //判定客户、交付标准
  15473. if(stdCic.getListStdGB().size()>0){
  15474. if (stdCic.getListStdKH()!=null&&pass) {
  15475. pass=CompareResult(stdCic.getListStdKH(),listEle);
  15476. }
  15477. if(pass){
  15478. pass=CompareResult(stdCic.getListStdGB(),listEle);
  15479. /*if(pass){
  15480. pass=CompareResult(stdCic.getListStdLG(),listEle);
  15481. }*/
  15482. }
  15483. }
  15484. //查询判定标准,最后一个参数需要调用生产计划相关接口获取当前使用的制程号
  15485. cicModel=GetOrdJudgeStdCic(design_key);
  15486. stdCic=(OrdJudgeStd<QCMOrdDesignStdCic>)cicModel.getResult();
  15487. if(stdCic.getListStdGB().size()>0 || stdCic.getListStdKH().size() > 0){
  15488. if(pass && hashmap.get(0).get("INSPECTION_LOT")!= null){
  15489. String condition=" and m.inspection_lot = '"+hashmap.get(0).get("INSPECTION_LOT").toString()+"'";
  15490. List<QcmJhySampleROrd> listOrd=mapper.GetSampleChemInfo(condition);
  15491. _consignD=new QcmJhySampleConsignD();
  15492. for (QcmJhySampleROrd qcmJhySampleROrd : listOrd) {
  15493. //获取取样编号
  15494. _consignD.setSmp_no(qcmJhySampleROrd.getSmp_no());
  15495. _consignD.setInspection_lot(qcmJhySampleROrd.getInspection_lot());
  15496. _consignD.setHeat_no(qcmJhySampleROrd.getHeat_no());
  15497. List<QcmJhySampleConsignD> listConsignD=mapper.findQcmJhySampleConsignD(qcmJhySampleROrd.getSmp_no(), qcmJhySampleROrd.getInspection_lot(), qcmJhySampleROrd.getHeat_no());
  15498. //上面listConsignD 只会查出一条数据,如果有多条数据需要跟设计确认是如何进行关联的
  15499. //根据取样编号查询检验实绩信息
  15500. QcmJhyInspElements _ele=new QcmJhyInspElements();
  15501. _ele.setSpecimen_no(listConsignD.get(0).getSpecimen_no());
  15502. cro=GetElementsInfo(_ele,qcmJhySampleROrd.getDesign_key());
  15503. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15504. if(listEle.size()<1){
  15505. continue;
  15506. }
  15507. //开始判定:内控>客户>交付
  15508. pass=true;
  15509. if(stdCic.getListStdNK().size()>0){
  15510. pass=CompareResult(stdCic.getListStdNK(),listEle);
  15511. }
  15512. //判定客户、交付标准
  15513. if(stdCic.getListStdGB().size()>0){
  15514. if (stdCic.getListStdKH()!=null&&pass) {
  15515. pass=CompareResult(stdCic.getListStdKH(),listEle);
  15516. }
  15517. if(pass){
  15518. pass=CompareResult(stdCic.getListStdGB(),listEle);
  15519. }
  15520. }
  15521. }
  15522. if(!pass){
  15523. continue;
  15524. }else{
  15525. jsobj2.put("MATERIAL_NO", material_no);
  15526. ttmaps.add(jsobj2);
  15527. }
  15528. }else{
  15529. continue;
  15530. }
  15531. }else{
  15532. if(!pass){
  15533. continue;
  15534. }else{
  15535. jsobj2.put("MATERIAL_NO", material_no);
  15536. ttmaps.add(jsobj2);
  15537. }
  15538. }
  15539. }
  15540. SqlSession.close();
  15541. return ttmaps.toString();
  15542. }
  15543. public String JudgeResult(String param)throws Exception{
  15544. JSONObject jsonObject = (JSONObject) JSON.parse(param);
  15545. JSONArray displays = jsonObject.getJSONArray("PARAMS");
  15546. JSONArray ttmaps = new JSONArray();
  15547. for(Object param2 :displays){
  15548. JSONObject jsobj2 = new JSONObject();
  15549. JSONObject object = JSONObject.parseObject(param2.toString());
  15550. String result_type = object.getString("RESULT_TYPE");
  15551. if(result_type.equals("0")){
  15552. String material_no = object.getString("MATERIAL_NO");
  15553. String design_key = object.getString("DESIGN_KEY");
  15554. //比较成分
  15555. List<HashMap> hashmap = new ArrayList<HashMap>();
  15556. if(material_no.startsWith("H")){
  15557. hashmap = mapper.doQueryMaterialInfoHB(material_no);
  15558. }
  15559. else if(material_no.startsWith("Z")){
  15560. hashmap = mapper.doQueryMaterialInfoZB(material_no);
  15561. }
  15562. else if (material_no.startsWith("G") || material_no.startsWith("E") || material_no.startsWith("Y")){
  15563. hashmap = mapper.doQueryMaterialInfoX(material_no);
  15564. }else{
  15565. hashmap = mapper.doQueryMaterialInfoJ1(material_no);
  15566. }
  15567. if(hashmap.size() == 0){
  15568. hashmap = mapper.doQueryMaterialInfoZHB1(material_no);
  15569. if(hashmap.size()==0){
  15570. hashmap = mapper.doQueryMaterialInfoY(material_no);
  15571. }
  15572. }
  15573. if(hashmap.size() == 0){
  15574. continue;
  15575. }
  15576. QcmJhySampleConsignD _consignD=new QcmJhySampleConsignD();
  15577. String board_no = hashmap.get(0).get("BOARD_NO") == null?"":hashmap.get(0).get("BOARD_NO").toString();
  15578. String heat_no = hashmap.get(0).get("HEAT_NO").toString();
  15579. CoreReturnObject cro=GetElementsInfo2(heat_no,design_key,board_no);
  15580. List<QcmJhyInspElements> listEle=(List<QcmJhyInspElements>)cro.getResult();
  15581. if(listEle.size()<1){
  15582. cro = GetElementsInfos1(heat_no,design_key);
  15583. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15584. if(listEle.size() > 0){
  15585. List<HashMap> listz = mapper.query("select * from (SELECT T.ASSAYNO,MAX(T.CUTSTARTTIME),MAX(T.GOWHERE) FROM KCG_STUFFLIST@XGCX T WHERE T.HEATNO LIKE '"+heat_no+"'||'%' GROUP BY T.ASSAYNO) where ASSAYNO is not null");
  15586. List<HashMap> listz2 = new ArrayList<HashMap>();
  15587. if(!board_no.equals("")){
  15588. listz2 = mapper.query("select * from (SELECT T.ASSAYNO,MAX(T.CUTSTARTTIME),MAX(T.GOWHERE) FROM KCG_STUFFLIST@XGCX T WHERE T.HEATNO LIKE '"+board_no+"'||'%' GROUP BY T.ASSAYNO) where ASSAYNO is not null");
  15589. }
  15590. List<HashMap> listz1 = mapper.query("SELECT * FROM (SELECT NVL(T.ASK_CFM_QY_DESC,T.CHARGE_NO || '-CP' || TO_NUMBER(SUBSTR(T1.LST_INGR_CD, 3)) || '-2') ASSAYNO1, "
  15591. + " T.CHARGE_NO || '-' || T2.CHEM_L2_PROC_CD || '-2' ASSAYNO2 "
  15592. + " FROM (SELECT ASK_CFM_QY_DESC, CHARGE_NO, MAX(SLAB_CUT_DTIME) SLAB_CUT_DTIME "
  15593. + " FROM TBG02_SLAB_COMM "
  15594. + " WHERE SLAB_NO LIKE '"+heat_no+"'||'%' "
  15595. //+ " AND ASK_CFM_QY_DESC IS NOT NULL "
  15596. + " GROUP BY CHARGE_NO, ASK_CFM_QY_DESC) T "
  15597. + " LEFT JOIN TBG02_CHARGE_COMM_D T1 "
  15598. + " ON T.CHARGE_NO = T1.CHARGE_NO "
  15599. + " LEFT JOIN (SELECT CHEM_L2_PROC_CD,CHEM_SEQ,CHARGE_NO FROM TBB02_WORK_INGR WHERE PROC_CD = 'JJ' AND CHEM_CD = 'C') T2 "
  15600. + " ON T.CHARGE_NO = T2.CHARGE_NO AND SUBSTR(T1.LST_INGR_CD, 3) = T2.CHEM_SEQ) WHERE ROWNUM <= 1");
  15601. if(listz.size()==1){
  15602. cro=GetElementsInfo1(listz.get(0).get("ASSAYNO").toString());
  15603. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15604. if(listEle.size()<1){
  15605. continue;
  15606. }
  15607. }else if(listz2.size() == 1){
  15608. cro=GetElementsInfo1(listz2.get(0).get("ASSAYNO").toString());
  15609. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15610. if(listEle.size()<1){
  15611. continue;
  15612. }
  15613. }
  15614. else
  15615. {
  15616. if(listz1.size() == 1){
  15617. cro=GetElementsInfo1(listz1.get(0).get("ASSAYNO1").toString());
  15618. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15619. if(listEle.size()<1){
  15620. cro=GetElementsInfo1(listz1.get(0).get("ASSAYNO2").toString());
  15621. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15622. if(listEle.size()<1){
  15623. continue;
  15624. }
  15625. }
  15626. }else{
  15627. continue;
  15628. }
  15629. }
  15630. }else
  15631. {
  15632. cro=GetElementsInfos(heat_no,design_key);
  15633. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15634. if(listEle.size()<1){
  15635. continue;
  15636. }
  15637. }
  15638. }
  15639. /*CoreReturnObject cro=GetElementsInfos(hashmap.get(0).get("HEAT_NO").toString(),design_key);
  15640. List<QcmJhyInspElements> listEle=(List<QcmJhyInspElements>)cro.getResult();
  15641. if(listEle.size()<1){
  15642. continue;
  15643. }*/
  15644. //查询判定标准,最后一个参数需要调用生产计划相关接口获取当前使用的制程号
  15645. CoreReturnObject cicModel=GetOrdJudgeStdCicR(design_key,hashmap.get(0).get("GRADE_NAME")==null?"":hashmap.get(0).get("GRADE_NAME").toString());
  15646. OrdJudgeStd<QCMOrdDesignStdCic> stdCic=(OrdJudgeStd<QCMOrdDesignStdCic>)cicModel.getResult();
  15647. List<ArrayList> list = new ArrayList();
  15648. //开始判定:内控>客户>交付
  15649. if(stdCic.getListStdNK().size() == 0 || stdCic.getListStdLG().size() == 0){
  15650. continue;
  15651. }
  15652. boolean pass=true;
  15653. //判定客户、交付标准
  15654. if(stdCic.getListStdGB().size()>0){
  15655. if (stdCic.getListStdKH()!=null&&pass) {
  15656. pass=CompareResult(stdCic.getListStdKH(),listEle);
  15657. list = CompareResultInfo(list, stdCic.getListStdKH(), listEle);
  15658. }
  15659. if(pass){
  15660. pass=CompareResult(stdCic.getListStdGB(),listEle);
  15661. list = CompareResultInfo(list, stdCic.getListStdGB(), listEle);
  15662. }
  15663. }
  15664. //查询判定标准,最后一个参数需要调用生产计划相关接口获取当前使用的制程号
  15665. cicModel=GetOrdJudgeStdCic(design_key);
  15666. stdCic=(OrdJudgeStd<QCMOrdDesignStdCic>)cicModel.getResult();
  15667. if(stdCic.getListStdGB().size()>0 || stdCic.getListStdKH().size() > 0){
  15668. if(pass && hashmap.get(0).get("INSPECTION_LOT")!= null){
  15669. String condition=" and m.inspection_lot = '"+hashmap.get(0).get("INSPECTION_LOT").toString()+"'";
  15670. List<QcmJhySampleROrd> listOrd=mapper.GetSampleChemInfo(condition);
  15671. _consignD=new QcmJhySampleConsignD();
  15672. for (QcmJhySampleROrd qcmJhySampleROrd : listOrd) {
  15673. //获取取样编号
  15674. _consignD.setSmp_no(qcmJhySampleROrd.getSmp_no());
  15675. _consignD.setInspection_lot(qcmJhySampleROrd.getInspection_lot());
  15676. _consignD.setHeat_no(qcmJhySampleROrd.getHeat_no());
  15677. List<QcmJhySampleConsignD> listConsignD=mapper.findQcmJhySampleConsignD(qcmJhySampleROrd.getSmp_no(), qcmJhySampleROrd.getInspection_lot(), qcmJhySampleROrd.getHeat_no());
  15678. //上面listConsignD 只会查出一条数据,如果有多条数据需要跟设计确认是如何进行关联的
  15679. //根据取样编号查询检验实绩信息
  15680. QcmJhyInspElements _ele=new QcmJhyInspElements();
  15681. _ele.setSpecimen_no(listConsignD.get(0).getSpecimen_no());
  15682. cro=GetElementsInfo(_ele,qcmJhySampleROrd.getDesign_key());
  15683. listEle=(List<QcmJhyInspElements>)cro.getResult();
  15684. if(listEle.size()<1){
  15685. jsobj2 = new JSONObject();
  15686. jsobj2.put("IS_SAMPLE", "2");
  15687. jsobj2.put("TYPE", "C");
  15688. jsobj2.put("NAME", "");
  15689. jsobj2.put("ITEM_OF_ORD", "");
  15690. jsobj2.put("VALUE1", "");
  15691. jsobj2.put("VALUE2", "");
  15692. jsobj2.put("VALUE3", "");
  15693. ttmaps.add(jsobj2);
  15694. continue;
  15695. }
  15696. //开始判定:内控>客户>交付
  15697. pass=true;
  15698. if(stdCic.getListStdNK().size()>0){
  15699. pass=CompareResult(stdCic.getListStdNK(),listEle);
  15700. }
  15701. //判定客户、交付标准
  15702. if(stdCic.getListStdGB().size()>0){
  15703. if (stdCic.getListStdKH()!=null&&pass) {
  15704. pass=CompareResult(stdCic.getListStdKH(),listEle);
  15705. list = CompareResultInfo(list, stdCic.getListStdKH(), listEle);
  15706. }
  15707. if(pass){
  15708. pass=CompareResult(stdCic.getListStdGB(),listEle);
  15709. list = CompareResultInfo(list, stdCic.getListStdKH(), listEle);
  15710. }
  15711. }
  15712. }
  15713. if(!pass){
  15714. for (ArrayList listz : list) {
  15715. jsobj2 = new JSONObject();
  15716. jsobj2.put("IS_SAMPLE", "1");
  15717. jsobj2.put("TYPE", "C");
  15718. jsobj2.put("NAME", listz.get(1).equals("")?listz.get(0).toString():listz.get(1).toString()+"成分含量不合格");
  15719. jsobj2.put("ITEM_OF_ORD", (listz.get(5) == null?"":listz.get(1).toString())+(listz.get(6) == null ? "" : listz.get(6).toString())+(listz.get(5) == null ? "" : listz.get(5).toString())+(listz.get(5) == null ? "" :";")+ (listz.get(3) == null?"":listz.get(1).toString())+(listz.get(4) == null ? "" : listz.get(4).toString())+(listz.get(3) == null ? "" : listz.get(3).toString()));
  15720. jsobj2.put("VALUE1", (listz.get(1).equals("")?listz.get(0).toString():listz.get(1).toString())+"="+(listz.get(2)==null?"":listz.get(2).toString()));
  15721. jsobj2.put("VALUE2", "");
  15722. jsobj2.put("VALUE3", "");
  15723. ttmaps.add(jsobj2);
  15724. }
  15725. continue;
  15726. }else{
  15727. continue;
  15728. }
  15729. }else{
  15730. jsobj2 = new JSONObject();
  15731. jsobj2.put("IS_SAMPLE", "2");
  15732. jsobj2.put("TYPE", "C");
  15733. jsobj2.put("NAME", "");
  15734. jsobj2.put("ITEM_OF_ORD", "");
  15735. jsobj2.put("VALUE1", "");
  15736. jsobj2.put("VALUE2", "");
  15737. jsobj2.put("VALUE3", "");
  15738. ttmaps.add(jsobj2);
  15739. continue;
  15740. }
  15741. }else{
  15742. if(!pass){
  15743. for (ArrayList listz : list) {
  15744. jsobj2 = new JSONObject();
  15745. jsobj2.put("IS_SAMPLE", "1");
  15746. jsobj2.put("TYPE", "C");
  15747. jsobj2.put("NAME", listz.get(1).equals("")?listz.get(0).toString():listz.get(1).toString()+"成分含量不合格");
  15748. jsobj2.put("ITEM_OF_ORD", (listz.get(5) == null?"":listz.get(1).toString())+(listz.get(6) == null ? "" : listz.get(6).toString())+(listz.get(5) == null ? "" : listz.get(5).toString())+(listz.get(5) == null ? "" :";")+ (listz.get(3) == null?"":listz.get(1).toString())+(listz.get(4) == null ? "" : listz.get(4).toString())+(listz.get(3) == null ? "" : listz.get(3).toString()));
  15749. jsobj2.put("VALUE1", (listz.get(1).equals("")?listz.get(0).toString():listz.get(1).toString())+"="+(listz.get(2)==null?"":listz.get(2).toString()));
  15750. jsobj2.put("VALUE2", "");
  15751. jsobj2.put("VALUE3", "");
  15752. ttmaps.add(jsobj2);
  15753. }
  15754. continue;
  15755. }else{
  15756. continue;
  15757. }
  15758. }
  15759. }else{
  15760. String material_no = object.getString("MATERIAL_NO");
  15761. String design_key = object.getString("DESIGN_KEY");
  15762. String cert_inst_name = object.getString("CERT_INST_NAME");
  15763. //比较成分
  15764. List<HashMap> hashmap = new ArrayList<HashMap>();
  15765. if(material_no.startsWith("H")){
  15766. hashmap = mapper.doQueryMaterialInfoHB(material_no);
  15767. }else if(material_no.startsWith("Z")){
  15768. hashmap = mapper.doQueryMaterialInfoZB(material_no);
  15769. }
  15770. else if (material_no.startsWith("G") || material_no.startsWith("E") || material_no.startsWith("Y")){
  15771. hashmap = mapper.doQueryMaterialInfoX(material_no);
  15772. }else{
  15773. hashmap = mapper.doQueryMaterialInfoJ1(material_no);
  15774. }
  15775. if(hashmap.size() == 0){
  15776. hashmap = mapper.doQueryMaterialInfoZHB1(material_no);
  15777. if(hashmap.size()==0){
  15778. hashmap = mapper.doQueryMaterialInfoY(material_no);
  15779. }
  15780. }
  15781. if(hashmap.size() == 0){
  15782. continue;
  15783. }
  15784. QcmJhySampleConsignD _consignD=new QcmJhySampleConsignD();
  15785. boolean pass=true;
  15786. boolean judge = true;
  15787. //材质检验
  15788. String condition=" 1=1";
  15789. QcmJhySampleROrd qjsr=new QcmJhySampleROrd();
  15790. List<QcmJhySampleROrd> listqjsr=new ArrayList<QcmJhySampleROrd>();
  15791. int status=0;
  15792. List<String> lists=new ArrayList<String>();//异常材料处理用,用于不合格项目的备注
  15793. List<QcmJhySampleROrd> listz = new ArrayList<QcmJhySampleROrd>();
  15794. String sql = "select * from qcm_ord_design_std_pic where design_key = '"+design_key+"'";
  15795. if(material_no.startsWith("R")){
  15796. sql = "select * from qcm_ord_design_std_pic where design_key = '"+design_key+"' and process_code = 'RZ1'";
  15797. }else if(material_no.startsWith("L")){
  15798. sql = "select * from qcm_ord_design_std_pic where design_key = '"+design_key+"' and process_code = 'LT1'";
  15799. }
  15800. List<HashMap> list2 = mapper.query(sql);
  15801. if(list2.size() ==0){
  15802. continue;
  15803. }
  15804. String INSPECTION_LOT = hashmap.get(0).get("INSPECTION_LOT") ==null?"":hashmap.get(0).get("INSPECTION_LOT").toString();
  15805. sql = "select * from qcm_jhy_sample_r_ord a where a.batch_no LIKE '"+hashmap.get(0).get("BATCHNO")+"%' and a.steel_name = '"+list2.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"' and a.inspection_lot = '"+INSPECTION_LOT+"' order by a.create_time desc ";
  15806. List<HashMap> list1 = mapper.query(sql);
  15807. if(list1.size() ==0){
  15808. if(material_no.startsWith("R")){
  15809. sql = "select * from qcm_jhy_sample_r_ord a where a.steel_name = '"+list2.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"' and a.inspection_lot = '"+INSPECTION_LOT+"' order by a.create_time desc ";
  15810. list1 = mapper.query(sql);
  15811. if(list1.size() ==0){
  15812. sql = "select * from qcm_jhy_sample_r_ord a where a.batch_no LIKE '"+hashmap.get(0).get("BATCHNO")+"%' and a.steel_name = '"+list2.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"' order by a.create_time desc ";
  15813. list1 = mapper.query(sql);
  15814. }
  15815. }else{
  15816. sql = "select * from qcm_jhy_sample_r_ord a where a.batch_no LIKE '"+hashmap.get(0).get("BATCHNO")+"%' and a.steel_name = '"+list2.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"' order by a.create_time desc ";
  15817. list1 = mapper.query(sql);
  15818. }
  15819. if(list1.size() ==0){
  15820. jsobj2 = new JSONObject();
  15821. jsobj2.put("IS_SAMPLE", "2");
  15822. jsobj2.put("TYPE", "D");
  15823. jsobj2.put("NAME", "");
  15824. jsobj2.put("ITEM_OF_ORD", "");
  15825. jsobj2.put("VALUE1", "");
  15826. jsobj2.put("VALUE2", "");
  15827. jsobj2.put("VALUE3", "");
  15828. ttmaps.add(jsobj2);
  15829. continue;
  15830. }else{
  15831. listz=mapper.GetSamplePhyInfos(condition,list1.get(0).get("INSPECTION_LOT").toString(),cert_inst_name);
  15832. }
  15833. }
  15834. else{
  15835. listz=mapper.GetSamplePhyInfos(condition,list1.get(0).get("INSPECTION_LOT").toString(),cert_inst_name);
  15836. }
  15837. /*if(hashmap.get(0).get("INSPECTION_LOT") !=null){
  15838. listz=mapper.GetSamplePhyInfos(condition,hashmap.get(0).get("INSPECTION_LOT").toString(),cert_inst_name);
  15839. }
  15840. else{
  15841. String sql = "select * from qcm_ord_design_std_pic where design_key = '"+design_key+"'";
  15842. List<HashMap> list2 = mapper.query(sql);
  15843. sql = "select * from qcm_jhy_sample_r_ord a where a.batch_no = '"+hashmap.get(0).get("BATCHNO")+"' and a.steel_name = '"+list2.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"'";
  15844. List<HashMap> list1 = mapper.query(sql);
  15845. if(list1.size() ==0){
  15846. sql = "select * from qcm_jhy_sample_r_ord a where a.batch_no = '"+hashmap.get(0).get("BATCHNO")+"' and a.steel_name = '"+hashmap.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"'";
  15847. list1 = mapper.query(sql);
  15848. if(list1.size() ==0){
  15849. continue;
  15850. }else{
  15851. listz=mapper.GetSamplePhyInfos(condition,list1.get(0).get("INSPECTION_LOT").toString(),cert_inst_name);
  15852. }
  15853. }
  15854. }*/
  15855. if(listz.size() ==0){
  15856. jsobj2 = new JSONObject();
  15857. jsobj2.put("IS_SAMPLE", "2");
  15858. jsobj2.put("TYPE", "D");
  15859. jsobj2.put("NAME", "");
  15860. jsobj2.put("ITEM_OF_ORD", "");
  15861. jsobj2.put("VALUE1", "");
  15862. jsobj2.put("VALUE2", "");
  15863. jsobj2.put("VALUE3", "");
  15864. ttmaps.add(jsobj2);
  15865. continue;
  15866. }
  15867. List<QcmJhySampleROrd> listOrd=new ArrayList<QcmJhySampleROrd>();
  15868. List<String> w=new ArrayList<String>();
  15869. for (QcmJhySampleROrd o : listz) {
  15870. boolean flag=true;//判定试样号向下的取样编号是否都是已完成状态;
  15871. List<QcmJhySampleConsignD> listd = mapper.findQcmJhySampleConsignD2(o.getSmp_no());
  15872. for (QcmJhySampleConsignD d : listd) {
  15873. if (!d.getStatus().equals("3")) {
  15874. flag=false;
  15875. }
  15876. }
  15877. if (flag) {
  15878. listOrd.add(o);
  15879. }
  15880. }
  15881. _consignD=new QcmJhySampleConsignD();
  15882. for (QcmJhySampleROrd qcmJhySampleROrds : listOrd) {
  15883. _consignD.setSmp_no(qcmJhySampleROrds.getSmp_no());
  15884. _consignD.setInspection_lot(qcmJhySampleROrds.getInspection_lot());
  15885. _consignD.setHeat_no(qcmJhySampleROrds.getHeat_no());
  15886. //获取取样编号
  15887. List<QcmJhySampleConsignDItem> qjscList = new ArrayList<QcmJhySampleConsignDItem>();
  15888. List<QcmJhySampleConsignD> listConsignD=mapper.findQcmJhySampleConsignD(qcmJhySampleROrds.getSmp_no(), qcmJhySampleROrds.getInspection_lot(), qcmJhySampleROrds.getHeat_no());
  15889. //上面listConsignD 只会查出一条数据,如果有多条数据需要跟设计确认是如何进行关联的
  15890. List<QcmJhyPhyresult> listResult=new ArrayList<QcmJhyPhyresult>();
  15891. //获取检验信息
  15892. for (QcmJhySampleConsignD d : listConsignD) {
  15893. QcmJhyPhyresult _result=new QcmJhyPhyresult();
  15894. List<QcmJhyPhyresult> listqjp=mapper.findphyresult(d.getSpecimen_no());
  15895. if (listqjp.size()<1) {
  15896. jsobj2 = new JSONObject();
  15897. jsobj2.put("IS_SAMPLE", "2");
  15898. jsobj2.put("TYPE", "D");
  15899. jsobj2.put("NAME", "");
  15900. jsobj2.put("ITEM_OF_ORD", "");
  15901. jsobj2.put("VALUE1", "");
  15902. jsobj2.put("VALUE2", "");
  15903. jsobj2.put("VALUE3", "");
  15904. ttmaps.add(jsobj2);
  15905. continue;
  15906. }
  15907. for (QcmJhyPhyresult q : listqjp) {
  15908. if(SqlJoint.IsNullOrSpace(q.getVal1()) && SqlJoint.IsNullOrSpace(q.getVal2()) && SqlJoint.IsNullOrSpace(q.getVal3())){
  15909. }else{
  15910. listResult.add(q);
  15911. }
  15912. }
  15913. List<QcmJhySampleConsignDItem> listi=mapper.findQcmJhySampleConsignDItem(d.getSpecimen_no());
  15914. if(listi.size()<=0){
  15915. jsobj2 = new JSONObject();
  15916. jsobj2.put("IS_SAMPLE", "2");
  15917. jsobj2.put("TYPE", "D");
  15918. jsobj2.put("NAME", "");
  15919. jsobj2.put("ITEM_OF_ORD", "");
  15920. jsobj2.put("VALUE1", "");
  15921. jsobj2.put("VALUE2", "");
  15922. jsobj2.put("VALUE3", "");
  15923. ttmaps.add(jsobj2);
  15924. continue;
  15925. }/*else{
  15926. for (QcmJhySampleConsignDItem t : listi) {
  15927. List<QcmJhySampleConsignDItem> qjsList = (List<QcmJhySampleConsignDItem>) new QcmJhySampleConsignDItem();
  15928. if(!SqlJoint.IsNullOrSpace(t.getGroup_seq())){
  15929. qjsList = mapper.findQcmJhySampleConsignDItem1(t.getSpecimen_no(),t.getGroup_seq());
  15930. }else{
  15931. qjsList = mapper.findQcmJhySampleConsignDItem2(t.getSpecimen_no());
  15932. }
  15933. Boolean groupFlag = false;
  15934. for (QcmJhySampleConsignDItem qsc : qjsList) {
  15935. for(QcmJhySampleConsignDItem qjs1: listi){
  15936. if(qjs1.getSpecimen_no().equals(qsc.getSpecimen_no()) && qjs1.getSeq().equals(qsc.getSeq())){
  15937. if(!SqlJoint.IsNullOrSpace(qjs1.getVal1()) || !SqlJoint.IsNullOrSpace(qjs1.getVal2()) || !SqlJoint.IsNullOrSpace(qjs1.getVal3())){
  15938. groupFlag = true;
  15939. break;
  15940. }
  15941. }
  15942. }
  15943. }
  15944. if (SqlJoint.IsNullOrSpace(t.getVal1())&&SqlJoint.IsNullOrSpace(t.getVal2())&&SqlJoint.IsNullOrSpace(t.getVal3()) && (SqlJoint.IsNullOrSpace(t.getGroup_seq()) || !groupFlag) && !"0".equals(t.getIsjudge())) {
  15945. return "N";
  15946. }
  15947. }
  15948. }*/
  15949. }
  15950. //获取标准和实测值(调用zj书写的接口)
  15951. CoreReturnObject r =querryJudgetItemInfo(qcmJhySampleROrds.getSmp_no(), design_key,qcmJhySampleROrds.getSteel_name(),qcmJhySampleROrds.getPline_code(),listz.get(0).getPhy_id());
  15952. List<QcmOrdDesignStdPic> listp = mapper.queryQCMOrdDesignStdPic("SELECT distinct a.phy_code_l,a.phy_code_m,a.phy_code_s,a.item_code_d,a.item_code_t,a.item_desc_s,a.item_code_l FROM qcm_ord_design_std_pic a WHERE DESIGN_KEY = '"+design_key+"'");
  15953. List<QcmJhySampleConsignDItem> listd=(List<QcmJhySampleConsignDItem>) r.getResult();
  15954. if(listd==null || listd.size() < listp.size()){
  15955. continue;
  15956. }
  15957. for (QcmJhySampleConsignDItem sod : listd) {
  15958. if(SqlJoint.IsNullOrSpace(sod.getVal1()) && SqlJoint.IsNullOrSpace(sod.getVal2()) && SqlJoint.IsNullOrSpace(sod.getVal3()) && SqlJoint.IsNullOrSpace(sod.getAvg_val())){
  15959. jsobj2 = new JSONObject();
  15960. jsobj2.put("IS_SAMPLE", "1");
  15961. jsobj2.put("TYPE", "D");
  15962. jsobj2.put("NAME", sod.getPhy_name_s());
  15963. jsobj2.put("ITEM_OF_ORD", (sod.getStdmin_sign()==null?"":sod.getPhy_name_s()==null?"":sod.getPhy_name_s().toString())+(sod.getStdmin_sign()==null?"":sod.getStdmin_sign())+(sod.getStdmin()==null?"":sod.getStdmin())+(sod.getStdmin()==null?"":";")+(sod.getStdmax_sign()==null?"":sod.getPhy_name_s()==null?"":sod.getPhy_name_s().toString())+(sod.getStdmax_sign()==null?"":sod.getStdmax_sign())+(sod.getStdmax()==null?"":sod.getStdmax()));
  15964. jsobj2.put("VALUE1", "");
  15965. jsobj2.put("VALUE2", "");
  15966. jsobj2.put("VALUE3", "");
  15967. ttmaps.add(jsobj2);
  15968. continue;
  15969. }
  15970. if(SqlJoint.IsNullOrSpace(sod.getJf_stdmax()) && SqlJoint.IsNullOrSpace(sod.getJf_stdmin())){
  15971. jsobj2 = new JSONObject();
  15972. jsobj2.put("IS_SAMPLE", "2");
  15973. jsobj2.put("TYPE", "D");
  15974. jsobj2.put("NAME", sod.getPhy_name_s());
  15975. jsobj2.put("ITEM_OF_ORD", "");
  15976. jsobj2.put("VALUE1", "");
  15977. jsobj2.put("VALUE2", "");
  15978. jsobj2.put("VALUE3", "");
  15979. ttmaps.add(jsobj2);
  15980. continue;
  15981. }
  15982. String bool0="";
  15983. String bool1="";
  15984. String bool2="";
  15985. String bool3="";
  15986. String bool4="";
  15987. String bool5="";
  15988. String bool6="";
  15989. String bool7="";
  15990. pass = true;
  15991. //if(pass){
  15992. //最小值判定
  15993. if (!SqlJoint.IsNullOrSpace(sod.getJudge_basis())&&sod.getJudge_basis().equalsIgnoreCase("A")&&"1".equals(sod.getIsjudge())) {
  15994. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(), sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(),sod.getJudge_basis());
  15995. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),min,null,null,null,null,null,null,null,null);
  15996. if ("2".equals(bool0)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  15997. lists.add(sod.getPhy_name_l()+":"+min);
  15998. sod.setStdmin(sod.getJf_stdmin());
  15999. sod.setStdmin_sign(sod.getJf_stdmin_sign());
  16000. }
  16001. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),min,null,null,null,null,null,null,null,null);
  16002. if ("2".equals(bool1)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16003. lists.add(sod.getPhy_name_l()+":"+min);
  16004. sod.setStdmax(sod.getJf_stdmax());
  16005. sod.setStdmax_sign(sod.getJf_stdmax_sign());
  16006. }
  16007. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),min,null,null,null,null,null,null,null,null);
  16008. if ("2".equals(bool2)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16009. lists.add(sod.getPhy_name_l()+":"+min);
  16010. sod.setStdmin(sod.getKh_stdmin());
  16011. sod.setStdmin_sign(sod.getKh_stdmin_sign());
  16012. }
  16013. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),min,null,null,null,null,null,null,null,null);
  16014. if ("2".equals(bool3)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16015. lists.add(sod.getPhy_name_l()+":"+min);
  16016. sod.setStdmax(sod.getKh_stdmax());
  16017. sod.setStdmax_sign(sod.getKh_stdmax_sign());
  16018. }
  16019. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),min,null,null,null,null,null,null,null,null);
  16020. if ("2".equals(bool4)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16021. lists.add(sod.getPhy_name_l()+":"+min);
  16022. sod.setStdmin(sod.getNk_stdmin());
  16023. sod.setStdmin_sign(sod.getNk_stdmin_sign());
  16024. }
  16025. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),min,null,null,null,null,null,null,null,null);
  16026. if ("2".equals(bool5)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16027. lists.add(sod.getPhy_name_l()+":"+min);
  16028. sod.setStdmax(sod.getNk_stdmax());
  16029. sod.setStdmax_sign(sod.getNk_stdmax_sign());
  16030. }
  16031. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),min,null,null,null,null,null,null,null,null);
  16032. if ("2".equals(bool4)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16033. lists.add(sod.getPhy_name_l()+":"+min);
  16034. sod.setStdmin(sod.getFx_stdmin());
  16035. sod.setStdmin_sign(sod.getFx_stdmin_sign());
  16036. }
  16037. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),min,null,null,null,null,null,null,null,null);
  16038. if ("2".equals(bool5)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16039. lists.add(sod.getPhy_name_l()+":"+min);
  16040. sod.setStdmax(sod.getFx_stdmax());
  16041. sod.setStdmax_sign(sod.getFx_stdmax_sign());
  16042. }
  16043. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  16044. pass=false;
  16045. sod.setIsbz("0");
  16046. qjscList.add(sod);
  16047. }
  16048. }
  16049. //最大值判定
  16050. if (!SqlJoint.IsNullOrSpace(sod.getJudge_basis())&&sod.getJudge_basis().equalsIgnoreCase("B")&&"1".equals(sod.getIsjudge())) {
  16051. String min = compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(), sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(),sod.getJudge_basis());
  16052. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),min,null,null,null,null,null,null,null,null);
  16053. if ("2".equals(bool0)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16054. lists.add(sod.getPhy_name_l()+":"+min);
  16055. sod.setStdmin(sod.getJf_stdmin());
  16056. sod.setStdmin_sign(sod.getJf_stdmin_sign());
  16057. }
  16058. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),min,null,null,null,null,null,null,null,null);
  16059. if ("2".equals(bool1)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16060. lists.add(sod.getPhy_name_l()+":"+min);
  16061. sod.setStdmax(sod.getJf_stdmax());
  16062. sod.setStdmax_sign(sod.getJf_stdmax_sign());
  16063. }
  16064. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),min,null,null,null,null,null,null,null,null);
  16065. if ("2".equals(bool2)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16066. lists.add(sod.getPhy_name_l()+":"+min);
  16067. sod.setStdmin(sod.getKh_stdmin());
  16068. sod.setStdmin_sign(sod.getKh_stdmin_sign());
  16069. }
  16070. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),min,null,null,null,null,null,null,null,null);
  16071. if ("2".equals(bool3)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16072. lists.add(sod.getPhy_name_l()+":"+min);
  16073. sod.setStdmax(sod.getKh_stdmax());
  16074. sod.setStdmax_sign(sod.getKh_stdmax_sign());
  16075. }
  16076. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),min,null,null,null,null,null,null,null,null);
  16077. if ("2".equals(bool4)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16078. lists.add(sod.getPhy_name_l()+":"+min);
  16079. sod.setStdmin(sod.getNk_stdmin());
  16080. sod.setStdmin_sign(sod.getNk_stdmin_sign());
  16081. }
  16082. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),min,null,null,null,null,null,null,null,null);
  16083. if ("2".equals(bool5)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16084. lists.add(sod.getPhy_name_l()+":"+min);
  16085. sod.setStdmax(sod.getNk_stdmax());
  16086. sod.setStdmax_sign(sod.getNk_stdmax_sign());
  16087. }
  16088. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),min,null,null,null,null,null,null,null,null);
  16089. if ("2".equals(bool4)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16090. lists.add(sod.getPhy_name_l()+":"+min);
  16091. sod.setStdmin(sod.getFx_stdmin());
  16092. sod.setStdmin_sign(sod.getFx_stdmin_sign());
  16093. }
  16094. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),min,null,null,null,null,null,null,null,null);
  16095. if ("2".equals(bool5)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16096. lists.add(sod.getPhy_name_l()+":"+min);
  16097. sod.setStdmax(sod.getFx_stdmax());
  16098. sod.setStdmax_sign(sod.getFx_stdmax_sign());
  16099. }
  16100. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  16101. pass=false;
  16102. sod.setIsbz("0");
  16103. qjscList.add(sod);
  16104. }
  16105. }
  16106. //平均值判定
  16107. if (!SqlJoint.IsNullOrSpace(sod.getJudge_basis())&&sod.getJudge_basis().equalsIgnoreCase("C")&&"1".equals(sod.getIsjudge())) {
  16108. String min="";
  16109. if (!SqlJoint.IsNullOrSpace(sod.getAvg_val())) {
  16110. min=sod.getVal1();
  16111. }else {
  16112. min = compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), sod.getJudge_basis());
  16113. }
  16114. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),min,null,null,null,null,null,null,null,null);
  16115. if ("2".equals(bool0)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16116. lists.add(sod.getPhy_name_l()+":"+min);
  16117. sod.setStdmin(sod.getJf_stdmin());
  16118. sod.setStdmin_sign(sod.getJf_stdmin_sign());
  16119. }
  16120. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),min,null,null,null,null,null,null,null,null);
  16121. if ("2".equals(bool1)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16122. lists.add(sod.getPhy_name_l()+":"+min);
  16123. sod.setStdmax(sod.getJf_stdmax());
  16124. sod.setStdmax_sign(sod.getJf_stdmax_sign());
  16125. }
  16126. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),min,null,null,null,null,null,null,null,null);
  16127. if ("2".equals(bool2)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16128. lists.add(sod.getPhy_name_l()+":"+min);
  16129. sod.setStdmin(sod.getKh_stdmax());
  16130. sod.setStdmin_sign(sod.getKh_stdmax_sign());
  16131. }
  16132. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),min,null,null,null,null,null,null,null,null);
  16133. if ("2".equals(bool3)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16134. lists.add(sod.getPhy_name_l()+":"+min);
  16135. sod.setStdmax(sod.getKh_stdmax());
  16136. sod.setStdmax_sign(sod.getKh_stdmax_sign());
  16137. }
  16138. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),min,null,null,null,null,null,null,null,null);
  16139. if ("2".equals(bool4)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16140. lists.add(sod.getPhy_name_l()+":"+min);
  16141. sod.setStdmin(sod.getNk_stdmin());
  16142. sod.setStdmin_sign(sod.getNk_stdmin_sign());
  16143. }
  16144. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),min,null,null,null,null,null,null,null,null);
  16145. if ("2".equals(bool5)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16146. lists.add(sod.getPhy_name_l()+":"+min);
  16147. sod.setStdmax(sod.getNk_stdmax());
  16148. sod.setStdmax_sign(sod.getNk_stdmax_sign());
  16149. }
  16150. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),min,null,null,null,null,null,null,null,null);
  16151. if ("2".equals(bool4)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16152. lists.add(sod.getPhy_name_l()+":"+min);
  16153. sod.setStdmin(sod.getFx_stdmin());
  16154. sod.setStdmin_sign(sod.getFx_stdmin_sign());
  16155. }
  16156. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),min,null,null,null,null,null,null,null,null);
  16157. if ("2".equals(bool5)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16158. lists.add(sod.getPhy_name_l()+":"+min);
  16159. sod.setStdmax(sod.getFx_stdmax());
  16160. sod.setStdmax_sign(sod.getFx_stdmax_sign());
  16161. }
  16162. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  16163. pass=false;
  16164. sod.setIsbz("0");
  16165. qjscList.add(sod);
  16166. }
  16167. }
  16168. //逐项值判定
  16169. if (SqlJoint.IsNullOrSpace(sod.getJudge_basis())||sod.getJudge_basis().equalsIgnoreCase("D")&&"1".equals(sod.getIsjudge())) {
  16170. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16171. String str=connectVal(sod.getPhy_name_l(), sod.getVal1(),sod.getVal2(),sod.getVal3());
  16172. if ("2".equals(bool0)&&!lists.contains(str)) {
  16173. lists.add(str);
  16174. sod.setStdmin(sod.getJf_stdmin());
  16175. sod.setStdmin_sign(sod.getJf_stdmin_sign());
  16176. }
  16177. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16178. if ("2".equals(bool1)&&!lists.contains(str)) {
  16179. lists.add(str);
  16180. sod.setStdmax(sod.getJf_stdmax());
  16181. sod.setStdmax_sign(sod.getJf_stdmax_sign());
  16182. }
  16183. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16184. if ("2".equals(bool2)&&!lists.contains(str)) {
  16185. lists.add(str);
  16186. sod.setStdmin(sod.getKh_stdmin());
  16187. sod.setStdmin_sign(sod.getKh_stdmin_sign());
  16188. }
  16189. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16190. if ("2".equals(bool3)&&!lists.contains(str)) {
  16191. lists.add(str);
  16192. sod.setStdmax(sod.getKh_stdmax());
  16193. sod.setStdmax_sign(sod.getKh_stdmax_sign());
  16194. }
  16195. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16196. if ("2".equals(bool4)&&!lists.contains(str)) {
  16197. lists.add(str);
  16198. sod.setStdmin(sod.getNk_stdmin());
  16199. sod.setStdmin_sign(sod.getNk_stdmin_sign());
  16200. }
  16201. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16202. if ("2".equals(bool5)&&!lists.contains(str)) {
  16203. lists.add(str);
  16204. sod.setStdmax(sod.getNk_stdmax());
  16205. sod.setStdmax_sign(sod.getNk_stdmax_sign());
  16206. }
  16207. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16208. if ("2".equals(bool4)&&!lists.contains(str)) {
  16209. lists.add(str);
  16210. sod.setStdmin(sod.getFx_stdmin());
  16211. sod.setStdmin_sign(sod.getFx_stdmin_sign());
  16212. }
  16213. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16214. if ("2".equals(bool5)&&!lists.contains(str)) {
  16215. lists.add(str);
  16216. sod.setStdmax(sod.getFx_stdmax());
  16217. sod.setStdmax_sign(sod.getFx_stdmax_sign());
  16218. }
  16219. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  16220. pass=false;
  16221. sod.setIsbz("0");
  16222. qjscList.add(sod);
  16223. }
  16224. }
  16225. if((pass && !SqlJoint.IsNullOrSpace(sod.getAddcondition()) && sod.getAddcondition().equals("1")) || (!pass && !SqlJoint.IsNullOrSpace(sod.getAddcondition()) && sod.getAddcondition().equals("0"))){
  16226. pass = true;
  16227. int count = 0;
  16228. //允许一个值
  16229. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("A")&&"1".equals(sod.getIsjudge())) {
  16230. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16231. if(bool0.equals("2")){
  16232. count ++;
  16233. }else{
  16234. bool0=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16235. if(bool0.equals("2")){
  16236. count ++;
  16237. }else{
  16238. bool0=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16239. if(bool0.equals("2")){
  16240. count ++;
  16241. }
  16242. }
  16243. }
  16244. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16245. if ("2".equals(bool0)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal1())) {
  16246. lists.add(sod.getPhy_name_l()+":"+sod.getVal1());
  16247. }
  16248. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16249. if(bool1.equals("2")){
  16250. count ++;
  16251. }else{
  16252. bool1=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16253. if(bool1.equals("2")){
  16254. count ++;
  16255. }else{
  16256. bool1=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16257. if(bool1.equals("2")){
  16258. count ++;
  16259. }
  16260. }
  16261. }
  16262. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16263. if ("2".equals(bool1)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal1())) {
  16264. lists.add(sod.getPhy_name_l()+":"+sod.getVal1());
  16265. }
  16266. bool2=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16267. if(bool2.equals("2")){
  16268. count ++;
  16269. }else{
  16270. bool2=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16271. if(bool2.equals("2")){
  16272. count ++;
  16273. }else{
  16274. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16275. if(bool2.equals("2")){
  16276. count ++;
  16277. }
  16278. }
  16279. }
  16280. bool2=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16281. if ("2".equals(bool2)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal2())) {
  16282. lists.add(sod.getPhy_name_l()+":"+sod.getVal2());
  16283. }
  16284. bool3=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16285. if(bool3.equals("2")){
  16286. count ++;
  16287. }else{
  16288. bool3=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16289. if(bool3.equals("2")){
  16290. count ++;
  16291. }else{
  16292. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16293. if(bool3.equals("2")){
  16294. count ++;
  16295. }
  16296. }
  16297. }
  16298. bool3=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16299. if ("2".equals(bool3)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal2())) {
  16300. lists.add(sod.getPhy_name_l()+":"+sod.getVal2());
  16301. }
  16302. bool4=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16303. if(bool4.equals("2")){
  16304. count ++;
  16305. }else{
  16306. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16307. if(bool4.equals("2")){
  16308. count ++;
  16309. }else{
  16310. bool4=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16311. if(bool0.equals("2")){
  16312. count ++;
  16313. }
  16314. }
  16315. }
  16316. bool4=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16317. if ("2".equals(bool4)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal3())) {
  16318. lists.add(sod.getPhy_name_l()+":"+sod.getVal3());
  16319. }
  16320. bool5=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16321. if(bool5.equals("2")){
  16322. count ++;
  16323. }else{
  16324. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16325. if(bool5.equals("2")){
  16326. count ++;
  16327. }else{
  16328. bool5=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16329. if(bool0.equals("2")){
  16330. count ++;
  16331. }
  16332. }
  16333. }
  16334. bool5=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16335. if ("2".equals(bool5)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal3())) {
  16336. lists.add(sod.getPhy_name_l()+":"+sod.getVal3());
  16337. }
  16338. if(count > 1){
  16339. pass=false;
  16340. sod.setIsbz("1");
  16341. qjscList.add(sod);
  16342. }else{
  16343. if ("2".equals(bool0)||"2".equals(bool1) || "2".equals(bool2)||"2".equals(bool3) || "2".equals(bool4)||"2".equals(bool5) ){
  16344. pass=false;
  16345. sod.setIsbz("1");
  16346. qjscList.add(sod);
  16347. }
  16348. }
  16349. }
  16350. //最大最小差值
  16351. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("B")&&"1".equals(sod.getIsjudge())) {
  16352. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), "D");
  16353. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  16354. if ("2".equals(bool0)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16355. lists.add(sod.getPhy_name_l()+":"+min);
  16356. }
  16357. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  16358. if ("2".equals(bool1)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16359. lists.add(sod.getPhy_name_l()+":"+min);
  16360. }
  16361. if ("2".equals(bool0)||"2".equals(bool1)) {
  16362. pass=false;
  16363. sod.setIsbz("1");
  16364. qjscList.add(sod);
  16365. }
  16366. }
  16367. //平均值
  16368. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("C")&&"1".equals(sod.getIsjudge())) {
  16369. String min="";
  16370. if (!SqlJoint.IsNullOrSpace(sod.getAvg_val())) {
  16371. min=sod.getVal1();
  16372. }else {
  16373. min = compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), sod.getJudge_basis());
  16374. }
  16375. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  16376. if ("2".equals(bool0)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16377. lists.add(sod.getPhy_name_l()+":"+min);
  16378. }
  16379. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  16380. if ("2".equals(bool1)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16381. lists.add(sod.getPhy_name_l()+":"+min);
  16382. }
  16383. if ("2".equals(bool0)||"2".equals(bool1)) {
  16384. pass=false;
  16385. sod.setIsbz("1");
  16386. qjscList.add(sod);
  16387. }
  16388. }
  16389. //最小值
  16390. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("D")&&"1".equals(sod.getIsjudge())) {
  16391. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(), sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(),"A");
  16392. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  16393. if ("2".equals(bool0)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16394. lists.add(sod.getPhy_name_l()+":"+min);
  16395. }
  16396. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  16397. if ("2".equals(bool1)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16398. lists.add(sod.getPhy_name_l()+":"+min);
  16399. }
  16400. if ("2".equals(bool0)||"2".equals(bool1)) {
  16401. pass=false;
  16402. sod.setIsbz("1");
  16403. qjscList.add(sod);
  16404. }
  16405. }
  16406. //最大值
  16407. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("E")&&"1".equals(sod.getIsjudge())) {
  16408. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), "B");
  16409. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  16410. if ("2".equals(bool0)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16411. lists.add(sod.getPhy_name_l()+":"+min);
  16412. }
  16413. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  16414. if ("2".equals(bool1)&&!lists.contains(sod.getPhy_name_l()+":"+min)) {
  16415. lists.add(sod.getPhy_name_l()+":"+min);
  16416. }
  16417. if ("2".equals(bool0)||"2".equals(bool1)) {
  16418. pass=false;
  16419. sod.setIsbz("1");
  16420. qjscList.add(sod);
  16421. }
  16422. }
  16423. //所有值
  16424. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("E")&&"1".equals(sod.getIsjudge())) {
  16425. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16426. if ("2".equals(bool0)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal1())) {
  16427. lists.add(sod.getPhy_name_l()+":"+sod.getVal1());
  16428. }
  16429. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16430. if ("2".equals(bool1)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal1())) {
  16431. lists.add(sod.getPhy_name_l()+":"+sod.getVal1());
  16432. }
  16433. bool2=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16434. if ("2".equals(bool2)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal2())) {
  16435. lists.add(sod.getPhy_name_l()+":"+sod.getVal2());
  16436. }
  16437. bool3=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16438. if ("2".equals(bool3)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal2())) {
  16439. lists.add(sod.getPhy_name_l()+":"+sod.getVal2());
  16440. }
  16441. bool4=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16442. if ("2".equals(bool4)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal3())) {
  16443. lists.add(sod.getPhy_name_l()+":"+sod.getVal3());
  16444. }
  16445. bool5=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16446. if ("2".equals(bool5)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal3())) {
  16447. lists.add(sod.getPhy_name_l()+":"+sod.getVal3());
  16448. }
  16449. if ("2".equals(bool0)||"2".equals(bool1) ||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)) {
  16450. pass=false;
  16451. sod.setIsbz("1");
  16452. qjscList.add(sod);
  16453. }
  16454. }
  16455. }
  16456. if(sod.getDefect_flag()!= null){
  16457. if(sod.getDefect_flag().equals("1")){
  16458. pass = false;
  16459. }
  16460. }
  16461. if(!pass){
  16462. judge = false;
  16463. }
  16464. }
  16465. if(!judge){
  16466. for(QcmJhySampleConsignDItem listz1 : qjscList){
  16467. jsobj2 = new JSONObject();
  16468. jsobj2.put("IS_SAMPLE", "1");
  16469. jsobj2.put("TYPE", "D");
  16470. jsobj2.put("NAME", listz1.getPhy_name_s()==null?"":listz1.getPhy_name_s().toString());
  16471. //if(listz1.getIsbz().equals("0")){
  16472. jsobj2.put("ITEM_OF_ORD", (listz1.getStdmin_sign()==null?"":listz1.getPhy_name_s()==null?"":listz1.getPhy_name_s().toString())+(listz1.getStdmin_sign()==null?"":listz1.getStdmin_sign())+(listz1.getStdmin()==null?"":listz1.getStdmin())+(listz1.getStdmin()==null?"":";")+(listz1.getStdmax_sign()==null?"":listz1.getPhy_name_s()==null?"":listz1.getPhy_name_s().toString())+(listz1.getStdmax_sign()==null?"":listz1.getStdmax_sign())+(listz1.getStdmax()==null?"":listz1.getStdmax()));
  16473. /*}else{
  16474. jsobj2.put("ITEM_OF_ORD", (listz1.getAddstd_min_sign()==null?"":listz1.getPhy_name_s()==null?"":listz1.getPhy_name_s().toString())+(listz1.getAddstd_min_sign()==null?"":listz1.getAddstd_min_sign())+(listz1.getAddstd_min()==null?"":listz1.getAddstd_min())+(listz1.getAddstd_min()==null?"":";")+(listz1.getAdd_std_max_sign()==null?"":listz1.getPhy_name_s()==null?"":listz1.getPhy_name_s().toString())+(listz1.getAdd_std_max_sign()==null?"":listz1.getAdd_std_max_sign())+(listz1.getAddstd_max()==null?"":listz1.getAdd_std_max_sign()));
  16475. }*/
  16476. jsobj2.put("VALUE1", (listz1.getPhy_name_s()==null?"":listz1.getPhy_name_s().toString()) +"="+listz1.getVal1());
  16477. if(listz1.getVal2() == null){
  16478. jsobj2.put("VALUE2","");
  16479. }else{
  16480. jsobj2.put("VALUE2", (listz1.getPhy_name_s()==null?"":listz1.getPhy_name_s().toString()) +"="+listz1.getVal2());
  16481. }
  16482. if(listz1.getVal3() == null){
  16483. jsobj2.put("VALUE3","");
  16484. }else{
  16485. jsobj2.put("VALUE3", (listz1.getPhy_name_s()==null?"":listz1.getPhy_name_s().toString()) +"="+listz1.getVal3());
  16486. }
  16487. if(ttmaps.toString().contains(listz1.getPhy_name_s()==null?"":listz1.getPhy_name_s().toString())){
  16488. continue;
  16489. }
  16490. ttmaps.add(jsobj2);
  16491. }
  16492. continue;
  16493. }else{
  16494. continue;
  16495. }
  16496. }
  16497. }
  16498. }
  16499. SqlSession.close();
  16500. return ttmaps.toString();
  16501. }
  16502. /**
  16503. * 物料、订单号匹配接口 11111
  16504. * @param design_key
  16505. * @param materail_no
  16506. * @return
  16507. * @throws Exception
  16508. */
  16509. @SuppressWarnings({ "unchecked", "rawtypes" })
  16510. public String JudgeCheckC(String design_key,String materail_no) throws Exception{
  16511. //比较成分
  16512. QcmJhyElementsServiceImpl qes = new QcmJhyElementsServiceImpl();
  16513. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  16514. QcmJhyPhyresultServiceImpl qjp = new QcmJhyPhyresultServiceImpl();
  16515. List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(materail_no);
  16516. if(hashmap.size() == 0){
  16517. hashmap = qjms.doQueryMaterialInfoJ(materail_no);
  16518. }
  16519. if(hashmap.size() == 0){
  16520. return "N";
  16521. }
  16522. QcmJhySampleConsignD _consignD=new QcmJhySampleConsignD();
  16523. CoreReturnObject cro=GetElementsInfos(hashmap.get(0).get("HEAT_NO").toString(),design_key);
  16524. List<QcmJhyInspElements> listEle=(List<QcmJhyInspElements>)cro.getResult();
  16525. if(listEle.size()<1){
  16526. return "N";
  16527. }
  16528. //查询判定标准,最后一个参数需要调用生产计划相关接口获取当前使用的制程号
  16529. CoreReturnObject cicModel=GetOrdJudgeStdCicR(design_key,hashmap.get(0).get("GRADE_NAME").toString());
  16530. OrdJudgeStd<QCMOrdDesignStdCic> stdCic=(OrdJudgeStd<QCMOrdDesignStdCic>)cicModel.getResult();
  16531. List<ArrayList> list = new ArrayList();
  16532. //开始判定:内控>客户>交付
  16533. if(stdCic.getListStdNK().size() == 0 || stdCic.getListStdLG().size() == 0){
  16534. return "N";
  16535. }
  16536. boolean pass=true;
  16537. //判定客户、交付标准
  16538. if(stdCic.getListStdGB().size()>0){
  16539. if (stdCic.getListStdKH()!=null&&pass) {
  16540. pass=CompareResult(stdCic.getListStdKH(),listEle);
  16541. }
  16542. if(pass){
  16543. pass=CompareResult(stdCic.getListStdGB(),listEle);
  16544. if(pass){
  16545. pass=CompareResult(stdCic.getListStdLG(),listEle);
  16546. }
  16547. }
  16548. }
  16549. if(pass){
  16550. String condition=" and m.inspection_lot = '"+hashmap.get(0).get("INSPECTION_LOT").toString()+"'";
  16551. List<QcmJhySampleROrd> listOrd=mapper.GetSampleChemInfo(condition);
  16552. _consignD=new QcmJhySampleConsignD();
  16553. for (QcmJhySampleROrd qcmJhySampleROrd : listOrd) {
  16554. //获取取样编号
  16555. _consignD.setSmp_no(qcmJhySampleROrd.getSmp_no());
  16556. _consignD.setInspection_lot(qcmJhySampleROrd.getInspection_lot());
  16557. _consignD.setHeat_no(qcmJhySampleROrd.getHeat_no());
  16558. List<QcmJhySampleConsignD> listConsignD=mapper.findQcmJhySampleConsignD(qcmJhySampleROrd.getSmp_no(), qcmJhySampleROrd.getInspection_lot(), qcmJhySampleROrd.getHeat_no());
  16559. //上面listConsignD 只会查出一条数据,如果有多条数据需要跟设计确认是如何进行关联的
  16560. //根据取样编号查询检验实绩信息
  16561. QcmJhyInspElements _ele=new QcmJhyInspElements();
  16562. _ele.setSpecimen_no(listConsignD.get(0).getSpecimen_no());
  16563. cro=qes.GetElementsInfo(_ele,qcmJhySampleROrd.getDesign_key());
  16564. listEle=(List<QcmJhyInspElements>)cro.getResult();
  16565. if(listEle.size()<1){
  16566. return "N";
  16567. }
  16568. //查询判定标准,最后一个参数需要调用生产计划相关接口获取当前使用的制程号
  16569. cicModel=qes.GetOrdJudgeStdCic(design_key);
  16570. stdCic=(OrdJudgeStd<QCMOrdDesignStdCic>)cicModel.getResult();
  16571. //开始判定:内控>客户>交付
  16572. pass=true;
  16573. if(stdCic.getListStdNK().size()>0){
  16574. pass=qes.CompareResult(stdCic.getListStdNK(),listEle);
  16575. }
  16576. //判定客户、交付标准
  16577. if(stdCic.getListStdGB().size()>0){
  16578. if (stdCic.getListStdKH()!=null&&pass) {
  16579. pass=qes.CompareResult(stdCic.getListStdKH(),listEle);
  16580. }
  16581. if(pass){
  16582. pass=qes.CompareResult(stdCic.getListStdGB(),listEle);
  16583. }
  16584. }
  16585. }
  16586. if(!pass){
  16587. return "N";
  16588. }else{
  16589. return "Y";
  16590. }
  16591. }else{
  16592. return "N";
  16593. }
  16594. }
  16595. /**
  16596. * 物料、订单号匹配接口 产销质财一体化冷轧充当功能修改 20240531运维平台申请
  16597. * @param design_key
  16598. * @param materail_no
  16599. * @return
  16600. * @throws Exception
  16601. */
  16602. @SuppressWarnings({ "unchecked", "rawtypes" })
  16603. public String JudgeCheck01(String param1) throws Exception{
  16604. JSONObject jsonObject = (JSONObject) JSON.parse(param1);
  16605. JSONArray displays = jsonObject.getJSONArray("PARAMS");
  16606. JSONArray ttmaps = new JSONArray();
  16607. for(Object param2 :displays){
  16608. JSONObject jsobj2 = new JSONObject();
  16609. JSONObject object = JSONObject.parseObject(param2.toString());
  16610. String material_no = object.getString("MATERIAL_NO");
  16611. String design_key = object.getString("DESIGN_KEY");
  16612. String cert_inst_name = object.getString("CERT_INST_NAME");
  16613. //比较成分
  16614. /*QcmJhyElementsServiceImpl qes = new QcmJhyElementsServiceImpl();
  16615. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  16616. QcmJhyPhyresultServiceImpl qjp = new QcmJhyPhyresultServiceImpl();*/
  16617. List<HashMap> hashmap = new ArrayList<HashMap>();
  16618. if(material_no.startsWith("H")){
  16619. hashmap = mapper.doQueryMaterialInfoHB(material_no);
  16620. }else if(material_no.startsWith("Z")){
  16621. hashmap = mapper.doQueryMaterialInfoZB(material_no);
  16622. }
  16623. else if (material_no.startsWith("G") || material_no.startsWith("E") || material_no.startsWith("Y")){
  16624. hashmap = mapper.doQueryMaterialInfoX(material_no);
  16625. }else{
  16626. hashmap = mapper.doQueryMaterialInfoJ1(material_no);//连退
  16627. }
  16628. if(hashmap.size() == 0){
  16629. hashmap = mapper.doQueryMaterialInfoZHB1(material_no);
  16630. if(hashmap.size()==0){
  16631. hashmap = mapper.doQueryMaterialInfoY(material_no);
  16632. }
  16633. }
  16634. if(hashmap.size() == 0){
  16635. continue;
  16636. }
  16637. QcmJhySampleConsignD _consignD=new QcmJhySampleConsignD();
  16638. boolean pass=true;
  16639. boolean judge = true;
  16640. //材质检验
  16641. String condition=" 1=1";
  16642. QcmJhySampleROrd qjsr=new QcmJhySampleROrd();
  16643. List<QcmJhySampleROrd> listqjsr=new ArrayList<QcmJhySampleROrd>();
  16644. int status=0;
  16645. List<String> lists=new ArrayList<String>();//异常材料处理用,用于不合格项目的备注
  16646. List<QcmJhySampleROrd> listz = new ArrayList<QcmJhySampleROrd>();
  16647. String sql = "select * from qcm_ord_design_std_pic where design_key = '"+design_key+"'";
  16648. if(material_no.startsWith("R")){
  16649. sql = "select * from qcm_ord_design_std_pic where design_key = '"+design_key+"' and process_code = 'RZ1'";
  16650. }else if(material_no.startsWith("L")){
  16651. sql = "select * from qcm_ord_design_std_pic where design_key = '"+design_key+"' and process_code = 'LT1' and PHY_CODE_L!='HV' ";//240625 粗糙度剔除
  16652. }
  16653. List<HashMap> list2 = mapper.query(sql);
  16654. if(list2.size() ==0){
  16655. jsobj2.put("MATERIAL_NO", material_no);
  16656. ttmaps.add(jsobj2);
  16657. continue;
  16658. }
  16659. String INSPECTION_LOT = hashmap.get(0).get("INSPECTION_LOT") ==null?"":hashmap.get(0).get("INSPECTION_LOT").toString();
  16660. sql = "select * from qcm_jhy_sample_r_ord a where a.batch_no LIKE '"+hashmap.get(0).get("BATCHNO")+"%' and a.steel_name = '"+list2.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"' and a.inspection_lot = '"+INSPECTION_LOT+"' order by a.create_time desc ";
  16661. List<HashMap> list1 = mapper.query(sql);
  16662. if(list1.size() ==0){
  16663. if(material_no.startsWith("R")){
  16664. sql = "select * from qcm_jhy_sample_r_ord a where a.steel_name = '"+list2.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"' and a.inspection_lot = '"+INSPECTION_LOT+"' order by a.create_time desc ";
  16665. list1 = mapper.query(sql);
  16666. if(list1.size() ==0){
  16667. sql = "select * from qcm_jhy_sample_r_ord a where a.batch_no LIKE '"+hashmap.get(0).get("BATCHNO")+"%' and a.steel_name = '"+list2.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"' order by a.create_time desc ";
  16668. list1 = mapper.query(sql);
  16669. }
  16670. }else{
  16671. sql = "select * from qcm_jhy_sample_r_ord a where a.batch_no LIKE '"+hashmap.get(0).get("BATCHNO")+"%' and a.steel_name = '"+list2.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"' order by a.create_time desc ";
  16672. list1 = mapper.query(sql);
  16673. }
  16674. if(list1.size() ==0){
  16675. continue;
  16676. }else{
  16677. listz=mapper.GetSamplePhyInfos(condition,list1.get(0).get("INSPECTION_LOT").toString(),cert_inst_name);
  16678. }
  16679. }else{
  16680. listz=mapper.GetSamplePhyInfos(condition,list1.get(0).get("INSPECTION_LOT").toString(),cert_inst_name);
  16681. }
  16682. /*if(hashmap.get(0).get("INSPECTION_LOT") !=null){
  16683. listz=mapper.GetSamplePhyInfos(condition,hashmap.get(0).get("INSPECTION_LOT").toString(),cert_inst_name);
  16684. }
  16685. else{
  16686. String sql = "select * from qcm_ord_design_std_pic where design_key = '"+design_key+"'";
  16687. List<HashMap> list2 = mapper.query(sql);
  16688. sql = "select * from qcm_jhy_sample_r_ord a where a.batch_no = '"+hashmap.get(0).get("BATCHNO")+"' and a.steel_name = '"+list2.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"'";
  16689. List<HashMap> list1 = mapper.query(sql);
  16690. if(list1.size() ==0){
  16691. sql = "select * from qcm_jhy_sample_r_ord a where a.batch_no = '"+hashmap.get(0).get("BATCHNO")+"' and a.steel_name = '"+hashmap.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"'";
  16692. list1 = mapper.query(sql);
  16693. if(list1.size() ==0){
  16694. continue;
  16695. }else{
  16696. listz=mapper.GetSamplePhyInfos(condition,list1.get(0).get("INSPECTION_LOT").toString(),cert_inst_name);
  16697. }
  16698. }
  16699. }*/
  16700. List<QcmJhySampleROrd> listOrd=new ArrayList<QcmJhySampleROrd>();
  16701. List<String> w=new ArrayList<String>();
  16702. for (QcmJhySampleROrd o : listz) {
  16703. boolean flag=true;//判定试样号向下的取样编号是否都是已完成状态;
  16704. List<QcmJhySampleConsignD> listd = mapper.findQcmJhySampleConsignD2(o.getSmp_no());
  16705. for (QcmJhySampleConsignD d : listd) {
  16706. if (!d.getStatus().equals("3")) {
  16707. flag=false;
  16708. }
  16709. }
  16710. if (flag) {
  16711. listOrd.add(o);
  16712. }
  16713. }
  16714. _consignD=new QcmJhySampleConsignD();
  16715. for (QcmJhySampleROrd qcmJhySampleROrds : listOrd) {
  16716. _consignD.setSmp_no(qcmJhySampleROrds.getSmp_no());
  16717. _consignD.setInspection_lot(qcmJhySampleROrds.getInspection_lot());
  16718. _consignD.setHeat_no(qcmJhySampleROrds.getHeat_no());
  16719. //获取取样编号
  16720. List<QcmJhySampleConsignD> listConsignD=mapper.findQcmJhySampleConsignD(qcmJhySampleROrds.getSmp_no(), qcmJhySampleROrds.getInspection_lot(), qcmJhySampleROrds.getHeat_no());
  16721. //上面listConsignD 只会查出一条数据,如果有多条数据需要跟设计确认是如何进行关联的
  16722. List<QcmJhyPhyresult> listResult=new ArrayList<QcmJhyPhyresult>();
  16723. //获取检验信息
  16724. for (QcmJhySampleConsignD d : listConsignD) {
  16725. QcmJhyPhyresult _result=new QcmJhyPhyresult();
  16726. List<QcmJhyPhyresult> listqjp=mapper.findphyresult(d.getSpecimen_no());
  16727. if (listqjp.size()<1) {
  16728. continue;
  16729. }
  16730. for (QcmJhyPhyresult q : listqjp) {
  16731. if(SqlJoint.IsNullOrSpace(q.getVal1()) && SqlJoint.IsNullOrSpace(q.getVal2()) && SqlJoint.IsNullOrSpace(q.getVal3()) ){
  16732. }else{
  16733. listResult.add(q);
  16734. }
  16735. }
  16736. List<QcmJhySampleConsignDItem> listi=mapper.findQcmJhySampleConsignDItem(d.getSpecimen_no());
  16737. if(listi.size()<=0){
  16738. continue;
  16739. }/*else{
  16740. for (QcmJhySampleConsignDItem t : listi) {
  16741. List<QcmJhySampleConsignDItem> qjsList = (List<QcmJhySampleConsignDItem>) new QcmJhySampleConsignDItem();
  16742. if(!SqlJoint.IsNullOrSpace(t.getGroup_seq())){
  16743. qjsList = mapper.findQcmJhySampleConsignDItem1(t.getSpecimen_no(),t.getGroup_seq());
  16744. }else{
  16745. qjsList = mapper.findQcmJhySampleConsignDItem2(t.getSpecimen_no());
  16746. }
  16747. Boolean groupFlag = false;
  16748. for (QcmJhySampleConsignDItem qsc : qjsList) {
  16749. for(QcmJhySampleConsignDItem qjs1: listi){
  16750. if(qjs1.getSpecimen_no().equals(qsc.getSpecimen_no()) && qjs1.getSeq().equals(qsc.getSeq())){
  16751. if(!SqlJoint.IsNullOrSpace(qjs1.getVal1()) || !SqlJoint.IsNullOrSpace(qjs1.getVal2()) || !SqlJoint.IsNullOrSpace(qjs1.getVal3())){
  16752. groupFlag = true;
  16753. break;
  16754. }
  16755. }
  16756. }
  16757. }
  16758. if (SqlJoint.IsNullOrSpace(t.getVal1())&&SqlJoint.IsNullOrSpace(t.getVal2())&&SqlJoint.IsNullOrSpace(t.getVal3()) && (SqlJoint.IsNullOrSpace(t.getGroup_seq()) || !groupFlag) && !"0".equals(t.getIsjudge())) {
  16759. return "N";
  16760. }
  16761. }
  16762. }*/
  16763. }
  16764. //获取标准和实测值(调用zj书写的接口)
  16765. CoreReturnObject r =querryJudgetItemInfo(qcmJhySampleROrds.getSmp_no(), design_key,qcmJhySampleROrds.getSteel_name(),qcmJhySampleROrds.getPline_code(),listz.get(0).getPhy_id());
  16766. List<QcmOrdDesignStdPic> listp = mapper.queryQCMOrdDesignStdPic("SELECT distinct a.phy_code_l,a.phy_code_m,a.phy_code_s,a.item_code_d,a.item_code_t,a.item_desc_s,a.item_code_l FROM qcm_ord_design_std_pic a WHERE DESIGN_KEY = '"+design_key+"'");
  16767. List<QcmJhySampleConsignDItem> listd=(List<QcmJhySampleConsignDItem>) r.getResult();
  16768. if(listd==null || listd.size() < listp.size()){
  16769. continue;
  16770. }
  16771. for (QcmJhySampleConsignDItem sod : listd) {
  16772. //连退粗造度不参于判定
  16773. if (sod.getSpecimen_no().startsWith("L") && sod.getPhy_code_l().equals("HV")){
  16774. continue;
  16775. }
  16776. if(SqlJoint.IsNullOrSpace(sod.getVal1()) && SqlJoint.IsNullOrSpace(sod.getVal2()) && SqlJoint.IsNullOrSpace(sod.getVal3()) && SqlJoint.IsNullOrSpace(sod.getAvg_val())){
  16777. judge = false;
  16778. break;
  16779. }
  16780. if(SqlJoint.IsNullOrSpace(sod.getJf_stdmax()) && SqlJoint.IsNullOrSpace(sod.getJf_stdmin())){
  16781. continue;
  16782. }
  16783. String bool0="";
  16784. String bool1="";
  16785. String bool2="";
  16786. String bool3="";
  16787. String bool4="";
  16788. String bool5="";
  16789. String bool6="";
  16790. String bool7="";
  16791. pass = true;
  16792. //if(pass){
  16793. //最小值判定
  16794. if (!SqlJoint.IsNullOrSpace(sod.getJudge_basis())&&sod.getJudge_basis().equalsIgnoreCase("A")&&"1".equals(sod.getIsjudge())) {
  16795. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(), sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(),sod.getJudge_basis());
  16796. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),min,null,null,null,null,null,null,null,null);
  16797. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),min,null,null,null,null,null,null,null,null);
  16798. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),min,null,null,null,null,null,null,null,null);
  16799. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),min,null,null,null,null,null,null,null,null);
  16800. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),min,null,null,null,null,null,null,null,null);
  16801. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),min,null,null,null,null,null,null,null,null);
  16802. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),min,null,null,null,null,null,null,null,null);
  16803. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),min,null,null,null,null,null,null,null,null);
  16804. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  16805. pass=false;
  16806. }
  16807. }
  16808. //最大值判定
  16809. if (!SqlJoint.IsNullOrSpace(sod.getJudge_basis())&&sod.getJudge_basis().equalsIgnoreCase("B")&&"1".equals(sod.getIsjudge())) {
  16810. String min = compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(), sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(),sod.getJudge_basis());
  16811. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),min,null,null,null,null,null,null,null,null);
  16812. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),min,null,null,null,null,null,null,null,null);
  16813. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),min,null,null,null,null,null,null,null,null);
  16814. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),min,null,null,null,null,null,null,null,null);
  16815. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),min,null,null,null,null,null,null,null,null);
  16816. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),min,null,null,null,null,null,null,null,null);
  16817. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),min,null,null,null,null,null,null,null,null);
  16818. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),min,null,null,null,null,null,null,null,null);
  16819. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  16820. pass=false;
  16821. }
  16822. }
  16823. //平均值判定
  16824. if (!SqlJoint.IsNullOrSpace(sod.getJudge_basis())&&sod.getJudge_basis().equalsIgnoreCase("C")&&"1".equals(sod.getIsjudge())) {
  16825. String min="";
  16826. if (!SqlJoint.IsNullOrSpace(sod.getAvg_val())) {
  16827. min=sod.getVal1();
  16828. }else {
  16829. min = compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), sod.getJudge_basis());
  16830. }
  16831. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),min,null,null,null,null,null,null,null,null);
  16832. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),min,null,null,null,null,null,null,null,null);
  16833. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),min,null,null,null,null,null,null,null,null);
  16834. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),min,null,null,null,null,null,null,null,null);
  16835. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),min,null,null,null,null,null,null,null,null);
  16836. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),min,null,null,null,null,null,null,null,null);
  16837. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),min,null,null,null,null,null,null,null,null);
  16838. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),min,null,null,null,null,null,null,null,null);
  16839. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  16840. pass=false;
  16841. }
  16842. }
  16843. //逐项值判定
  16844. if (SqlJoint.IsNullOrSpace(sod.getJudge_basis())||sod.getJudge_basis().equalsIgnoreCase("D")&&"1".equals(sod.getIsjudge())) {
  16845. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16846. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16847. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16848. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16849. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16850. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16851. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16852. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  16853. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  16854. pass=false;
  16855. }
  16856. }
  16857. if((pass && !SqlJoint.IsNullOrSpace(sod.getAddcondition()) && sod.getAddcondition().equals("1")) || (!pass && !SqlJoint.IsNullOrSpace(sod.getAddcondition()) && sod.getAddcondition().equals("0"))){
  16858. pass = true;
  16859. int count = 0;
  16860. //允许一个值
  16861. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("A")&&"1".equals(sod.getIsjudge())) {
  16862. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16863. if(bool0.equals("2")){
  16864. count ++;
  16865. }else{
  16866. bool0=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16867. if(bool0.equals("2")){
  16868. count ++;
  16869. }else{
  16870. bool0=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16871. if(bool0.equals("2")){
  16872. count ++;
  16873. }
  16874. }
  16875. }
  16876. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16877. if ("2".equals(bool0)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal1())) {
  16878. lists.add(sod.getPhy_name_l()+":"+sod.getVal1());
  16879. }
  16880. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16881. if(bool1.equals("2")){
  16882. count ++;
  16883. }else{
  16884. bool1=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16885. if(bool1.equals("2")){
  16886. count ++;
  16887. }else{
  16888. bool1=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16889. if(bool1.equals("2")){
  16890. count ++;
  16891. }
  16892. }
  16893. }
  16894. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal1(),null,null,null,null,null,null,null,null);
  16895. if ("2".equals(bool1)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal1())) {
  16896. lists.add(sod.getPhy_name_l()+":"+sod.getVal1());
  16897. }
  16898. bool2=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16899. if(bool2.equals("2")){
  16900. count ++;
  16901. }else{
  16902. bool2=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16903. if(bool2.equals("2")){
  16904. count ++;
  16905. }else{
  16906. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16907. if(bool2.equals("2")){
  16908. count ++;
  16909. }
  16910. }
  16911. }
  16912. bool2=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16913. if ("2".equals(bool2)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal2())) {
  16914. lists.add(sod.getPhy_name_l()+":"+sod.getVal2());
  16915. }
  16916. bool3=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16917. if(bool3.equals("2")){
  16918. count ++;
  16919. }else{
  16920. bool3=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16921. if(bool3.equals("2")){
  16922. count ++;
  16923. }else{
  16924. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16925. if(bool3.equals("2")){
  16926. count ++;
  16927. }
  16928. }
  16929. }
  16930. bool3=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal2(),null,null,null,null,null,null,null,null);
  16931. if ("2".equals(bool3)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal2())) {
  16932. lists.add(sod.getPhy_name_l()+":"+sod.getVal2());
  16933. }
  16934. bool4=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16935. if(bool4.equals("2")){
  16936. count ++;
  16937. }else{
  16938. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16939. if(bool4.equals("2")){
  16940. count ++;
  16941. }else{
  16942. bool4=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16943. if(bool0.equals("2")){
  16944. count ++;
  16945. }
  16946. }
  16947. }
  16948. bool4=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16949. if ("2".equals(bool4)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal3())) {
  16950. lists.add(sod.getPhy_name_l()+":"+sod.getVal3());
  16951. }
  16952. bool5=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16953. if(bool5.equals("2")){
  16954. count ++;
  16955. }else{
  16956. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16957. if(bool5.equals("2")){
  16958. count ++;
  16959. }else{
  16960. bool5=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16961. if(bool0.equals("2")){
  16962. count ++;
  16963. }
  16964. }
  16965. }
  16966. bool5=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal3(),null,null,null,null,null,null,null,null);
  16967. if ("2".equals(bool5)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal3())) {
  16968. lists.add(sod.getPhy_name_l()+":"+sod.getVal3());
  16969. }
  16970. if(count > 1){
  16971. pass=false;
  16972. }else{
  16973. if ("2".equals(bool0)||"2".equals(bool1) || "2".equals(bool2)||"2".equals(bool3) || "2".equals(bool4)||"2".equals(bool5) ){
  16974. pass=false;
  16975. }
  16976. }
  16977. }
  16978. //最大最小差值
  16979. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("B")&&"1".equals(sod.getIsjudge())) {
  16980. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), "D");
  16981. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  16982. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  16983. if ("2".equals(bool0)||"2".equals(bool1)) {
  16984. pass=false;
  16985. }
  16986. }
  16987. //平均值
  16988. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("C")&&"1".equals(sod.getIsjudge())) {
  16989. String min="";
  16990. if (!SqlJoint.IsNullOrSpace(sod.getAvg_val())) {
  16991. min=sod.getVal1();
  16992. }else {
  16993. min = compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), sod.getJudge_basis());
  16994. }
  16995. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  16996. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  16997. if ("2".equals(bool0)||"2".equals(bool1)) {
  16998. pass=false;
  16999. }
  17000. }
  17001. //最小值
  17002. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("D")&&"1".equals(sod.getIsjudge())) {
  17003. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(), sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(),"A");
  17004. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  17005. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  17006. if ("2".equals(bool0)||"2".equals(bool1)) {
  17007. pass=false;
  17008. }
  17009. }
  17010. //最大值
  17011. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("E")&&"1".equals(sod.getIsjudge())) {
  17012. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), "B");
  17013. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  17014. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  17015. if ("2".equals(bool0)||"2".equals(bool1)) {
  17016. pass=false;
  17017. }
  17018. }
  17019. //所有值
  17020. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("E")&&"1".equals(sod.getIsjudge())) {
  17021. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17022. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17023. bool2=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17024. bool3=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17025. bool4=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17026. bool5=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17027. if ("2".equals(bool0)||"2".equals(bool1) ||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)) {
  17028. pass=false;
  17029. }
  17030. }
  17031. }
  17032. if(sod.getDefect_flag()!= null){
  17033. if(sod.getDefect_flag().equals("1")){
  17034. pass = false;
  17035. }
  17036. }
  17037. if(!pass){
  17038. judge = false;
  17039. }
  17040. }
  17041. if(!judge){
  17042. //240524 增加代码
  17043. /* if(material_no.startsWith("R") || material_no.startsWith("L")){
  17044. String sqlcoilresult = "select JUDGERESULT,t.* from qcm_judge_coil_result t where t.COIL_NO = '"+material_no+"' and t.judgeresult = '1' ";
  17045. List<HashMap> HMCOIL = mapper.query(sqlcoilresult);
  17046. if(HMCOIL!=null && HMCOIL.size()>=1){
  17047. jsobj2.put("MATERIAL_NO", material_no);
  17048. ttmaps.add(jsobj2);
  17049. }
  17050. }*/
  17051. continue;
  17052. }else{
  17053. jsobj2.put("MATERIAL_NO", material_no);
  17054. ttmaps.add(jsobj2);
  17055. }
  17056. }
  17057. }
  17058. SqlSession.close();
  17059. return ttmaps.toString();
  17060. }
  17061. /**
  17062. * 物料、订单号匹配接口 产销质财一体化冷轧充当功能修改 20240531运维平台申请 连退粗糙度
  17063. * @param design_key
  17064. * @param materail_no
  17065. * @return
  17066. * @throws Exception
  17067. */
  17068. @SuppressWarnings({ "unchecked", "rawtypes" })
  17069. public String JudgeCheckLT(String param1) throws Exception{
  17070. JSONObject jsonObject = (JSONObject) JSON.parse(param1);
  17071. JSONArray displays = jsonObject.getJSONArray("PARAMS");
  17072. JSONArray ttmaps = new JSONArray();
  17073. for(Object param2 :displays){
  17074. JSONObject jsobj2 = new JSONObject();
  17075. JSONObject object = JSONObject.parseObject(param2.toString());
  17076. String material_no = object.getString("MATERIAL_NO");
  17077. if(!material_no.startsWith("L")){
  17078. jsobj2.put("MATERIAL_NO", material_no);
  17079. jsobj2.put("MEMO", "当前接口是连退粗糙度接口,只能传连退数据");
  17080. ttmaps.add(jsobj2);
  17081. continue;
  17082. }
  17083. String design_key = object.getString("DESIGN_KEY");
  17084. String cert_inst_name = object.getString("CERT_INST_NAME");
  17085. //比较成分
  17086. /*QcmJhyElementsServiceImpl qes = new QcmJhyElementsServiceImpl();
  17087. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  17088. QcmJhyPhyresultServiceImpl qjp = new QcmJhyPhyresultServiceImpl();*/
  17089. List<HashMap> hashmap = new ArrayList<HashMap>();
  17090. if(material_no.startsWith("H")){
  17091. hashmap = mapper.doQueryMaterialInfoHB(material_no);
  17092. }else if(material_no.startsWith("Z")){
  17093. hashmap = mapper.doQueryMaterialInfoZB(material_no);
  17094. }
  17095. else if (material_no.startsWith("G") || material_no.startsWith("E") || material_no.startsWith("Y")){
  17096. hashmap = mapper.doQueryMaterialInfoX(material_no);
  17097. }else{
  17098. hashmap = mapper.doQueryMaterialInfoJ1(material_no);//连退
  17099. }
  17100. if(hashmap.size() == 0){
  17101. hashmap = mapper.doQueryMaterialInfoZHB1(material_no);
  17102. if(hashmap.size()==0){
  17103. hashmap = mapper.doQueryMaterialInfoY(material_no);
  17104. }
  17105. }
  17106. if(hashmap.size() == 0){
  17107. continue;
  17108. }
  17109. QcmJhySampleConsignD _consignD=new QcmJhySampleConsignD();
  17110. boolean pass=true;
  17111. boolean judge = true;
  17112. //材质检验
  17113. String condition=" 1=1";
  17114. QcmJhySampleROrd qjsr=new QcmJhySampleROrd();
  17115. List<QcmJhySampleROrd> listqjsr=new ArrayList<QcmJhySampleROrd>();
  17116. int status=0;
  17117. List<String> lists=new ArrayList<String>();//异常材料处理用,用于不合格项目的备注
  17118. List<QcmJhySampleROrd> listz = new ArrayList<QcmJhySampleROrd>();
  17119. String sql = "select * from qcm_ord_design_std_pic where design_key = '"+design_key+"'";
  17120. if(material_no.startsWith("R")){
  17121. sql = "select * from qcm_ord_design_std_pic where design_key = '"+design_key+"' and process_code = 'RZ1'";
  17122. }else if(material_no.startsWith("L")){
  17123. sql = "select * from qcm_ord_design_std_pic where design_key = '"+design_key+"' and process_code = 'LT1' and PHY_CODE_L='HV' ";//240625 粗糙度
  17124. }
  17125. List<HashMap> list2 = mapper.query(sql);//订单标准
  17126. if(list2.size() ==0){
  17127. jsobj2.put("MATERIAL_NO", material_no);
  17128. jsobj2.put("MEMO", "订单号【"+design_key+"】未找到粗糙度项目!");
  17129. ttmaps.add(jsobj2);
  17130. continue;
  17131. }
  17132. String INSPECTION_LOT = hashmap.get(0).get("INSPECTION_LOT") ==null?"":hashmap.get(0).get("INSPECTION_LOT").toString();
  17133. sql = "select * from qcm_jhy_sample_r_ord a where a.batch_no LIKE '"+hashmap.get(0).get("BATCHNO")+"%' and a.steel_name = '"+list2.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"' and a.inspection_lot = '"+INSPECTION_LOT+"' order by a.create_time desc ";
  17134. List<HashMap> list1 = mapper.query(sql);
  17135. if(list1.size() ==0){//未判定
  17136. if(material_no.startsWith("R")){
  17137. sql = "select * from qcm_jhy_sample_r_ord a where a.steel_name = '"+list2.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"' and a.inspection_lot = '"+INSPECTION_LOT+"' order by a.create_time desc ";
  17138. list1 = mapper.query(sql);
  17139. if(list1.size() ==0){
  17140. sql = "select * from qcm_jhy_sample_r_ord a where a.batch_no LIKE '"+hashmap.get(0).get("BATCHNO")+"%' and a.steel_name = '"+list2.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"' order by a.create_time desc ";
  17141. list1 = mapper.query(sql);
  17142. }
  17143. }else{
  17144. sql = "select * from qcm_jhy_sample_r_ord a where a.batch_no LIKE '"+hashmap.get(0).get("BATCHNO")+"%' and a.steel_name = '"+list2.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"' order by a.create_time desc ";
  17145. list1 = mapper.query(sql);
  17146. }
  17147. if(list1.size() ==0){
  17148. jsobj2.put("MATERIAL_NO", material_no);
  17149. jsobj2.put("MEMO", "当前轧批还没有做委托,未找到相应委托数据");
  17150. ttmaps.add(jsobj2);
  17151. continue;
  17152. }else{
  17153. listz=mapper.GetSamplePhyInfos(condition,list1.get(0).get("INSPECTION_LOT").toString(),cert_inst_name);
  17154. }
  17155. }else{//已判定
  17156. listz=mapper.GetSamplePhyInfos(condition,list1.get(0).get("INSPECTION_LOT").toString(),cert_inst_name);
  17157. }
  17158. /*if(hashmap.get(0).get("INSPECTION_LOT") !=null){
  17159. listz=mapper.GetSamplePhyInfos(condition,hashmap.get(0).get("INSPECTION_LOT").toString(),cert_inst_name);
  17160. }
  17161. else{
  17162. String sql = "select * from qcm_ord_design_std_pic where design_key = '"+design_key+"'";
  17163. List<HashMap> list2 = mapper.query(sql);
  17164. sql = "select * from qcm_jhy_sample_r_ord a where a.batch_no = '"+hashmap.get(0).get("BATCHNO")+"' and a.steel_name = '"+list2.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"'";
  17165. List<HashMap> list1 = mapper.query(sql);
  17166. if(list1.size() ==0){
  17167. sql = "select * from qcm_jhy_sample_r_ord a where a.batch_no = '"+hashmap.get(0).get("BATCHNO")+"' and a.steel_name = '"+hashmap.get(0).get("STEEL_NAME")+"' and a.cert_inst_name = '"+cert_inst_name+"'";
  17168. list1 = mapper.query(sql);
  17169. if(list1.size() ==0){
  17170. continue;
  17171. }else{
  17172. listz=mapper.GetSamplePhyInfos(condition,list1.get(0).get("INSPECTION_LOT").toString(),cert_inst_name);
  17173. }
  17174. }
  17175. }*/
  17176. List<QcmJhySampleROrd> listOrd=new ArrayList<QcmJhySampleROrd>();
  17177. List<String> w=new ArrayList<String>();
  17178. for (QcmJhySampleROrd o : listz) {
  17179. boolean flag=true;//判定试样号向下的取样编号是否都是已完成状态;
  17180. List<QcmJhySampleConsignD> listd = mapper.findQcmJhySampleConsignD2(o.getSmp_no());
  17181. for (QcmJhySampleConsignD d : listd) {
  17182. if (!d.getStatus().equals("3")) {
  17183. flag=false;//委托未返回实绩
  17184. jsobj2.put("MATERIAL_NO", material_no);
  17185. jsobj2.put("MEMO", "委托未返回实绩,还未材质判定!");
  17186. ttmaps.add(jsobj2);
  17187. continue;
  17188. }
  17189. }
  17190. if (flag) {
  17191. listOrd.add(o);//委托已返回实绩
  17192. }
  17193. }
  17194. _consignD=new QcmJhySampleConsignD();
  17195. for (QcmJhySampleROrd qcmJhySampleROrds : listOrd) {
  17196. _consignD.setSmp_no(qcmJhySampleROrds.getSmp_no());
  17197. _consignD.setInspection_lot(qcmJhySampleROrds.getInspection_lot());
  17198. _consignD.setHeat_no(qcmJhySampleROrds.getHeat_no());
  17199. //获取取样编号
  17200. List<QcmJhySampleConsignD> listConsignD=mapper.findQcmJhySampleConsignD(qcmJhySampleROrds.getSmp_no(), qcmJhySampleROrds.getInspection_lot(), qcmJhySampleROrds.getHeat_no());
  17201. //上面listConsignD 只会查出一条数据,如果有多条数据需要跟设计确认是如何进行关联的
  17202. List<QcmJhyPhyresult> listResult=new ArrayList<QcmJhyPhyresult>();
  17203. //获取检验信息
  17204. for (QcmJhySampleConsignD d : listConsignD) {
  17205. QcmJhyPhyresult _result=new QcmJhyPhyresult();
  17206. List<QcmJhyPhyresult> listqjp=mapper.findphyresult(d.getSpecimen_no());
  17207. if (listqjp.size()<1) {
  17208. continue;
  17209. }
  17210. for (QcmJhyPhyresult q : listqjp) {
  17211. if(SqlJoint.IsNullOrSpace(q.getVal1()) && SqlJoint.IsNullOrSpace(q.getVal2()) && SqlJoint.IsNullOrSpace(q.getVal3()) ){
  17212. }else{
  17213. listResult.add(q);
  17214. }
  17215. }
  17216. List<QcmJhySampleConsignDItem> listi=mapper.findQcmJhySampleConsignDItem(d.getSpecimen_no());
  17217. if(listi.size()<=0){
  17218. continue;
  17219. }/*else{
  17220. for (QcmJhySampleConsignDItem t : listi) {
  17221. List<QcmJhySampleConsignDItem> qjsList = (List<QcmJhySampleConsignDItem>) new QcmJhySampleConsignDItem();
  17222. if(!SqlJoint.IsNullOrSpace(t.getGroup_seq())){
  17223. qjsList = mapper.findQcmJhySampleConsignDItem1(t.getSpecimen_no(),t.getGroup_seq());
  17224. }else{
  17225. qjsList = mapper.findQcmJhySampleConsignDItem2(t.getSpecimen_no());
  17226. }
  17227. Boolean groupFlag = false;
  17228. for (QcmJhySampleConsignDItem qsc : qjsList) {
  17229. for(QcmJhySampleConsignDItem qjs1: listi){
  17230. if(qjs1.getSpecimen_no().equals(qsc.getSpecimen_no()) && qjs1.getSeq().equals(qsc.getSeq())){
  17231. if(!SqlJoint.IsNullOrSpace(qjs1.getVal1()) || !SqlJoint.IsNullOrSpace(qjs1.getVal2()) || !SqlJoint.IsNullOrSpace(qjs1.getVal3())){
  17232. groupFlag = true;
  17233. break;
  17234. }
  17235. }
  17236. }
  17237. }
  17238. if (SqlJoint.IsNullOrSpace(t.getVal1())&&SqlJoint.IsNullOrSpace(t.getVal2())&&SqlJoint.IsNullOrSpace(t.getVal3()) && (SqlJoint.IsNullOrSpace(t.getGroup_seq()) || !groupFlag) && !"0".equals(t.getIsjudge())) {
  17239. return "N";
  17240. }
  17241. }
  17242. }*/
  17243. }
  17244. //获取标准和实测值(调用zj书写的接口)
  17245. CoreReturnObject r =querryJudgetItemInfo(qcmJhySampleROrds.getSmp_no(), design_key,qcmJhySampleROrds.getSteel_name(),qcmJhySampleROrds.getPline_code(),listz.get(0).getPhy_id());
  17246. List<QcmOrdDesignStdPic> listp = mapper.queryQCMOrdDesignStdPic("SELECT distinct a.phy_code_l,a.phy_code_m,a.phy_code_s,a.item_code_d,a.item_code_t,a.item_desc_s,a.item_code_l FROM qcm_ord_design_std_pic a WHERE DESIGN_KEY = '"+design_key+"'");
  17247. List<QcmJhySampleConsignDItem> listd=(List<QcmJhySampleConsignDItem>) r.getResult();
  17248. if(listd==null || listd.size() < listp.size()){
  17249. continue;
  17250. }
  17251. for (QcmJhySampleConsignDItem sod : listd) {//实绩值
  17252. if(SqlJoint.IsNullOrSpace(sod.getVal1()) && SqlJoint.IsNullOrSpace(sod.getVal2()) && SqlJoint.IsNullOrSpace(sod.getVal3()) && SqlJoint.IsNullOrSpace(sod.getAvg_val())){
  17253. judge = false;
  17254. break;
  17255. }
  17256. if(SqlJoint.IsNullOrSpace(sod.getJf_stdmax()) && SqlJoint.IsNullOrSpace(sod.getJf_stdmin())){
  17257. continue;
  17258. }
  17259. String bool0="";
  17260. String bool1="";
  17261. String bool2="";
  17262. String bool3="";
  17263. String bool4="";
  17264. String bool5="";
  17265. String bool6="";
  17266. String bool7="";
  17267. pass = true;
  17268. //if(pass){
  17269. //最小值判定
  17270. if (!SqlJoint.IsNullOrSpace(sod.getJudge_basis())&&sod.getJudge_basis().equalsIgnoreCase("A")&&"1".equals(sod.getIsjudge())) {
  17271. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(), sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(),sod.getJudge_basis());
  17272. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),min,null,null,null,null,null,null,null,null);
  17273. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),min,null,null,null,null,null,null,null,null);
  17274. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),min,null,null,null,null,null,null,null,null);
  17275. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),min,null,null,null,null,null,null,null,null);
  17276. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),min,null,null,null,null,null,null,null,null);
  17277. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),min,null,null,null,null,null,null,null,null);
  17278. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),min,null,null,null,null,null,null,null,null);
  17279. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),min,null,null,null,null,null,null,null,null);
  17280. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  17281. pass=false;
  17282. }
  17283. }
  17284. //最大值判定
  17285. if (!SqlJoint.IsNullOrSpace(sod.getJudge_basis())&&sod.getJudge_basis().equalsIgnoreCase("B")&&"1".equals(sod.getIsjudge())) {
  17286. String min = compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(), sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(),sod.getJudge_basis());
  17287. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),min,null,null,null,null,null,null,null,null);
  17288. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),min,null,null,null,null,null,null,null,null);
  17289. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),min,null,null,null,null,null,null,null,null);
  17290. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),min,null,null,null,null,null,null,null,null);
  17291. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),min,null,null,null,null,null,null,null,null);
  17292. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),min,null,null,null,null,null,null,null,null);
  17293. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),min,null,null,null,null,null,null,null,null);
  17294. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),min,null,null,null,null,null,null,null,null);
  17295. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  17296. pass=false;
  17297. }
  17298. }
  17299. //平均值判定
  17300. if (!SqlJoint.IsNullOrSpace(sod.getJudge_basis())&&sod.getJudge_basis().equalsIgnoreCase("C")&&"1".equals(sod.getIsjudge())) {
  17301. String min="";
  17302. if (!SqlJoint.IsNullOrSpace(sod.getAvg_val())) {
  17303. min=sod.getVal1();
  17304. }else {
  17305. min = compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), sod.getJudge_basis());
  17306. }
  17307. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),min,null,null,null,null,null,null,null,null);
  17308. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),min,null,null,null,null,null,null,null,null);
  17309. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),min,null,null,null,null,null,null,null,null);
  17310. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),min,null,null,null,null,null,null,null,null);
  17311. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),min,null,null,null,null,null,null,null,null);
  17312. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),min,null,null,null,null,null,null,null,null);
  17313. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),min,null,null,null,null,null,null,null,null);
  17314. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),min,null,null,null,null,null,null,null,null);
  17315. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  17316. pass=false;
  17317. }
  17318. }
  17319. //逐项值判定
  17320. if (SqlJoint.IsNullOrSpace(sod.getJudge_basis())||sod.getJudge_basis().equalsIgnoreCase("D")&&"1".equals(sod.getIsjudge())) {
  17321. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17322. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17323. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17324. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17325. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17326. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17327. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17328. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17329. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  17330. pass=false;
  17331. }
  17332. }
  17333. if((pass && !SqlJoint.IsNullOrSpace(sod.getAddcondition()) && sod.getAddcondition().equals("1")) || (!pass && !SqlJoint.IsNullOrSpace(sod.getAddcondition()) && sod.getAddcondition().equals("0"))){
  17334. pass = true;
  17335. int count = 0;
  17336. //允许一个值
  17337. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("A")&&"1".equals(sod.getIsjudge())) {
  17338. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17339. if(bool0.equals("2")){
  17340. count ++;
  17341. }else{
  17342. bool0=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17343. if(bool0.equals("2")){
  17344. count ++;
  17345. }else{
  17346. bool0=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17347. if(bool0.equals("2")){
  17348. count ++;
  17349. }
  17350. }
  17351. }
  17352. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17353. if ("2".equals(bool0)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal1())) {
  17354. lists.add(sod.getPhy_name_l()+":"+sod.getVal1());
  17355. }
  17356. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17357. if(bool1.equals("2")){
  17358. count ++;
  17359. }else{
  17360. bool1=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17361. if(bool1.equals("2")){
  17362. count ++;
  17363. }else{
  17364. bool1=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17365. if(bool1.equals("2")){
  17366. count ++;
  17367. }
  17368. }
  17369. }
  17370. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17371. if ("2".equals(bool1)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal1())) {
  17372. lists.add(sod.getPhy_name_l()+":"+sod.getVal1());
  17373. }
  17374. bool2=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17375. if(bool2.equals("2")){
  17376. count ++;
  17377. }else{
  17378. bool2=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17379. if(bool2.equals("2")){
  17380. count ++;
  17381. }else{
  17382. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17383. if(bool2.equals("2")){
  17384. count ++;
  17385. }
  17386. }
  17387. }
  17388. bool2=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17389. if ("2".equals(bool2)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal2())) {
  17390. lists.add(sod.getPhy_name_l()+":"+sod.getVal2());
  17391. }
  17392. bool3=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17393. if(bool3.equals("2")){
  17394. count ++;
  17395. }else{
  17396. bool3=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17397. if(bool3.equals("2")){
  17398. count ++;
  17399. }else{
  17400. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17401. if(bool3.equals("2")){
  17402. count ++;
  17403. }
  17404. }
  17405. }
  17406. bool3=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17407. if ("2".equals(bool3)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal2())) {
  17408. lists.add(sod.getPhy_name_l()+":"+sod.getVal2());
  17409. }
  17410. bool4=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17411. if(bool4.equals("2")){
  17412. count ++;
  17413. }else{
  17414. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17415. if(bool4.equals("2")){
  17416. count ++;
  17417. }else{
  17418. bool4=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17419. if(bool0.equals("2")){
  17420. count ++;
  17421. }
  17422. }
  17423. }
  17424. bool4=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17425. if ("2".equals(bool4)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal3())) {
  17426. lists.add(sod.getPhy_name_l()+":"+sod.getVal3());
  17427. }
  17428. bool5=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17429. if(bool5.equals("2")){
  17430. count ++;
  17431. }else{
  17432. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17433. if(bool5.equals("2")){
  17434. count ++;
  17435. }else{
  17436. bool5=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17437. if(bool0.equals("2")){
  17438. count ++;
  17439. }
  17440. }
  17441. }
  17442. bool5=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17443. if ("2".equals(bool5)&&!lists.contains(sod.getPhy_name_l()+":"+sod.getVal3())) {
  17444. lists.add(sod.getPhy_name_l()+":"+sod.getVal3());
  17445. }
  17446. if(count > 1){
  17447. pass=false;
  17448. }else{
  17449. if ("2".equals(bool0)||"2".equals(bool1) || "2".equals(bool2)||"2".equals(bool3) || "2".equals(bool4)||"2".equals(bool5) ){
  17450. pass=false;
  17451. }
  17452. }
  17453. }
  17454. //最大最小差值
  17455. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("B")&&"1".equals(sod.getIsjudge())) {
  17456. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), "D");
  17457. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  17458. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  17459. if ("2".equals(bool0)||"2".equals(bool1)) {
  17460. pass=false;
  17461. }
  17462. }
  17463. //平均值
  17464. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("C")&&"1".equals(sod.getIsjudge())) {
  17465. String min="";
  17466. if (!SqlJoint.IsNullOrSpace(sod.getAvg_val())) {
  17467. min=sod.getVal1();
  17468. }else {
  17469. min = compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), sod.getJudge_basis());
  17470. }
  17471. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  17472. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  17473. if ("2".equals(bool0)||"2".equals(bool1)) {
  17474. pass=false;
  17475. }
  17476. }
  17477. //最小值
  17478. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("D")&&"1".equals(sod.getIsjudge())) {
  17479. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(), sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(),"A");
  17480. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  17481. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  17482. if ("2".equals(bool0)||"2".equals(bool1)) {
  17483. pass=false;
  17484. }
  17485. }
  17486. //最大值
  17487. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("E")&&"1".equals(sod.getIsjudge())) {
  17488. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), "B");
  17489. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  17490. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  17491. if ("2".equals(bool0)||"2".equals(bool1)) {
  17492. pass=false;
  17493. }
  17494. }
  17495. //所有值
  17496. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("E")&&"1".equals(sod.getIsjudge())) {
  17497. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17498. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17499. bool2=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17500. bool3=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17501. bool4=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17502. bool5=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17503. if ("2".equals(bool0)||"2".equals(bool1) ||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)) {
  17504. pass=false;
  17505. }
  17506. }
  17507. }
  17508. if(sod.getDefect_flag()!= null){
  17509. if(sod.getDefect_flag().equals("1")){
  17510. pass = false;
  17511. }
  17512. }
  17513. if(!pass){
  17514. judge = false;
  17515. }
  17516. }
  17517. if(!judge){
  17518. //240524 增加代码
  17519. /* if(material_no.startsWith("R") || material_no.startsWith("L")){
  17520. String sqlcoilresult = "select JUDGERESULT,t.* from qcm_judge_coil_result t where t.COIL_NO = '"+material_no+"' and t.judgeresult = '1' ";
  17521. List<HashMap> HMCOIL = mapper.query(sqlcoilresult);
  17522. if(HMCOIL!=null && HMCOIL.size()>=1){
  17523. jsobj2.put("MATERIAL_NO", material_no);
  17524. ttmaps.add(jsobj2);
  17525. }
  17526. }*/
  17527. continue;
  17528. }else{
  17529. jsobj2.put("MATERIAL_NO", material_no);
  17530. ttmaps.add(jsobj2);
  17531. }
  17532. }
  17533. }
  17534. SqlSession.close();
  17535. return ttmaps.toString();
  17536. }
  17537. /**
  17538. * 物料、订单号匹配接口 11111
  17539. * @param design_key
  17540. * @param materail_no
  17541. * @return
  17542. * @throws Exception
  17543. */
  17544. @SuppressWarnings({ "unchecked", "rawtypes" })
  17545. public String JudgeCheck(String design_key,String materail_no,String cert_inst_name) throws Exception{
  17546. //比较成分
  17547. QcmJhyElementsServiceImpl qes = new QcmJhyElementsServiceImpl();
  17548. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  17549. QcmJhyPhyresultServiceImpl qjp = new QcmJhyPhyresultServiceImpl();
  17550. List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(materail_no);
  17551. if(hashmap.size() == 0){
  17552. hashmap = qjms.doQueryMaterialInfoJ(materail_no);
  17553. }
  17554. if(hashmap.size() == 0){
  17555. return "N";
  17556. }
  17557. QcmJhySampleConsignD _consignD=new QcmJhySampleConsignD();
  17558. boolean pass=true;
  17559. boolean judge = true;
  17560. //材质检验
  17561. String condition=" 1=1";
  17562. QcmJhySampleROrd qjsr=new QcmJhySampleROrd();
  17563. List<QcmJhySampleROrd> listqjsr=new ArrayList<QcmJhySampleROrd>();
  17564. int status=0;
  17565. List<String> lists=new ArrayList<String>();//异常材料处理用,用于不合格项目的备注
  17566. List<QcmJhySampleROrd> listz=mapper.GetSamplePhyInfos(condition,hashmap.get(0).get("INSPECTION_LOT")==null?"":hashmap.get(0).get("INSPECTION_LOT").toString(),cert_inst_name);
  17567. List<QcmJhySampleROrd> listOrd=new ArrayList<QcmJhySampleROrd>();
  17568. List<String> w=new ArrayList<String>();
  17569. for (QcmJhySampleROrd o : listz) {
  17570. boolean flag=true;//判定试样号向下的取样编号是否都是已完成状态;
  17571. List<QcmJhySampleConsignD> listd = mapper.findQcmJhySampleConsignD2(o.getSmp_no());
  17572. for (QcmJhySampleConsignD d : listd) {
  17573. if (!d.getStatus().equals("3")) {
  17574. flag=false;
  17575. }
  17576. }
  17577. if (flag) {
  17578. listOrd.add(o);
  17579. }
  17580. }
  17581. _consignD=new QcmJhySampleConsignD();
  17582. for (QcmJhySampleROrd qcmJhySampleROrds : listOrd) {
  17583. _consignD.setSmp_no(qcmJhySampleROrds.getSmp_no());
  17584. _consignD.setInspection_lot(qcmJhySampleROrds.getInspection_lot());
  17585. _consignD.setHeat_no(qcmJhySampleROrds.getHeat_no());
  17586. //获取取样编号
  17587. List<QcmJhySampleConsignD> listConsignD=mapper.findQcmJhySampleConsignD(qcmJhySampleROrds.getSmp_no(), qcmJhySampleROrds.getInspection_lot(), qcmJhySampleROrds.getHeat_no());
  17588. //上面listConsignD 只会查出一条数据,如果有多条数据需要跟设计确认是如何进行关联的
  17589. List<QcmJhyPhyresult> listResult=new ArrayList<QcmJhyPhyresult>();
  17590. //获取检验信息
  17591. for (QcmJhySampleConsignD d : listConsignD) {
  17592. QcmJhyPhyresult _result=new QcmJhyPhyresult();
  17593. List<QcmJhyPhyresult> listqjp=mapper.findphyresult(d.getSpecimen_no());
  17594. if (listqjp.size()<1) {
  17595. continue;
  17596. }
  17597. for (QcmJhyPhyresult q : listqjp) {
  17598. if(SqlJoint.IsNullOrSpace(q.getVal1()) && SqlJoint.IsNullOrSpace(q.getVal2()) && SqlJoint.IsNullOrSpace(q.getVal3())){
  17599. }else{
  17600. listResult.add(q);
  17601. }
  17602. }
  17603. List<QcmJhySampleConsignDItem> listi=mapper.findQcmJhySampleConsignDItem(d.getSpecimen_no());
  17604. if(listi.size()<=0){
  17605. return "N";
  17606. }/*else{
  17607. for (QcmJhySampleConsignDItem t : listi) {
  17608. List<QcmJhySampleConsignDItem> qjsList = (List<QcmJhySampleConsignDItem>) new QcmJhySampleConsignDItem();
  17609. if(!SqlJoint.IsNullOrSpace(t.getGroup_seq())){
  17610. qjsList = mapper.findQcmJhySampleConsignDItem1(t.getSpecimen_no(),t.getGroup_seq());
  17611. }else{
  17612. qjsList = mapper.findQcmJhySampleConsignDItem2(t.getSpecimen_no());
  17613. }
  17614. Boolean groupFlag = false;
  17615. for (QcmJhySampleConsignDItem qsc : qjsList) {
  17616. for(QcmJhySampleConsignDItem qjs1: listi){
  17617. if(qjs1.getSpecimen_no().equals(qsc.getSpecimen_no()) && qjs1.getSeq().equals(qsc.getSeq())){
  17618. if(!SqlJoint.IsNullOrSpace(qjs1.getVal1()) || !SqlJoint.IsNullOrSpace(qjs1.getVal2()) || !SqlJoint.IsNullOrSpace(qjs1.getVal3())){
  17619. groupFlag = true;
  17620. break;
  17621. }
  17622. }
  17623. }
  17624. }
  17625. if (SqlJoint.IsNullOrSpace(t.getVal1())&&SqlJoint.IsNullOrSpace(t.getVal2())&&SqlJoint.IsNullOrSpace(t.getVal3()) && (SqlJoint.IsNullOrSpace(t.getGroup_seq()) || !groupFlag) && !"0".equals(t.getIsjudge())) {
  17626. return "N";
  17627. }
  17628. }
  17629. }*/
  17630. }
  17631. //获取标准和实测值(调用zj书写的接口)
  17632. CoreReturnObject r =qjp.querryJudgetItemInfo(qcmJhySampleROrds.getSmp_no(), design_key,qcmJhySampleROrds.getSteel_name(),qcmJhySampleROrds.getPline_code());
  17633. List<QcmOrdDesignStdPic> listp = mapper.queryQCMOrdDesignStdPic("SELECT distinct a.phy_code_l,a.phy_code_m,a.phy_code_s,a.item_code_d,a.item_code_t,a.item_desc_s,a.item_code_l FROM qcm_ord_design_std_pic a WHERE DESIGN_KEY = '"+design_key+"'");
  17634. List<QcmJhySampleConsignDItem> listd=(List<QcmJhySampleConsignDItem>) r.getResult();
  17635. if(listd.size() < listp.size()){
  17636. return "N";
  17637. }
  17638. for (QcmJhySampleConsignDItem sod : listd) {
  17639. if(SqlJoint.IsNullOrSpace(sod.getVal1()) && SqlJoint.IsNullOrSpace(sod.getVal2()) && SqlJoint.IsNullOrSpace(sod.getVal3())){
  17640. return "N";
  17641. }
  17642. if(SqlJoint.IsNullOrSpace(sod.getJf_stdmax()) && SqlJoint.IsNullOrSpace(sod.getJf_stdmin())){
  17643. return "N";
  17644. }
  17645. String bool0="";
  17646. String bool1="";
  17647. String bool2="";
  17648. String bool3="";
  17649. String bool4="";
  17650. String bool5="";
  17651. String bool6="";
  17652. String bool7="";
  17653. pass = true;
  17654. //if(pass){
  17655. //最小值判定
  17656. if (!SqlJoint.IsNullOrSpace(sod.getJudge_basis())&&sod.getJudge_basis().equalsIgnoreCase("A")&&"1".equals(sod.getIsjudge())) {
  17657. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(), sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(),sod.getJudge_basis());
  17658. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),min,null,null,null,null,null,null,null,null);
  17659. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),min,null,null,null,null,null,null,null,null);
  17660. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),min,null,null,null,null,null,null,null,null);
  17661. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),min,null,null,null,null,null,null,null,null);
  17662. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),min,null,null,null,null,null,null,null,null);
  17663. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),min,null,null,null,null,null,null,null,null);
  17664. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),min,null,null,null,null,null,null,null,null);
  17665. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),min,null,null,null,null,null,null,null,null);
  17666. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  17667. pass=false;
  17668. }
  17669. }
  17670. //最大值判定
  17671. if (!SqlJoint.IsNullOrSpace(sod.getJudge_basis())&&sod.getJudge_basis().equalsIgnoreCase("B")&&"1".equals(sod.getIsjudge())) {
  17672. String min = compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(), sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(),sod.getJudge_basis());
  17673. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),min,null,null,null,null,null,null,null,null);
  17674. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),min,null,null,null,null,null,null,null,null);
  17675. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),min,null,null,null,null,null,null,null,null);
  17676. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),min,null,null,null,null,null,null,null,null);
  17677. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),min,null,null,null,null,null,null,null,null);
  17678. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),min,null,null,null,null,null,null,null,null);
  17679. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),min,null,null,null,null,null,null,null,null);
  17680. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),min,null,null,null,null,null,null,null,null);
  17681. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  17682. pass=false;
  17683. }
  17684. }
  17685. //平均值判定
  17686. if (!SqlJoint.IsNullOrSpace(sod.getJudge_basis())&&sod.getJudge_basis().equalsIgnoreCase("C")&&"1".equals(sod.getIsjudge())) {
  17687. String min="";
  17688. if (!SqlJoint.IsNullOrSpace(sod.getAvg_val())) {
  17689. min=sod.getVal1();
  17690. }else {
  17691. min = compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), sod.getJudge_basis());
  17692. }
  17693. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),min,null,null,null,null,null,null,null,null);
  17694. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),min,null,null,null,null,null,null,null,null);
  17695. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),min,null,null,null,null,null,null,null,null);
  17696. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),min,null,null,null,null,null,null,null,null);
  17697. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),min,null,null,null,null,null,null,null,null);
  17698. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),min,null,null,null,null,null,null,null,null);
  17699. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),min,null,null,null,null,null,null,null,null);
  17700. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),min,null,null,null,null,null,null,null,null);
  17701. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  17702. pass=false;
  17703. }
  17704. }
  17705. //逐项值判定
  17706. if (SqlJoint.IsNullOrSpace(sod.getJudge_basis())||sod.getJudge_basis().equalsIgnoreCase("D")&&"1".equals(sod.getIsjudge())) {
  17707. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17708. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17709. bool2=getJudgeColor(sod.getKh_stdmin_sign(),sod.getKh_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17710. bool3=getJudgeColor(sod.getKh_stdmax_sign(),sod.getKh_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17711. bool4=getJudgeColor(sod.getNk_stdmin_sign(),sod.getNk_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17712. bool5=getJudgeColor(sod.getNk_stdmax_sign(),sod.getNk_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17713. bool6=getJudgeColor(sod.getFx_stdmin_sign(),sod.getFx_stdmin(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17714. bool7=getJudgeColor(sod.getFx_stdmax_sign(),sod.getFx_stdmax(),sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9());
  17715. if ("2".equals(bool0)||"2".equals(bool1)||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)||"2".equals(bool6)||"2".equals(bool7)) {
  17716. pass=false;
  17717. }
  17718. }
  17719. if((pass && !SqlJoint.IsNullOrSpace(sod.getAddcondition()) && sod.getAddcondition().equals("1")) || (!pass && !SqlJoint.IsNullOrSpace(sod.getAddcondition()) && sod.getAddcondition().equals("0"))){
  17720. pass = true;
  17721. int count = 0;
  17722. //允许一个值
  17723. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("A")&&"1".equals(sod.getIsjudge())) {
  17724. bool0=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17725. if(bool0.equals("2")){
  17726. count ++;
  17727. }
  17728. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17729. bool1=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17730. if(bool1.equals("2")){
  17731. count ++;
  17732. }
  17733. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17734. bool2=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17735. if(bool2.equals("2")){
  17736. count ++;
  17737. }
  17738. bool2=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17739. bool3=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17740. if(bool3.equals("2")){
  17741. count ++;
  17742. }
  17743. bool3=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17744. bool4=getJudgeColor(sod.getJf_stdmin_sign(),sod.getJf_stdmin(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17745. if(bool4.equals("2")){
  17746. count ++;
  17747. }
  17748. bool4=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17749. bool5=getJudgeColor(sod.getJf_stdmax_sign(),sod.getJf_stdmax(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17750. if(bool5.equals("2")){
  17751. count ++;
  17752. }
  17753. bool5=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17754. if(count > 1){
  17755. pass=false;
  17756. }
  17757. else{
  17758. if ("2".equals(bool0)||"2".equals(bool1) || "2".equals(bool2)||"2".equals(bool3) || "2".equals(bool4)||"2".equals(bool5) ){
  17759. pass=false;
  17760. }
  17761. }
  17762. }
  17763. //最大最小差值
  17764. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("B")&&"1".equals(sod.getIsjudge())) {
  17765. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), "D");
  17766. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  17767. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  17768. if ("2".equals(bool0)||"2".equals(bool1)) {
  17769. pass=false;
  17770. }
  17771. }
  17772. //平均值
  17773. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("C")&&"1".equals(sod.getIsjudge())) {
  17774. String min="";
  17775. if (!SqlJoint.IsNullOrSpace(sod.getAvg_val())) {
  17776. min=sod.getVal1();
  17777. }else {
  17778. min = compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), sod.getJudge_basis());
  17779. }
  17780. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  17781. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  17782. if ("2".equals(bool0)||"2".equals(bool1)) {
  17783. pass=false;
  17784. }
  17785. }
  17786. //最小值
  17787. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("D")&&"1".equals(sod.getIsjudge())) {
  17788. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(), sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(),"A");
  17789. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  17790. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  17791. if ("2".equals(bool0)||"2".equals(bool1)) {
  17792. pass=false;
  17793. }
  17794. }
  17795. //最大值
  17796. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("E")&&"1".equals(sod.getIsjudge())) {
  17797. String min =compareVal(sod.getVal1(),sod.getVal2(),sod.getVal3(),sod.getVal4(),sod.getVal5(),sod.getVal6(),sod.getVal7(),sod.getVal8(),sod.getVal9(), "B");
  17798. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),min,null,null,null,null,null,null,null,null);
  17799. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),min,null,null,null,null,null,null,null,null);
  17800. if ("2".equals(bool0)||"2".equals(bool1)) {
  17801. pass=false;
  17802. }
  17803. }
  17804. //所有值
  17805. if (!SqlJoint.IsNullOrSpace(sod.getAddstdcon_code())&&sod.getAddstdcon_code().equalsIgnoreCase("E")&&"1".equals(sod.getIsjudge())) {
  17806. bool0=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17807. bool1=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal1(),null,null,null,null,null,null,null,null);
  17808. bool2=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17809. bool3=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal2(),null,null,null,null,null,null,null,null);
  17810. bool4=getJudgeColor(sod.getAddstd_min_sign(),sod.getAddstd_min(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17811. bool5=getJudgeColor(sod.getAdd_std_max_sign(),sod.getAddstd_max(),sod.getVal3(),null,null,null,null,null,null,null,null);
  17812. if ("2".equals(bool0)||"2".equals(bool1) ||"2".equals(bool2)||"2".equals(bool3)||"2".equals(bool4)||"2".equals(bool5)) {
  17813. pass=false;
  17814. }
  17815. }
  17816. }
  17817. if(sod.getDefect_flag()!= null){
  17818. if(sod.getDefect_flag().equals("1")){
  17819. pass = false;
  17820. }
  17821. }
  17822. if(!pass){
  17823. judge = false;
  17824. }
  17825. }
  17826. }
  17827. if(!judge){
  17828. return "N";
  17829. }else{
  17830. return "Y";
  17831. }
  17832. }
  17833. public void SendGenerationSampleInfo(String batch_no,List<HashMap> hashmap,ArrayList param1,String type,String type2,String hj_name)throws Exception{
  17834. JSONObject jsobj1 = new JSONObject();
  17835. JSONObject jsobj2 = new JSONObject();
  17836. JSONArray ttmaps = new JSONArray();
  17837. String smp_no = "";
  17838. String psc = "";
  17839. if(hashmap.size() == 0){
  17840. throw new Exception("找不到库存!");
  17841. }
  17842. QcmJhySampleROrd qjsp = mapper.queryQcmJhySampleROrd(hashmap.get(0).get("DESIGN_KEY").toString());
  17843. List<QcmJudgePhysical> listz = mapper.queryQcmJudgePhysical("select * from qcm_judge_physical where phy_id = '"+param1.get(6).toString()+"'");
  17844. if(listz.size()>0){
  17845. smp_no = listz.get(0).getSmp_no();
  17846. psc = listz.get(0).getPsc();
  17847. }
  17848. else{
  17849. List<QcmJudgeChemical> lists = mapper.queryQcmJudgeChemical("select * from qcm_judge_chemical where cic_id = '"+param1.get(6).toString()+"'");
  17850. if(lists.size()>0){
  17851. smp_no = lists.get(0).getSmp_no();
  17852. psc = lists.get(0).getPsc();
  17853. }
  17854. }
  17855. /*int count=Integer.parseInt(hashmap.get(0).get("INSPECTION_LOT").toString().substring(hashmap.get(0).get("INSPECTION_LOT").toString().length()-4, hashmap.get(0).get("INSPECTION_LOT").toString().length()));
  17856. count++;
  17857. String INSPECTION_LOT=hashmap.get(0).get("INSPECTION_LOT").toString().substring(0,hashmap.get(0).get("INSPECTION_LOT").toString().length()-4)+String.format("%04d",count);*/
  17858. jsobj2.put("INSPECTION_LOT", hashmap.get(0).get("INSPECTION_LOT")==null?"":hashmap.get(0).get("INSPECTION_LOT").toString());
  17859. jsobj2.put("DESIGN_KEY", hashmap.get(0).get("DESIGN_KEY")==null?"":hashmap.get(0).get("DESIGN_KEY").toString());
  17860. jsobj2.put("PSC", psc);
  17861. jsobj2.put("HEAT_NO", hashmap.get(0).get("HEAT_NO")==null?"":hashmap.get(0).get("HEAT_NO").toString());
  17862. jsobj2.put("BATCH_NO", hashmap.get(0).get("BATCHNO")==null?"":hashmap.get(0).get("BATCHNO").toString());
  17863. jsobj2.put("BOARD_NO", hashmap.get(0).get("BOARD_NO")==null?"":hashmap.get(0).get("BOARD_NO").toString());
  17864. jsobj2.put("GRADE_CODE", hashmap.get(0).get("GRADE_CODE")==null?"":hashmap.get(0).get("GRADE_CODE").toString());
  17865. jsobj2.put("GRADE_NAME", hashmap.get(0).get("GRADE_NAME")==null?"":hashmap.get(0).get("GRADE_NAME").toString());
  17866. jsobj2.put("PLINE_ABBR", hashmap.get(0).get("PLINE_ABBR")==null?"":hashmap.get(0).get("PLINE_ABBR").toString());
  17867. jsobj2.put("MATERIAL_NO", hashmap.get(0).get("MATERIAL_NO")==null?"":hashmap.get(0).get("MATERIAL_NO").toString());
  17868. jsobj2.put("MSC_PLINE", "12345");
  17869. jsobj2.put("PLINE_CODE", hashmap.get(0).get("PLINE_CODE")==null?"":hashmap.get(0).get("PLINE_CODE").toString());
  17870. jsobj2.put("PLINE_NAME", hashmap.get(0).get("PLINE_NAME")==null?"":hashmap.get(0).get("PLINE_NAME").toString());
  17871. jsobj2.put("DELIVERY_STATE_CODE", hashmap.get(0).get("DELIVERY_STATE_CODE")==null?"":hashmap.get(0).get("DELIVERY_STATE_CODE").toString());
  17872. jsobj2.put("DELIVERY_STATE_DESC", hashmap.get(0).get("DELIVERY_STATE_DESC")==null?"":hashmap.get(0).get("DELIVERY_STATE_DESC").toString());
  17873. jsobj2.put("PROCESS_CODE", "");
  17874. jsobj2.put("THICK", hashmap.get(0).get("THICK")==null?"": hashmap.get(0).get("THICK").toString());
  17875. jsobj2.put("WIDTH", hashmap.get(0).get("WIDTH")==null?"":hashmap.get(0).get("WIDTH").toString());
  17876. jsobj2.put("LENGTH", hashmap.get(0).get("LENGTH")==null?"": hashmap.get(0).get("LENGTH").toString());
  17877. jsobj2.put("IS_QTLY", type.equals("2")?"1":(type2.equals("0")?"0":"1"));
  17878. jsobj2.put("IS_CHEM", type.equals("2")?"1":(type2.equals("0")?"1":"0"));
  17879. jsobj2.put("TYPE", type);
  17880. jsobj2.put("MEMO", param1.get(4).toString());
  17881. jsobj2.put("QLTY_SMP_NO", smp_no);
  17882. jsobj2.put("HJ_NAME", hj_name);
  17883. if(!batch_no.equals("")){
  17884. jsobj2.put("BATCH_NO", batch_no);
  17885. }
  17886. ttmaps.add(jsobj2);
  17887. jsobj1.put("KEY", ttmaps);
  17888. WebService1Impl web = new WebService1Impl();
  17889. //复样
  17890. try {
  17891. String result = web.sendDuplicateSample(jsobj1.toString());
  17892. if(!result.equals("1")){
  17893. throw new Exception(result);
  17894. }
  17895. } catch (Exception e) {
  17896. // TODO Auto-generated catch block
  17897. throw new Exception(e.getMessage());
  17898. }
  17899. }
  17900. public void SendGenerationSampleInfo2(String batch_no,List<HashMap> hashmap,ArrayList param1,String type,String type2,String smp_no,String hj_name)throws Exception{
  17901. JSONObject jsobj1 = new JSONObject();
  17902. JSONObject jsobj2 = new JSONObject();
  17903. JSONArray ttmaps = new JSONArray();
  17904. String psc = "";
  17905. if(hashmap.size() == 0){
  17906. throw new Exception("找不到库存!");
  17907. }
  17908. QcmJhySampleROrd qjsp = mapper.queryQcmJhySampleROrd(hashmap.get(0).get("DESIGN_KEY").toString());
  17909. List<QcmJudgePhysical> listz = mapper.queryQcmJudgePhysical("select * from qcm_judge_physical where phy_id = '"+param1.get(6).toString()+"'");
  17910. if(listz.size()>0){
  17911. psc = listz.get(0).getPsc();
  17912. }
  17913. else{
  17914. List<QcmJudgeChemical> lists = mapper.queryQcmJudgeChemical("select * from qcm_judge_chemical where cic_id = '"+param1.get(6).toString()+"'");
  17915. if(lists.size()>0){
  17916. psc = lists.get(0).getPsc();
  17917. }
  17918. }
  17919. /*int count=Integer.parseInt(hashmap.get(0).get("INSPECTION_LOT").toString().substring(hashmap.get(0).get("INSPECTION_LOT").toString().length()-4, hashmap.get(0).get("INSPECTION_LOT").toString().length()));
  17920. count++;
  17921. String INSPECTION_LOT=hashmap.get(0).get("INSPECTION_LOT").toString().substring(0,hashmap.get(0).get("INSPECTION_LOT").toString().length()-4)+String.format("%04d",count);*/
  17922. jsobj2.put("INSPECTION_LOT", hashmap.get(0).get("INSPECTION_LOT")==null?"":hashmap.get(0).get("INSPECTION_LOT").toString());
  17923. jsobj2.put("DESIGN_KEY", hashmap.get(0).get("DESIGN_KEY")==null?"":hashmap.get(0).get("DESIGN_KEY").toString());
  17924. jsobj2.put("PSC", psc);
  17925. jsobj2.put("HEAT_NO", hashmap.get(0).get("HEAT_NO")==null?"":hashmap.get(0).get("HEAT_NO").toString());
  17926. jsobj2.put("BATCH_NO", hashmap.get(0).get("BATCHNO")==null?"":hashmap.get(0).get("BATCHNO").toString());
  17927. jsobj2.put("BOARD_NO", hashmap.get(0).get("BOARD_NO")==null?"":hashmap.get(0).get("BOARD_NO").toString());
  17928. jsobj2.put("GRADE_CODE", hashmap.get(0).get("GRADE_CODE")==null?"":hashmap.get(0).get("GRADE_CODE").toString());
  17929. jsobj2.put("GRADE_NAME", hashmap.get(0).get("GRADE_NAME")==null?"":hashmap.get(0).get("GRADE_NAME").toString());
  17930. jsobj2.put("PLINE_ABBR", hashmap.get(0).get("PLINE_ABBR")==null?"":hashmap.get(0).get("PLINE_ABBR").toString());
  17931. jsobj2.put("MATERIAL_NO", hashmap.get(0).get("MATERIAL_NO")==null?"":hashmap.get(0).get("MATERIAL_NO").toString());
  17932. jsobj2.put("MSC_PLINE", "12345");
  17933. jsobj2.put("PLINE_CODE", hashmap.get(0).get("PLINE_CODE")==null?"":hashmap.get(0).get("PLINE_CODE").toString());
  17934. jsobj2.put("PLINE_NAME", hashmap.get(0).get("PLINE_NAME")==null?"":hashmap.get(0).get("PLINE_NAME").toString());
  17935. jsobj2.put("DELIVERY_STATE_CODE", hashmap.get(0).get("DELIVERY_STATE_CODE")==null?"":hashmap.get(0).get("DELIVERY_STATE_CODE").toString());
  17936. jsobj2.put("DELIVERY_STATE_DESC", hashmap.get(0).get("DELIVERY_STATE_DESC")==null?"":hashmap.get(0).get("DELIVERY_STATE_DESC").toString());
  17937. jsobj2.put("PROCESS_CODE", "");
  17938. jsobj2.put("THICK", hashmap.get(0).get("THICK")==null?"": hashmap.get(0).get("THICK").toString());
  17939. jsobj2.put("WIDTH", hashmap.get(0).get("WIDTH")==null?"":hashmap.get(0).get("WIDTH").toString());
  17940. jsobj2.put("LENGTH", hashmap.get(0).get("LENGTH")==null?"": hashmap.get(0).get("LENGTH").toString());
  17941. jsobj2.put("IS_QTLY", type.equals("2")?"1":(type2.equals("0")?"0":"1"));
  17942. jsobj2.put("IS_CHEM", type.equals("2")?"1":(type2.equals("0")?"1":"0"));
  17943. jsobj2.put("TYPE", type);
  17944. jsobj2.put("MEMO", param1.get(4).toString());
  17945. jsobj2.put("QLTY_SMP_NO", smp_no);
  17946. jsobj2.put("HJ_NAME", hj_name);
  17947. if(!batch_no.equals("")){
  17948. jsobj2.put("BATCH_NO", batch_no);
  17949. }
  17950. ttmaps.add(jsobj2);
  17951. jsobj1.put("KEY", ttmaps);
  17952. WebService1Impl web = new WebService1Impl();
  17953. //复样
  17954. try {
  17955. String result = web.sendDuplicateSample(jsobj1.toString());
  17956. if(!result.equals("1")){
  17957. throw new Exception(result);
  17958. }
  17959. } catch (Exception e) {
  17960. // TODO Auto-generated catch block
  17961. throw new Exception(e.getMessage());
  17962. }
  17963. }
  17964. public String SendGenerationSampleInfo1(List<HashMap> hashmap,ArrayList param1,String type,String type2)throws Exception{
  17965. JSONObject jsobj1 = new JSONObject();
  17966. JSONObject jsobj2 = new JSONObject();
  17967. JSONArray ttmaps = new JSONArray();
  17968. if(hashmap.size() == 0){
  17969. throw new Exception("找不到库存!");
  17970. }
  17971. String smp_no = "";
  17972. String psc = "";
  17973. QcmJhySampleROrd qjsp = mapper.queryQcmJhySampleROrd(hashmap.get(0).get("DESIGN_KEY").toString());
  17974. String jyh=hashmap.get(0).get("INSPECTION_LOT").toString().substring(0,hashmap.get(0).get("INSPECTION_LOT").toString().length()-4);
  17975. String sql = "select max(billetid_jy) INSPECTION_LOT from (select billetid_jy from zj_result_all@xgcx where billetid like '"+jyh+"%' "
  17976. + " union all select INSPECTION_LOT from qcm_judge_coil_result where INSPECTION_LOT like '"+jyh+"%')";
  17977. List<HashMap> t = mapper.query(sql);
  17978. String s = t.get(0).get("INSPECTION_LOT") == null?"": t.get(0).get("INSPECTION_LOT").toString();
  17979. int count=Integer.parseInt(s.substring(s.length()-4, s.length()));
  17980. count++;
  17981. String INSPECTION_LOT=s.substring(0,s.length()-4)+String.format("%04d",count);
  17982. jsobj2.put("INSPECTION_LOT", INSPECTION_LOT);
  17983. jsobj2.put("DESIGN_KEY", param1.get(7).toString());
  17984. jsobj2.put("PSC", qjsp.getPsc());
  17985. jsobj2.put("HEAT_NO", hashmap.get(0).get("HEAT_NO")==null?"":hashmap.get(0).get("HEAT_NO").toString());
  17986. jsobj2.put("BATCH_NO", hashmap.get(0).get("BATCHNO")==null?"":hashmap.get(0).get("BATCHNO").toString());
  17987. jsobj2.put("BOARD_NO", hashmap.get(0).get("BOARD_NO")==null?"":hashmap.get(0).get("BOARD_NO").toString());
  17988. jsobj2.put("GRADE_CODE", hashmap.get(0).get("GRADE_CODE")==null?"":hashmap.get(0).get("GRADE_CODE").toString());
  17989. jsobj2.put("GRADE_NAME", hashmap.get(0).get("GRADE_NAME")==null?"":hashmap.get(0).get("GRADE_NAME").toString());
  17990. jsobj2.put("PLINE_ABBR", hashmap.get(0).get("PLINE_ABBR")==null?"":hashmap.get(0).get("PLINE_ABBR").toString());
  17991. jsobj2.put("MATERIAL_NO", hashmap.get(0).get("MATERIAL_NO")==null?"":hashmap.get(0).get("MATERIAL_NO").toString());
  17992. jsobj2.put("MSC_PLINE", qjsp.getMsc_pline()==null?"12345":qjsp.getMsc_pline());
  17993. jsobj2.put("PLINE_CODE", hashmap.get(0).get("PLINE_CODE")==null?"":hashmap.get(0).get("PLINE_CODE").toString());
  17994. jsobj2.put("PLINE_NAME", hashmap.get(0).get("PLINE_NAME")==null?"":hashmap.get(0).get("PLINE_NAME").toString());
  17995. jsobj2.put("DELIVERY_STATE_CODE", hashmap.get(0).get("DELIVERY_STATE_CODE")==null?"":hashmap.get(0).get("DELIVERY_STATE_CODE").toString());
  17996. jsobj2.put("DELIVERY_STATE_DESC", hashmap.get(0).get("DELIVERY_STATE_DESC")==null?"":hashmap.get(0).get("DELIVERY_STATE_DESC").toString());
  17997. jsobj2.put("PROCESS_CODE", "");
  17998. jsobj2.put("THICK", hashmap.get(0).get("THICK")==null?"": hashmap.get(0).get("THICK").toString());
  17999. jsobj2.put("WIDTH", hashmap.get(0).get("WIDTH")==null?"":hashmap.get(0).get("WIDTH").toString());
  18000. jsobj2.put("LENGTH", hashmap.get(0).get("LENGTH")==null?"": hashmap.get(0).get("LENGTH").toString());
  18001. jsobj2.put("IS_QTLY", type.equals("2")?"1":(type2.equals("0")?"0":"1"));
  18002. jsobj2.put("IS_CHEM", type.equals("2")?"1":(type2.equals("0")?"1":"0"));
  18003. jsobj2.put("TYPE", type);
  18004. jsobj2.put("MEMO", param1.get(4).toString());
  18005. jsobj2.put("QLTY_SMP_NO", "");
  18006. ttmaps.add(jsobj2);
  18007. jsobj1.put("KEY", ttmaps);
  18008. WebService1Impl web = new WebService1Impl();
  18009. //委托
  18010. try {
  18011. String result = web.autoGenerationSampleInfo(jsobj1.toString());
  18012. if(!result.equals("1")){
  18013. throw new Exception(result);
  18014. }
  18015. } catch (Exception e) {
  18016. // TODO Auto-generated catch block
  18017. throw new Exception(e.getMessage());
  18018. }
  18019. return INSPECTION_LOT;
  18020. }
  18021. /**
  18022. * 材质判定
  18023. */
  18024. public void PhyUtmJudge(String design_key,String inspection_lot,String username)throws Exception{
  18025. try
  18026. {
  18027. //判断试样号是否都已经判定完
  18028. List<QcmJhySampleROrd> listor = mapper.findInfo1("B",inspection_lot);
  18029. String pic_id="";
  18030. List<String> lstr=new ArrayList<String>();
  18031. for (QcmJhySampleROrd l : listor) {
  18032. if (!SqlJoint.IsNullOrSpace(l.getJudge_result_desc())) {
  18033. lstr.add(l.getJudge_result_desc());
  18034. }
  18035. /*else if ("0".equals(l.getJudge_result_desc()) || "2".equals(l.getJudge_result_desc())) {
  18036. lstr.add("待判");
  18037. }*/
  18038. else {
  18039. lstr.add("null");
  18040. }
  18041. }
  18042. QcmJudgePhysicalUtmM qpu=new QcmJudgePhysicalUtmM();
  18043. QcmJudgePhysicalUtmD qpd=new QcmJudgePhysicalUtmD();
  18044. if (!lstr.contains("待判")) {
  18045. if (!lstr.contains("null")) {
  18046. if (lstr.contains("不合格")) {
  18047. qpu.setPic_result_desc("不合格");
  18048. qpu.setPic_result_code("2");
  18049. }else if(lstr.contains("判次")){
  18050. qpu.setPic_result_desc("判次");
  18051. qpu.setPic_result_code("3");
  18052. }else if(lstr.contains("判废")){
  18053. qpu.setPic_result_desc("判废");
  18054. qpu.setPic_result_code("4");
  18055. }else{
  18056. qpu.setPic_result_desc("合格");
  18057. qpu.setPic_result_code("1");
  18058. }
  18059. //把对应的数据加入qcm_judge_Physical_Utm_M表中
  18060. int a=0;
  18061. for (QcmJhySampleROrd q : listor) {
  18062. //获取当日最大编号
  18063. if (a==0) {
  18064. int count=0;
  18065. SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
  18066. String date=sdf.format(new Date());
  18067. // 获取材质结果集编号最大值
  18068. List<QcmJudgePhysicalUtmM> qrlist=mapper.queryQcmJudgePhysicalUtmM("select * from QCM_JUDGE_PHYSICAL_UTM_M where PIC_ID like 'PIC%"+date+"%' order by PIC_ID DESC");
  18069. if(qrlist!=null&&qrlist.size()>0){
  18070. String s=qrlist.get(0).getPic_id();
  18071. count=Integer.parseInt(s.substring(s.length()-4, s.length()));
  18072. }
  18073. count++;
  18074. pic_id="PIC"+sdf.format(new Date())+String.format("%04d",count);
  18075. qpu.setPic_id(pic_id);
  18076. qpu.setInspection_lot(q.getInspection_lot());
  18077. qpu.setDesign_key(q.getDesign_key());
  18078. mapper.insertQcmJudgePhysicalUtmM(qpu);
  18079. a++;
  18080. }
  18081. qpd.setPic_id(pic_id);
  18082. qpd.setSmp_no(q.getSmp_no());
  18083. qpd.setHeat_no(q.getHeat_no());
  18084. qpd.setBatch_no(q.getBatch_no());
  18085. qpd.setInspection_lot(q.getInspection_lot());
  18086. qpd.setDesign_key(q.getDesign_key());
  18087. qpd.setPsc(q.getPsc());
  18088. qpd.setCert_inst_code(q.getCert_inst_code());
  18089. qpd.setCert_inst_name(q.getCert_inst_name());
  18090. qpd.setSmp_type_code(q.getSmp_type_code());
  18091. qpd.setSmp_type_name(q.getSmp_type_name());
  18092. qpd.setJudge_result_code(q.getJudge_result_code());
  18093. qpd.setJudge_result_desc(q.getJudge_result_desc());
  18094. qpd.setPhy_id(q.getPhy_id());
  18095. qpd.setJudge_ttime(new Date());
  18096. qpd.setJudge_name("system");
  18097. qpd.setPsc_desc(q.getPsc_desc());
  18098. qpd.setProd_code(q.getProd_code());
  18099. qpd.setProd_name(q.getProd_name());
  18100. qpd.setSteel_code(q.getSteel_code());
  18101. qpd.setSteel_name(q.getSteel_name());
  18102. qpd.setStd_code(q.getStd_code());
  18103. qpd.setStd_name(q.getStd_name());
  18104. //pme.setPhysresult_id(pic_id);
  18105. mapper.insertQcmJudgePhysicalUtmD(qpd);
  18106. String sql = "select * from zj_result_all@xgcx where BILLETID_JY = '"+inspection_lot+"'";
  18107. List<HashMap> list1 = mapper.query(sql);
  18108. sql = "select * from QCM_JUDGE_COIL_RESULT where INSPECTION_LOT = '"+inspection_lot+"'";
  18109. List<HashMap> list2 = mapper.query(sql);
  18110. if(list1.size() >0 || list2.size() >0){
  18111. if(list1.size()>0){
  18112. // 更新库存表材质判定结果
  18113. ZjResultAll zra = new ZjResultAll();
  18114. zra.setBilletid_jy(inspection_lot);
  18115. zra.setPic_is_lock(qpu.getPic_result_code().equals("2")?"1":"0");
  18116. zra.setPhysid(pic_id);
  18117. zra.setPhysresult(qpu.getPic_result_code());
  18118. zra.setPhysresult_desc(qpu.getPic_result_desc());
  18119. mapper.UpdateJugeResultB(zra);
  18120. }else{
  18121. // 更新库存表材质判定结果
  18122. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  18123. zra.setInspection_lot(inspection_lot);
  18124. zra.setPic_is_lock(qpu.getPic_result_code().equals("2")?"1":"0");
  18125. zra.setPhysid(pic_id);
  18126. zra.setPhysresult(qpu.getPic_result_code());
  18127. zra.setPhysresult_desc(qpu.getPic_result_desc());
  18128. mapper.UpdateJugeResultJ(zra);
  18129. }
  18130. }else{
  18131. continue;
  18132. }
  18133. }
  18134. }
  18135. }
  18136. }catch(Exception e){
  18137. throw new Exception(e.getMessage());
  18138. }
  18139. }
  18140. private void order_down(String billet_id,String reason) throws java.lang.Exception
  18141. {
  18142. Connection conn = null;
  18143. CallableStatement cstmt = null;
  18144. ResultSet rs = null;
  18145. try {
  18146. conn = SqlSession.getConnection();
  18147. String callSql = "{call GETJHTOMESPLAN.ORDER_DOWN@xgcx(?,?) }";
  18148. cstmt = conn.prepareCall(callSql);
  18149. cstmt.setString(1, billet_id);
  18150. cstmt.setString(2, reason);
  18151. cstmt.execute();
  18152. } catch (Exception e) {
  18153. throw new Exception(e.getMessage());
  18154. } finally {
  18155. try {
  18156. if (rs != null) {
  18157. rs.close();
  18158. }
  18159. } catch (Exception e) {
  18160. throw new Exception(e.getMessage());
  18161. }
  18162. try {
  18163. if (cstmt != null) {
  18164. cstmt.close();
  18165. }
  18166. } catch (Exception e) {
  18167. throw new Exception(e.getMessage());
  18168. }
  18169. }
  18170. }
  18171. private void Td(String material_no,String prod_line)throws java.lang.Exception{
  18172. Connection conn = null;
  18173. CallableStatement cstmt = null;
  18174. ResultSet rs = null;
  18175. try {
  18176. conn = SqlSession.getConnection();
  18177. String callSql = "{call C_JH_ORD_REP.YTH_COIL_STAT(?,?,?,?,?,?,?,?,?,?) }";
  18178. cstmt = conn.prepareCall(callSql);
  18179. cstmt.setString(1, "");
  18180. cstmt.setString(2, "");
  18181. cstmt.setString(3, "");
  18182. cstmt.setString(4, "");
  18183. cstmt.setString(5, material_no);
  18184. cstmt.setString(6, prod_line);
  18185. cstmt.setString(7, "JJ");
  18186. cstmt.setString(8, "A");
  18187. cstmt.setString(9, "1");
  18188. cstmt.registerOutParameter(10, java.sql.Types.VARCHAR);
  18189. cstmt.execute();
  18190. } catch (Exception e) {
  18191. throw new Exception(e.getMessage());
  18192. } finally {
  18193. try {
  18194. if (rs != null) {
  18195. rs.close();
  18196. }
  18197. } catch (Exception e) {
  18198. throw new Exception(e.getMessage());
  18199. }
  18200. try {
  18201. if (cstmt != null) {
  18202. cstmt.close();
  18203. }
  18204. } catch (Exception e) {
  18205. throw new Exception(e.getMessage());
  18206. }
  18207. }
  18208. }
  18209. private void updateorderno(String VORDERNO,String VDETERMINANTCARDNUMBER,String VUPDATEMAN,String VBILLETID) throws java.lang.Exception
  18210. {
  18211. Connection conn = null;
  18212. CallableStatement cstmt = null;
  18213. ResultSet rs = null;
  18214. try {
  18215. conn = SqlSession.getConnection();
  18216. String callSql = "{call GETJHTOMESPLAN.ORDERUPDATE_TOZJ@xgcx(?,?,?,?,?) }";
  18217. cstmt = conn.prepareCall(callSql);
  18218. cstmt.setString(1, VORDERNO);
  18219. cstmt.setString(2, "");
  18220. cstmt.setString(3, VDETERMINANTCARDNUMBER);
  18221. cstmt.setString(4, VUPDATEMAN);
  18222. cstmt.setString(5, VBILLETID);
  18223. cstmt.execute();
  18224. } catch (Exception e) {
  18225. throw new Exception(e.getMessage());
  18226. } finally {
  18227. try {
  18228. if (rs != null) {
  18229. rs.close();
  18230. }
  18231. } catch (Exception e) {
  18232. throw new Exception(e.getMessage());
  18233. }
  18234. try {
  18235. if (cstmt != null) {
  18236. cstmt.close();
  18237. }
  18238. } catch (Exception e) {
  18239. throw new Exception(e.getMessage());
  18240. }
  18241. }
  18242. }
  18243. private void judge_call(String aPlanStand,String aPlanPurpose,String aStand, String aPurpose, String aHIC,String aCollResult,String aJudgeReason, String aJudgeMemo , String aXJudgeMemo, String aMuliSteelInfo , String aSlabNos, String aOperator, String aProductName, String aRclStae,String sBH, String aApplyOrderno,String steelname) throws java.lang.Exception
  18244. {
  18245. Connection conn = null;
  18246. CallableStatement cstmt = null;
  18247. ResultSet rs = null;
  18248. try {
  18249. conn = SqlSession.getConnection();
  18250. String callSql = "{call GETJHTOMESPLAN.JudgeRec_Add@xgcx(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) }";
  18251. cstmt = conn.prepareCall(callSql);
  18252. cstmt.setString(1, aPlanStand);
  18253. cstmt.setString(2, aPlanPurpose);
  18254. cstmt.setString(3, aStand);
  18255. cstmt.setString(4, aPurpose);
  18256. cstmt.setString(5, aHIC);
  18257. cstmt.setString(6, aCollResult);
  18258. cstmt.setString(7, aJudgeReason);
  18259. cstmt.setString(8, aJudgeMemo);
  18260. cstmt.setString(9, aXJudgeMemo);
  18261. cstmt.setString(10, aMuliSteelInfo);
  18262. cstmt.setString(11, aSlabNos);
  18263. cstmt.setString(12, aOperator);
  18264. cstmt.setString(13, aProductName);
  18265. cstmt.setString(14, aRclStae);
  18266. cstmt.setString(15, sBH);
  18267. cstmt.setString(16, aApplyOrderno);
  18268. cstmt.setString(17, steelname);
  18269. cstmt.registerOutParameter(18, java.sql.Types.INTEGER);
  18270. cstmt.execute();
  18271. if(cstmt.getString(18) != null){
  18272. if(cstmt.getString(18).equals("0")){
  18273. throw new java.lang.Exception("更新判定结果失败!");
  18274. }
  18275. }
  18276. } catch (Exception e) {
  18277. throw new Exception(e.getMessage());
  18278. } finally {
  18279. try {
  18280. if (rs != null) {
  18281. rs.close();
  18282. }
  18283. } catch (Exception e) {
  18284. throw new Exception(e.getMessage());
  18285. }
  18286. try {
  18287. if (cstmt != null) {
  18288. cstmt.close();
  18289. }
  18290. } catch (Exception e) {
  18291. throw new Exception(e.getMessage());
  18292. }
  18293. }
  18294. }
  18295. /***
  18296. * 判次、判废综合判定:
  18297. * @param sum
  18298. * @return
  18299. */
  18300. @SuppressWarnings({ "rawtypes", "unused" })
  18301. public CoreReturnObject ultimateJudgeAuto(String material_no, String username,String type) throws Exception{
  18302. try{
  18303. int count = 0;
  18304. QcmJudgeMeasureServiceImpl qjms = new QcmJudgeMeasureServiceImpl();
  18305. List<HashMap> hashmap = qjms.doQueryMaterialInfoBX(material_no);
  18306. if(hashmap.size() == 0){
  18307. hashmap = qjms.doQueryMaterialInfoJ(material_no);
  18308. }
  18309. if(hashmap.size()==0){
  18310. hashmap = mapper.doQueryMaterialInfoY(material_no);
  18311. }
  18312. String sql = "select * from zj_result_all@xgcx where BILLETID = '"+material_no+"'";
  18313. int flag = 0;
  18314. List<HashMap> list1 = mapper.query(sql);
  18315. sql = "select * from QCM_JUDGE_COIL_RESULT where coil_no = '"+material_no+"'";
  18316. List<HashMap> list2 = mapper.query(sql);
  18317. sql = "select * from QCM_JUDGE_YT_COIL_RESULT where coil_no = '"+material_no+"'";
  18318. List<HashMap> list3 = mapper.query(sql);
  18319. if(list1.size() >0 || list2.size() >0 || list3.size() >0){
  18320. if(list1.size()>0){
  18321. for(HashMap list:list1){
  18322. QcmJudgeUltimate qju=new QcmJudgeUltimate();
  18323. //获取判定记录号当天的最大值
  18324. Date now = new Date();
  18325. String opr_time = new SimpleDateFormat("yyyyMMddHHmmss").format(now); //操作时间
  18326. SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
  18327. String date=sdf.format(now);
  18328. count=0;
  18329. String type1 = "";
  18330. if(material_no.startsWith("Z")||material_no.startsWith("H")){
  18331. type1 = "ZB";
  18332. }else{
  18333. type1 = "ZX";
  18334. }
  18335. sql ="select * from (select * from qcm_judge_ultimate where UTM_ID like '"+type1+date+"%' order by UTM_ID desc) where rownum <= 1";
  18336. List<QcmJudgeUltimate> listUl=mapper.QcmJudgeUltimate(sql);
  18337. if (listUl!=null&&listUl.size()>0) {
  18338. String s=listUl.get(0).getUtm_id();
  18339. count=Integer.parseInt(s.substring(s.length()-4,s.length()));
  18340. }
  18341. count++;
  18342. String utm_id=type1+sdf.format(now)+String.format("%04d",count);
  18343. qju.setUtm_id(utm_id);
  18344. //更新库存表综合判定结果
  18345. ZjResultAll zra = new ZjResultAll();
  18346. zra.setBilletid(material_no);
  18347. zra.setJudgeid(utm_id);
  18348. if(type.equals("3")){
  18349. zra.setJudgeresult("3");
  18350. zra.setJudgeresult_desc("次品");
  18351. }
  18352. else if(type.equals("4")){
  18353. zra.setJudgeresult("4");
  18354. zra.setJudgeresult_desc("废品");
  18355. }else if(type.equals("0")){
  18356. zra.setJudgeresult("0");
  18357. zra.setJudgeresult_desc("待判");
  18358. }
  18359. if(zra.getJudgeresult().equals("2")){
  18360. throw new Exception("综合判定不合格!");
  18361. }
  18362. mapper.UpdateJugeResultB(zra);
  18363. //插入综合判定记录表
  18364. qju.setDesign_key(hashmap.get(0).get("DESIGN_KEY") == null ?"":hashmap.get(0).get("DESIGN_KEY").toString());
  18365. qju.setHeat_no(hashmap.get(0).get("HEAT_NO")==null?"":hashmap.get(0).get("HEAT_NO").toString());
  18366. qju.setBatch_no(hashmap.get(0).get("BATCHNO")==null?"":hashmap.get(0).get("BATCHNO").toString());
  18367. qju.setBoard_no(hashmap.get(0).get("BOARD_NO")==null?"":hashmap.get(0).get("BOARD_NO").toString());
  18368. qju.setInspection_lot(hashmap.get(0).get("INSPECTION_LOT")==null?"":hashmap.get(0).get("INSPECTION_LOT").toString());
  18369. qju.setMaterial_no(material_no);
  18370. qju.setUtm_id(utm_id);
  18371. qju.setUtm_memo("");
  18372. qju.setUtm_result_code(zra.getJudgeresult());
  18373. qju.setUtm_result_desc(zra.getJudgeresult_desc());
  18374. qju.setCic_id(list1.get(0).get("CHEMID") == null?"":list1.get(0).get("CHEMID").toString());
  18375. qju.setCic_result_code(list1.get(0).get("CHEMRESULT")==null?"":list1.get(0).get("CHEMRESULT").toString());
  18376. qju.setCic_result_desc(list1.get(0).get("CHEMRESULT_DESC")==null?"":list1.get(0).get("CHEMRESULT_DESC").toString());
  18377. qju.setR_cic_id(list1.get(0).get("R_CHEMID") == null?"":list1.get(0).get("R_CHEMID").toString());
  18378. qju.setR_cic_result_code(list1.get(0).get("R_CHEMRESULT")==null?"":list1.get(0).get("R_CHEMRESULT").toString());
  18379. qju.setR_cic_result_desc(list1.get(0).get("R_CHEMRESULT_DESC")==null?"":list1.get(0).get("R_CHEMRESULT_DESC").toString());
  18380. qju.setPic_id(list1.get(0).get("PHYSID") == null?"":list1.get(0).get("PHYSID").toString());
  18381. qju.setPic_result_code(list1.get(0).get("PHYSRESULT")==null?"":list1.get(0).get("PHYSRESULT").toString());
  18382. qju.setPic_result_desc(list1.get(0).get("PHYSRESULT_DESC")==null?"":list1.get(0).get("PHYSRESULT_DESC").toString());
  18383. qju.setSic_id(list1.get(0).get("SIZEID") == null?"":list1.get(0).get("SIZEID").toString());
  18384. qju.setSic_result_code(list1.get(0).get("SIZERESULT")==null?"":list1.get(0).get("SIZERESULT").toString());
  18385. qju.setSic_result_desc(list1.get(0).get("SIZERESULT_DESC")==null?"":list1.get(0).get("SIZERESULT_DESC").toString());
  18386. qju.setDic_id(list1.get(0).get("SPYID")==null?"":list1.get(0).get("SPYID").toString());
  18387. qju.setDic_result_code(list1.get(0).get("SPYRESULT")==null?"":list1.get(0).get("SPYRESULT").toString());
  18388. qju.setDic_result_desc(list1.get(0).get("SPYRESULT_DESC")==null?"":list1.get(0).get("SPYRESULT_DESC").toString());
  18389. qju.setSfd_id(list1.get(0).get("SURFACEID")==null?"":list1.get(0).get("SURFACEID").toString());
  18390. qju.setSfd_result_code(list1.get(0).get("UD_SURFACE_RESULT")==null?"":list1.get(0).get("UD_SURFACE_RESULT").toString());
  18391. qju.setSfd_result_desc(list1.get(0).get("UD_SURFACE_RESULT_DESC")==null?"":list1.get(0).get("UD_SURFACE_RESULT_DESC").toString());
  18392. qju.setSfu_id(list1.get(0).get("SURFACEID")==null?"":list1.get(0).get("SURFACEID").toString());
  18393. qju.setSfu_result_code(list1.get(0).get("UP_SURFACE_RESULT")==null?"":list1.get(0).get("UP_SURFACE_RESULT").toString());
  18394. qju.setSfu_result_desc(list1.get(0).get("UP_SURFACE_RESULT_DESC")==null?"":list1.get(0).get("UP_SURFACE_RESULT_DESC").toString());
  18395. qju.setSfe_id(list1.get(0).get("SURFACEID")==null?"":list1.get(0).get("SURFACEID").toString());
  18396. qju.setSfe_result_code(list1.get(0).get("MARGINAL_RESULT")==null?"":list1.get(0).get("MARGINAL_RESULT").toString());
  18397. qju.setSfe_result_desc(list1.get(0).get("MARGINAL_RESULT_DESC")==null?"":list1.get(0).get("MARGINAL_RESULT_DESC").toString());
  18398. qju.setMst_id(list1.get(0).get("SURFACEID")==null?"":list1.get(0).get("SURFACEID").toString());
  18399. qju.setMst_result_code(list1.get(0).get("SURFACERESULT")==null?"":list1.get(0).get("SURFACERESULT").toString());
  18400. qju.setMst_result_desc(list1.get(0).get("SURFACERESULT_DESC")==null?"":list1.get(0).get("SURFACERESULT_DESC").toString());
  18401. qju.setFst_id(list1.get(0).get("PHYFSTSID")==null?"":list1.get(0).get("PHYFSTSID").toString());
  18402. qju.setFst_result_code(list1.get(0).get("PHYFSTSRESULT")==null?"":list1.get(0).get("PHYFSTSRESULT").toString());
  18403. qju.setFst_result_desc(list1.get(0).get("PHYFSTSRESULT_DESC")==null?"":list1.get(0).get("PHYFSTSRESULT_DESC").toString());
  18404. qju.setPsc(hashmap.get(0).get("PSC")==null?"":hashmap.get(0).get("PSC").toString());
  18405. qju.setPsc_desc(hashmap.get(0).get("PSC_DESC")==null?"":hashmap.get(0).get("PSC_DESC").toString());
  18406. qju.setProd_code(hashmap.get(0).get("PROD_CODE")==null?"":hashmap.get(0).get("PROD_CODE").toString());
  18407. qju.setProd_name(hashmap.get(0).get("PROD_NAME")==null?"":hashmap.get(0).get("PROD_NAME").toString());
  18408. qju.setSteel_code(hashmap.get(0).get("STEEL_CODE")==null?"":hashmap.get(0).get("STEEL_CODE").toString());
  18409. qju.setSteel_name(hashmap.get(0).get("STEEL_NAME").toString());
  18410. qju.setStd_code(hashmap.get(0).get("STD_CODE")==null?"":hashmap.get(0).get("STD_CODE").toString());
  18411. qju.setStd_name(hashmap.get(0).get("STD_NAME")==null?"":hashmap.get(0).get("STD_NAME").toString());
  18412. qju.setJudge_name(username);
  18413. qju.setJudge_time(new Date());
  18414. qju.setPline_code(hashmap.get(0).get("PLINE_CODE")==null?"":hashmap.get(0).get("PLINE_CODE").toString());
  18415. qju.setPline_name(hashmap.get(0).get("PLINE_NAME")==null?"":hashmap.get(0).get("PLINE_NAME").toString());
  18416. mapper.insertQcmJudgeUltimate(qju);
  18417. String judgeresult = "";
  18418. if(zra.getJudgeresult().equals("1")){
  18419. judgeresult = "40140101";
  18420. }else if(zra.getJudgeresult().equals("3")){
  18421. if(zra.getSurfaceresult() != null && zra.getSurfaceresult().equals("3")){
  18422. judgeresult = "40140301";
  18423. }else{
  18424. judgeresult = "40140302";
  18425. }
  18426. }else if(zra.getJudgeresult().equals("4")){
  18427. judgeresult = "40140303";
  18428. }else if(zra.getJudgeresult().equals("0")){
  18429. judgeresult = "40140401";
  18430. }
  18431. String cj_result = "";
  18432. String steelname = hashmap.get(0).get("STEEL_NAME")==null?"":hashmap.get(0).get("STEEL_NAME").toString();
  18433. String phyid = list1.get(0).get("PHYSID")==null?"":list1.get(0).get("PHYSID").toString();
  18434. sql= "select max(t.steel_name) steel_name from qcm_judge_physical t where t.phy_id in (select phy_id from qcm_judge_physical_utm_d d where d.pic_id = '"+phyid+"')";
  18435. List<HashMap> liststeel = mapper.query(sql);
  18436. if(liststeel != null && liststeel.size() >0 && !phyid.equals("")){
  18437. steelname = liststeel.get(0).get("STEEL_NAME").toString();
  18438. }
  18439. judge_call(hashmap.get(0).get("STD_CODE")==null?"":hashmap.get(0).get("STD_CODE").toString(),hashmap.get(0).get("PROD_CODE")==null?"":hashmap.get(0).get("PROD_CODE").toString(),hashmap.get(0).get("STD_CODE")==null?"":hashmap.get(0).get("STD_CODE").toString(),hashmap.get(0).get("PROD_CODE")==null?"":hashmap.get(0).get("PROD_CODE").toString(),hashmap.get(0).get("PSC")==null?"":hashmap.get(0).get("PSC").toString(),judgeresult,"","","",cj_result,material_no,username,hashmap.get(0).get("PROD_CODE")==null?"":hashmap.get(0).get("PROD_CODE").toString(),hashmap.get(0).get("HT_NO")==null?"":hashmap.get(0).get("HT_NO").toString(),utm_id,hashmap.get(0).get("DESIGN_KEY")==null?"":hashmap.get(0).get("DESIGN_KEY").toString(),steelname);
  18440. }
  18441. }else if (list2.size() >0){
  18442. for(HashMap list:list2){
  18443. QcmJudgeUltimate qju=new QcmJudgeUltimate();
  18444. //获取判定记录号当天的最大值
  18445. Date now = new Date();
  18446. String opr_time = new SimpleDateFormat("yyyyMMddHHmmss").format(now); //操作时间
  18447. SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
  18448. String date=sdf.format(now);
  18449. count=0;
  18450. sql ="select * from qcm_judge_ultimate where UTM_ID like 'ZJ"+date+"%' order by UTM_ID desc";
  18451. List<QcmJudgeUltimate> listUl=mapper.QcmJudgeUltimate(sql);
  18452. if (listUl!=null&&listUl.size()>0) {
  18453. String s=listUl.get(0).getUtm_id();
  18454. count=Integer.parseInt(s.substring(s.length()-4,s.length()));
  18455. }
  18456. count++;
  18457. String utm_id="ZJ"+sdf.format(now)+String.format("%04d",count);
  18458. //更新库存表综合判定结果
  18459. QcmJudgeCoilResult zra = new QcmJudgeCoilResult();
  18460. zra.setCoil_no(material_no);
  18461. zra.setJudgeid(utm_id);
  18462. if(type.equals("3")){
  18463. zra.setJudgeresult("3");
  18464. zra.setJudgeresult_desc("次品");
  18465. }
  18466. else if(type.equals("4")){
  18467. zra.setJudgeresult("4");
  18468. zra.setJudgeresult_desc("废品");
  18469. }
  18470. if(zra.getJudgeresult().equals("2")){
  18471. throw new Exception("综合判定不合格!");
  18472. }
  18473. mapper.UpdateJugeResultJ(zra);
  18474. //插入综合判定记录表
  18475. qju.setDesign_key(hashmap.get(0).get("DESIGN_KEY") == null ?"":hashmap.get(0).get("DESIGN_KEY").toString());
  18476. qju.setHeat_no(hashmap.get(0).get("HEAT_NO")==null?"":hashmap.get(0).get("HEAT_NO").toString());
  18477. qju.setBatch_no(hashmap.get(0).get("BATCHNO")==null?"":hashmap.get(0).get("BATCHNO").toString());
  18478. qju.setBoard_no(hashmap.get(0).get("BOARD_NO")==null?"":hashmap.get(0).get("BOARD_NO").toString());
  18479. qju.setInspection_lot(hashmap.get(0).get("INSPECTION_LOT")==null ?"":hashmap.get(0).get("INSPECTION_LOT").toString());
  18480. qju.setMaterial_no(material_no);
  18481. qju.setUtm_id(utm_id);
  18482. qju.setUtm_memo("");
  18483. qju.setUtm_result_code(zra.getJudgeresult());
  18484. qju.setUtm_result_desc(zra.getJudgeresult_desc());
  18485. qju.setCic_id(list2.get(0).get("CHEMID") == null?"":list2.get(0).get("CHEMID").toString());
  18486. qju.setCic_result_code(list2.get(0).get("CHEMRESULT")==null?"":list2.get(0).get("CHEMRESULT").toString());
  18487. qju.setCic_result_desc(list2.get(0).get("CHEMRESULT_DESC")==null?"":list2.get(0).get("CHEMRESULT_DESC").toString());
  18488. qju.setR_cic_id(list2.get(0).get("R_CHEMID") == null?"":list2.get(0).get("R_CHEMID").toString());
  18489. qju.setR_cic_result_code(list2.get(0).get("R_CHEMRESULT")==null?"":list2.get(0).get("R_CHEMRESULT").toString());
  18490. qju.setR_cic_result_desc(list2.get(0).get("R_CHEMRESULT_DESC")==null?"":list2.get(0).get("R_CHEMRESULT_DESC").toString());
  18491. qju.setPic_id(list2.get(0).get("PHYSID") == null?"":list2.get(0).get("PHYSID").toString());
  18492. qju.setPic_result_code(list2.get(0).get("PHYSRESULT")==null?"":list2.get(0).get("PHYSRESULT").toString());
  18493. qju.setPic_result_desc(list2.get(0).get("PHYSRESULT_DESC")==null?"":list2.get(0).get("PHYSRESULT_DESC").toString());
  18494. qju.setSic_id(list2.get(0).get("SIZEID") == null?"":list2.get(0).get("SIZEID").toString());
  18495. qju.setSic_result_code(list2.get(0).get("SIZERESULT")==null?"":list2.get(0).get("SIZERESULT").toString());
  18496. qju.setSic_result_desc(list2.get(0).get("SIZERESULT_DESC")==null?"":list2.get(0).get("SIZERESULT_DESC").toString());
  18497. qju.setDic_id(list2.get(0).get("SPYID")==null?"":list2.get(0).get("SPYID").toString());
  18498. qju.setDic_result_code(list2.get(0).get("SPYRESULT")==null?"":list2.get(0).get("SPYRESULT").toString());
  18499. qju.setDic_result_desc(list2.get(0).get("SPYRESULT_DESC")==null?"":list2.get(0).get("SPYRESULT_DESC").toString());
  18500. qju.setSfd_id(list2.get(0).get("SURFACEID")==null?"":list2.get(0).get("SURFACEID").toString());
  18501. qju.setSfd_result_code(list2.get(0).get("UD_SURFACE_RESULT")==null?"":list2.get(0).get("UD_SURFACE_RESULT").toString());
  18502. qju.setSfd_result_desc(list2.get(0).get("UD_SURFACE_RESULT_DESC")==null?"":list2.get(0).get("UD_SURFACE_RESULT_DESC").toString());
  18503. qju.setSfu_id(list2.get(0).get("SURFACEID")==null?"":list2.get(0).get("SURFACEID").toString());
  18504. qju.setSfu_result_code(list2.get(0).get("UP_SURFACE_RESULT")==null?"":list2.get(0).get("UP_SURFACE_RESULT").toString());
  18505. qju.setSfu_result_desc(list2.get(0).get("UP_SURFACE_RESULT_DESC")==null?"":list2.get(0).get("UP_SURFACE_RESULT_DESC").toString());
  18506. qju.setSfe_id(list2.get(0).get("SURFACEID")==null?"":list2.get(0).get("SURFACEID").toString());
  18507. qju.setSfe_result_code(list2.get(0).get("MARGINAL_RESULT")==null?"":list2.get(0).get("MARGINAL_RESULT").toString());
  18508. qju.setSfe_result_desc(list2.get(0).get("MARGINAL_RESULT_DESC")==null?"":list2.get(0).get("MARGINAL_RESULT_DESC").toString());
  18509. qju.setMst_id(list2.get(0).get("SURFACEID")==null?"":list2.get(0).get("SURFACEID").toString());
  18510. qju.setMst_result_code(list2.get(0).get("SURFACERESULT")==null?"":list2.get(0).get("SURFACERESULT").toString());
  18511. qju.setMst_result_desc(list2.get(0).get("SURFACERESULT_DESC")==null?"":list2.get(0).get("SURFACERESULT_DESC").toString());
  18512. qju.setFst_id(list2.get(0).get("PHYFSTSID")==null?"":list2.get(0).get("PHYFSTSID").toString());
  18513. qju.setFst_result_code(list2.get(0).get("PHYFSTSRESULT")==null?"":list2.get(0).get("PHYFSTSRESULT").toString());
  18514. qju.setFst_result_desc(list2.get(0).get("PHYFSTSRESULT_DESC")==null?"":list2.get(0).get("PHYFSTSRESULT_DESC").toString());
  18515. qju.setPsc(hashmap.get(0).get("PSC")==null?"":hashmap.get(0).get("PSC").toString());
  18516. qju.setPsc_desc(hashmap.get(0).get("PSC_DESC")==null?"":hashmap.get(0).get("PSC_DESC").toString());
  18517. qju.setProd_code(hashmap.get(0).get("PROD_CODE")==null?"":hashmap.get(0).get("PROD_CODE").toString());
  18518. qju.setProd_name(hashmap.get(0).get("PROD_NAME")==null?"":hashmap.get(0).get("PROD_NAME").toString());
  18519. qju.setSteel_code(hashmap.get(0).get("STEEL_CODE")==null?"":hashmap.get(0).get("STEEL_CODE").toString());
  18520. qju.setSteel_name(hashmap.get(0).get("STEEL_NAME").toString());
  18521. qju.setStd_code(hashmap.get(0).get("STD_CODE")==null?"":hashmap.get(0).get("STD_CODE").toString());
  18522. qju.setStd_name(hashmap.get(0).get("STD_NAME")==null?"":hashmap.get(0).get("STD_NAME").toString());
  18523. qju.setJudge_name(username);
  18524. qju.setJudge_time(new Date());
  18525. qju.setPline_code(hashmap.get(0).get("PLINE_CODE")==null?"":hashmap.get(0).get("PLINE_CODE").toString());
  18526. qju.setPline_name(hashmap.get(0).get("PLINE_NAME")==null?"":hashmap.get(0).get("PLINE_NAME").toString());
  18527. mapper.insertQcmJudgeUltimate(qju);
  18528. coiljudge_status_call(hashmap.get(0).get("PLINE_CODE").toString(), material_no, null, null, null, null,type , null, null,"");
  18529. }
  18530. }else{
  18531. for(HashMap list:list3){
  18532. QcmJudgeUltimate qju=new QcmJudgeUltimate();
  18533. //获取判定记录号当天的最大值
  18534. Date now = new Date();
  18535. String opr_time = new SimpleDateFormat("yyyyMMddHHmmss").format(now); //操作时间
  18536. SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
  18537. String date=sdf.format(now);
  18538. count=0;
  18539. sql ="select * from qcm_judge_ultimate where UTM_ID like 'ZY"+date+"%' order by UTM_ID desc";
  18540. List<QcmJudgeUltimate> listUl=mapper.QcmJudgeUltimate(sql);
  18541. if (listUl!=null&&listUl.size()>0) {
  18542. String s=listUl.get(0).getUtm_id();
  18543. count=Integer.parseInt(s.substring(s.length()-4,s.length()));
  18544. }
  18545. count++;
  18546. String utm_id="ZY"+sdf.format(now)+String.format("%04d",count);
  18547. //更新库存表综合判定结果
  18548. QcmJudgeYtCoilResult zra = new QcmJudgeYtCoilResult();
  18549. zra.setCoil_no(material_no);
  18550. zra.setJudgeid(utm_id);
  18551. if(type.equals("3")){
  18552. zra.setJudgeresult("3");
  18553. zra.setJudgeresult_desc("次品");
  18554. }
  18555. else if(type.equals("4")){
  18556. zra.setJudgeresult("4");
  18557. zra.setJudgeresult_desc("废品");
  18558. }
  18559. if(zra.getJudgeresult().equals("2")){
  18560. throw new Exception("综合判定不合格!");
  18561. }
  18562. mapper.UpdateJugeResultY(zra);
  18563. //插入综合判定记录表
  18564. qju.setDesign_key(hashmap.get(0).get("DESIGN_KEY") == null ?"":hashmap.get(0).get("DESIGN_KEY").toString());
  18565. qju.setHeat_no(hashmap.get(0).get("HEAT_NO")==null?"":hashmap.get(0).get("HEAT_NO").toString());
  18566. qju.setBatch_no(hashmap.get(0).get("BATCHNO")==null?"":hashmap.get(0).get("BATCHNO").toString());
  18567. qju.setBoard_no(hashmap.get(0).get("BOARD_NO")==null?"":hashmap.get(0).get("BOARD_NO").toString());
  18568. qju.setInspection_lot(hashmap.get(0).get("INSPECTION_LOT")==null ?"":hashmap.get(0).get("INSPECTION_LOT").toString());
  18569. qju.setMaterial_no(material_no);
  18570. qju.setUtm_id(utm_id);
  18571. qju.setUtm_memo("");
  18572. qju.setUtm_result_code(zra.getJudgeresult());
  18573. qju.setUtm_result_desc(zra.getJudgeresult_desc());
  18574. qju.setCic_id(list3.get(0).get("CHEMID") == null?"":list3.get(0).get("CHEMID").toString());
  18575. qju.setCic_result_code(list3.get(0).get("CHEMRESULT")==null?"":list3.get(0).get("CHEMRESULT").toString());
  18576. qju.setCic_result_desc(list3.get(0).get("CHEMRESULT_DESC")==null?"":list3.get(0).get("CHEMRESULT_DESC").toString());
  18577. qju.setR_cic_id(list3.get(0).get("R_CHEMID") == null?"":list3.get(0).get("R_CHEMID").toString());
  18578. qju.setR_cic_result_code(list3.get(0).get("R_CHEMRESULT")==null?"":list3.get(0).get("R_CHEMRESULT").toString());
  18579. qju.setR_cic_result_desc(list3.get(0).get("R_CHEMRESULT_DESC")==null?"":list3.get(0).get("R_CHEMRESULT_DESC").toString());
  18580. qju.setPic_id(list3.get(0).get("PHYSID") == null?"":list3.get(0).get("PHYSID").toString());
  18581. qju.setPic_result_code(list3.get(0).get("PHYSRESULT")==null?"":list3.get(0).get("PHYSRESULT").toString());
  18582. qju.setPic_result_desc(list3.get(0).get("PHYSRESULT_DESC")==null?"":list3.get(0).get("PHYSRESULT_DESC").toString());
  18583. qju.setSic_id(list3.get(0).get("SIZEID") == null?"":list3.get(0).get("SIZEID").toString());
  18584. qju.setSic_result_code(list3.get(0).get("SIZERESULT")==null?"":list3.get(0).get("SIZERESULT").toString());
  18585. qju.setSic_result_desc(list3.get(0).get("SIZERESULT_DESC")==null?"":list3.get(0).get("SIZERESULT_DESC").toString());
  18586. qju.setDic_id(list3.get(0).get("SPYID")==null?"":list3.get(0).get("SPYID").toString());
  18587. qju.setDic_result_code(list3.get(0).get("SPYRESULT")==null?"":list3.get(0).get("SPYRESULT").toString());
  18588. qju.setDic_result_desc(list3.get(0).get("SPYRESULT_DESC")==null?"":list3.get(0).get("SPYRESULT_DESC").toString());
  18589. qju.setSfd_id(list3.get(0).get("SURFACEID")==null?"":list3.get(0).get("SURFACEID").toString());
  18590. qju.setSfd_result_code(list3.get(0).get("UD_SURFACE_RESULT")==null?"":list3.get(0).get("UD_SURFACE_RESULT").toString());
  18591. qju.setSfd_result_desc(list3.get(0).get("UD_SURFACE_RESULT_DESC")==null?"":list3.get(0).get("UD_SURFACE_RESULT_DESC").toString());
  18592. qju.setSfu_id(list3.get(0).get("SURFACEID")==null?"":list3.get(0).get("SURFACEID").toString());
  18593. qju.setSfu_result_code(list3.get(0).get("UP_SURFACE_RESULT")==null?"":list3.get(0).get("UP_SURFACE_RESULT").toString());
  18594. qju.setSfu_result_desc(list3.get(0).get("UP_SURFACE_RESULT_DESC")==null?"":list3.get(0).get("UP_SURFACE_RESULT_DESC").toString());
  18595. qju.setSfe_id(list3.get(0).get("SURFACEID")==null?"":list3.get(0).get("SURFACEID").toString());
  18596. qju.setSfe_result_code(list3.get(0).get("MARGINAL_RESULT")==null?"":list3.get(0).get("MARGINAL_RESULT").toString());
  18597. qju.setSfe_result_desc(list3.get(0).get("MARGINAL_RESULT_DESC")==null?"":list3.get(0).get("MARGINAL_RESULT_DESC").toString());
  18598. qju.setMst_id(list3.get(0).get("SURFACEID")==null?"":list3.get(0).get("SURFACEID").toString());
  18599. qju.setMst_result_code(list3.get(0).get("SURFACERESULT")==null?"":list3.get(0).get("SURFACERESULT").toString());
  18600. qju.setMst_result_desc(list3.get(0).get("SURFACERESULT_DESC")==null?"":list3.get(0).get("SURFACERESULT_DESC").toString());
  18601. qju.setFst_id(list3.get(0).get("PHYFSTSID")==null?"":list3.get(0).get("PHYFSTSID").toString());
  18602. qju.setFst_result_code(list3.get(0).get("PHYFSTSRESULT")==null?"":list3.get(0).get("PHYFSTSRESULT").toString());
  18603. qju.setFst_result_desc(list3.get(0).get("PHYFSTSRESULT_DESC")==null?"":list3.get(0).get("PHYFSTSRESULT_DESC").toString());
  18604. qju.setPsc(hashmap.get(0).get("PSC")==null?"":hashmap.get(0).get("PSC").toString());
  18605. qju.setPsc_desc(hashmap.get(0).get("PSC_DESC")==null?"":hashmap.get(0).get("PSC_DESC").toString());
  18606. qju.setProd_code(hashmap.get(0).get("PROD_CODE")==null?"":hashmap.get(0).get("PROD_CODE").toString());
  18607. qju.setProd_name(hashmap.get(0).get("PROD_NAME")==null?"":hashmap.get(0).get("PROD_NAME").toString());
  18608. qju.setSteel_code(hashmap.get(0).get("STEEL_CODE")==null?"":hashmap.get(0).get("STEEL_CODE").toString());
  18609. qju.setSteel_name(hashmap.get(0).get("STEEL_NAME").toString());
  18610. qju.setStd_code(hashmap.get(0).get("STD_CODE")==null?"":hashmap.get(0).get("STD_CODE").toString());
  18611. qju.setStd_name(hashmap.get(0).get("STD_NAME")==null?"":hashmap.get(0).get("STD_NAME").toString());
  18612. qju.setJudge_name(username);
  18613. qju.setJudge_time(new Date());
  18614. qju.setPline_code(hashmap.get(0).get("PLINE_CODE")==null?"":hashmap.get(0).get("PLINE_CODE").toString());
  18615. qju.setPline_name(hashmap.get(0).get("PLINE_NAME")==null?"":hashmap.get(0).get("PLINE_NAME").toString());
  18616. mapper.insertQcmJudgeUltimate(qju);
  18617. String url = "http://172.16.81.200/xinsteel.maketx/service/SlmFundFirstDetailService/receiveResUltimate";
  18618. JSONObject jsobj1 = new JSONObject();
  18619. JSONObject jsobj2 = new JSONObject();
  18620. JSONArray ttmaps = new JSONArray();
  18621. JSONArray ttmaps1 = new JSONArray();
  18622. jsobj1.put("utm_id", utm_id);
  18623. jsobj1.put("heat_no",hashmap.get(0).get("HEAT_NO")==null?"":hashmap.get(0).get("HEAT_NO").toString());
  18624. jsobj1.put("batch_no",hashmap.get(0).get("BATCHNO")==null?"":hashmap.get(0).get("BATCHNO").toString());
  18625. jsobj1.put("inspection_lot",hashmap.get(0).get("INSPECTION_LOT") == null ?"":hashmap.get(0).get("INSPECTION_LOT").toString());
  18626. jsobj1.put("material_no",material_no);
  18627. jsobj1.put("contract_line_no",hashmap.get(0).get("DESIGN_KEY") == null ?"":hashmap.get(0).get("DESIGN_KEY").toString());
  18628. jsobj1.put("cic_id",list3.get(0).get("CHEMID") == null?"":list3.get(0).get("CHEMID").toString());
  18629. jsobj1.put("pic_id",list3.get(0).get("PHYSID") == null?"":list3.get(0).get("PHYSID").toString());
  18630. jsobj1.put("sic_id",list3.get(0).get("SIZEID") == null?"":list3.get(0).get("SIZEID").toString());
  18631. jsobj1.put("sic_result_desc",list3.get(0).get("SIZERESULT_DESC")==null?"":list3.get(0).get("SIZERESULT_DESC").toString());
  18632. jsobj1.put("sfu_id",list3.get(0).get("SURFACEID")==null?"":list3.get(0).get("SURFACEID").toString());
  18633. jsobj1.put("sfu_result_desc",list3.get(0).get("SURFACERESULT_DESC")==null?"":list3.get(0).get("SURFACERESULT_DESC").toString());
  18634. jsobj1.put("utm_result_desc",zra.getJudgeresult_desc());
  18635. jsobj1.put("utm_reason","");
  18636. jsobj1.put("utm_memo","");
  18637. jsobj1.put("judge_name",username);
  18638. jsobj1.put("judge_time",now);
  18639. jsobj1.put("order_no",hashmap.get(0).get("DESIGN_KEY") == null ?"":hashmap.get(0).get("DESIGN_KEY").toString());
  18640. jsobj2.put("object", jsobj1);
  18641. ttmaps1.add(jsobj2);
  18642. String result = post1(JSON.toJSONString(ttmaps1),url);
  18643. JSONObject jo = JSONObject.parseObject(result);
  18644. if(!"200".equals(jo.get("state").toString())){
  18645. throw new Exception(jo.get("msgInfo").toString());
  18646. }
  18647. }
  18648. }
  18649. }else{
  18650. throw new Exception("未找到该检验号下的库存信息!");
  18651. }
  18652. //cro = creatUltimateResultByHand(material_no,username);//手动进行综合判定
  18653. }catch(Exception ex){
  18654. cro.setV_errCode(-1);
  18655. cro.setV_errMsg(ex.getMessage());
  18656. //SqlSession.rollback();
  18657. }
  18658. //SqlSession.close();
  18659. return cro;
  18660. }
  18661. /***
  18662. * 综合判定:
  18663. * @param sum
  18664. * @return
  18665. */
  18666. @SuppressWarnings({ "rawtypes", "unused" })
  18667. public void LgultimateJudgeAutoBySystem(String material_no, String username,String prodline,String prod_name) throws Exception{
  18668. try{
  18669. int flag = 0;
  18670. QcmJhyElementsServiceImpl qjes = new QcmJhyElementsServiceImpl();
  18671. List<HashMap> hashmap = (List<HashMap>) qjes.getLgRejudgeInfobyMaterial_no("", "", material_no, prodline, prod_name, "J").getResult();
  18672. if(hashmap.size() == 0){
  18673. return;
  18674. }
  18675. QcmJudgeUltimate qju=new QcmJudgeUltimate();
  18676. if(hashmap.get(0).get("CHEMRESULT_LK").toString().equals("0") || hashmap.get(0).get("FACERESULT").toString().equals("0") ||hashmap.get(0).get("CHEMRESULT_LK").toString().equals("") || hashmap.get(0).get("FACERESULT").toString().equals("")){
  18677. return;
  18678. }
  18679. if(hashmap.get(0).get("FACERESULT") == null || hashmap.get(0).get("CHEMRESULT_LK") == null||hashmap.get(0).get("FACERESULT").toString() == "" || hashmap.get(0).get("CHEMRESULT_LK").toString() == ""){
  18680. return;
  18681. }
  18682. flag += ("1".equals(hashmap.get(0).get("CHEMRESULT_LK").toString()) || "9".equals(hashmap.get(0).get("CHEMRESULT_LK").toString())) ? 0 : 1;
  18683. flag += ("1".equals(hashmap.get(0).get("FACERESULT").toString()) || "9".equals(hashmap.get(0).get("FACERESULT").toString())) ? 0 : 1;
  18684. String Judgeresult = (flag == 0 ? "1" :"2");
  18685. String Judgeresult_desc = (flag == 0 ? "合格" : "不合格");
  18686. if(hashmap.get(0).get("CHEMRESULT_LK").toString().equals("3") || hashmap.get(0).get("FACERESULT").toString().equals("3")){
  18687. Judgeresult ="3";
  18688. Judgeresult_desc = "次品";
  18689. }
  18690. if(hashmap.get(0).get("CHEMRESULT_LK").toString().equals("4") || hashmap.get(0).get("FACERESULT").toString().equals("4")){
  18691. Judgeresult ="4";
  18692. Judgeresult_desc = "废品";
  18693. }
  18694. if(prodline.equals("4001LGX") && (hashmap.get(0).get("DESIGN_KEY") == null || hashmap.get(0).get("DESIGN_KEY").toString().equals("")) && Judgeresult.equals("1")){
  18695. Judgeresult ="6";
  18696. Judgeresult_desc = "合格";
  18697. }
  18698. if(prodline.equals("4001LG0") && (hashmap.get(0).get("DESIGN_KEY") == null || hashmap.get(0).get("DESIGN_KEY").toString().equals("")) && Judgeresult.equals("1")){
  18699. Judgeresult ="9";
  18700. Judgeresult_desc = "合格";
  18701. }
  18702. List<QCMJudgeLocking> qj = mapper.queryQCMJudgeLockings("select * from qcm_judge_locking where lock_id = '"+hashmap.get(0).get("CHEMJUDGEID").toString()+"' and unlock_type_code is null");
  18703. if(qj.size() > 0){
  18704. return;
  18705. }
  18706. qj = mapper.queryQCMJudgeLockings("select * from qcm_judge_locking where lock_id = '"+hashmap.get(0).get("FACECHECKID").toString()+"' and unlock_type_code is null");
  18707. if(qj.size() > 0){
  18708. return;
  18709. }
  18710. qj = mapper.queryQCMJudgeLockings("select * from qcm_judge_locking where material_no = '"+material_no+"' and unlock_type_code is null");
  18711. if(qj.size() > 0){
  18712. return;
  18713. }
  18714. //获取判定记录号当天的最大值
  18715. Date now = new Date();
  18716. String opr_time = new SimpleDateFormat("yyyyMMddHHmmss").format(now); //操作时间
  18717. SimpleDateFormat sdf=new SimpleDateFormat("yyMMdd");
  18718. String date=sdf.format(now);
  18719. int count=0;
  18720. String sql ="select * from (select * from qcm_judge_ultimate where UTM_ID like 'ZL"+date+"%' order by UTM_ID desc) where rownum <= 1";
  18721. List<QcmJudgeUltimate> listUl=mapper.QcmJudgeUltimate(sql);
  18722. if (listUl!=null&&listUl.size()>0) {
  18723. String s=listUl.get(0).getUtm_id();
  18724. count=Integer.parseInt(s.substring(s.length()-4,s.length()));
  18725. }
  18726. count++;
  18727. String utm_id="ZL"+sdf.format(now)+String.format("%04d",count);
  18728. qju.setUtm_id(utm_id);
  18729. String is_fx = "1";
  18730. if(prodline.equals("4001LGX")){
  18731. is_fx = "0";
  18732. }
  18733. //插入综合判定记录表
  18734. qju.setDesign_key(hashmap.get(0).get("DESIGN_KEY") == null ?"":hashmap.get(0).get("DESIGN_KEY").toString());
  18735. qju.setHeat_no(hashmap.get(0).get("HEAT_NO")==null?"":hashmap.get(0).get("HEAT_NO").toString());
  18736. qju.setBatch_no(material_no);
  18737. qju.setBoard_no(material_no);
  18738. qju.setInspection_lot("");
  18739. qju.setMaterial_no(material_no);
  18740. qju.setUtm_id(utm_id);
  18741. qju.setUtm_memo(hashmap.get(0).get("REMARK")==null?"":hashmap.get(0).get("REMARK").toString());
  18742. qju.setUtm_result_code(Judgeresult.equals("6")?"1":Judgeresult);
  18743. qju.setUtm_result_desc(Judgeresult_desc);
  18744. if(Judgeresult.equals("9")){
  18745. qju.setUtm_result_code("1");
  18746. qju.setUtm_result_desc("订单外合格");
  18747. }
  18748. qju.setR_cic_id(hashmap.get(0).get("CHEMJUDGEID").toString());
  18749. qju.setR_cic_result_code(hashmap.get(0).get("CHEMRESULT_LK").toString());
  18750. qju.setR_cic_result_desc(hashmap.get(0).get("CHEMRESULT_LK").equals("1")?"合格":(hashmap.get(0).get("CHEMRESULT_LK").equals("2")?"不合格":(hashmap.get(0).get("CHEMRESULT_LK").equals("3")?"判次":(hashmap.get(0).get("CHEMRESULT_LK").equals("9")?"订单外合格":"判废"))));
  18751. qju.setSfd_id(hashmap.get(0).get("FACECHECKID").toString());
  18752. qju.setSfd_result_code(hashmap.get(0).get("FACERESULT").toString());
  18753. qju.setSfd_result_desc(hashmap.get(0).get("FACERESULT").equals("1")?"合格":(hashmap.get(0).get("FACERESULT").equals("2")?"不合格":(hashmap.get(0).get("FACERESULT").equals("3")?"判次":(hashmap.get(0).get("FACERESULT").equals("9")?"订单外合格":"判废"))));
  18754. qju.setSfe_id(hashmap.get(0).get("FACECHECKID").toString());
  18755. qju.setSfe_result_code(hashmap.get(0).get("FACERESULT").toString());
  18756. qju.setSfe_result_desc(hashmap.get(0).get("FACERESULT").equals("1")?"合格":(hashmap.get(0).get("FACERESULT").equals("2")?"不合格":(hashmap.get(0).get("FACERESULT").equals("3")?"判次":(hashmap.get(0).get("FACERESULT").equals("9")?"订单外合格":"判废"))));
  18757. qju.setSfu_id(hashmap.get(0).get("FACECHECKID").toString());
  18758. qju.setSfu_result_code(hashmap.get(0).get("FACERESULT").toString());
  18759. qju.setSfu_result_desc(hashmap.get(0).get("FACERESULT").equals("1")?"合格":(hashmap.get(0).get("FACERESULT").equals("2")?"不合格":(hashmap.get(0).get("FACERESULT").equals("3")?"判次":(hashmap.get(0).get("FACERESULT").equals("9")?"订单外合格":"判废"))));
  18760. qju.setPsc("");
  18761. qju.setPsc_desc("");
  18762. qju.setProd_code("");
  18763. qju.setProd_name(hashmap.get(0).get("PROD_NAME")==null?"":hashmap.get(0).get("PROD_NAME").toString());
  18764. qju.setSteel_code(hashmap.get(0).get("GRADE_NAME").toString());
  18765. qju.setSteel_name(hashmap.get(0).get("GRADE_NAME").toString());
  18766. qju.setStd_code(hashmap.get(0).get("STD_NAME")==null?"":hashmap.get(0).get("STD_NAME").toString());
  18767. qju.setStd_name(hashmap.get(0).get("STD_NAME")==null?"":hashmap.get(0).get("STD_NAME").toString());
  18768. qju.setJudge_name(username);
  18769. qju.setJudge_time(new Date());
  18770. qju.setPline_code(hashmap.get(0).get("PLINE_CODE")==null?"":hashmap.get(0).get("PLINE_CODE").toString());
  18771. qju.setPline_name(hashmap.get(0).get("PLINE_NAME")==null?"":hashmap.get(0).get("PLINE_NAME").toString());
  18772. mapper.insertQcmJudgeUltimate(qju);
  18773. //调用综合判定接口
  18774. JSONObject jsobj2 = new JSONObject();
  18775. JSONArray ttmaps = new JSONArray();
  18776. JSONObject jsobj1 = new JSONObject();
  18777. jsobj1.put("CHEMRESULT_LK", "");
  18778. jsobj1.put("FACERESULT","");
  18779. jsobj1.put("COMPREHENSIVERESULT",Judgeresult);
  18780. jsobj1.put("CHEMJUDGEID","");
  18781. jsobj1.put("FACECHECKID","");
  18782. jsobj1.put("COMPREHENSIVEID",utm_id);
  18783. jsobj1.put("JUDGE_TYPE","J");
  18784. jsobj1.put("PROD_LINE",prodline);
  18785. jsobj1.put("ISJUDGE","1");
  18786. jsobj1.put("PROD_TYPE",prod_name);
  18787. jsobj1.put("SLAB_NO",material_no);
  18788. jsobj1.put("CHECKNO","");
  18789. jsobj1.put("OPTMAN", username);
  18790. jsobj1.put("ISFX", is_fx);
  18791. jsobj1.put("CHEMRESULT_FX", "");
  18792. ttmaps.add(jsobj1);
  18793. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  18794. String result = qjes.callWebserviceASMX(url,"ChemJudge",JSON.toJSONString(ttmaps));
  18795. JSONObject jo = JSONObject.parseObject(result);
  18796. if(jo.get("code").toString().equals("1")){
  18797. return;
  18798. }
  18799. //judge_call(hashmap.get(0).get("STD_NAME"),hashmap.get(0).get("PROD_NAME"),hashmap.get(0).get("STD_NAME"),hashmap.get(0).get("PROD_NAME"),)
  18800. }catch(Exception ex){
  18801. cro.setV_errCode(-1);
  18802. cro.setV_errMsg(ex.getMessage());
  18803. SqlSession.rollback();
  18804. }
  18805. }
  18806. /**
  18807. * 线棒按吊号判次判废
  18808. */
  18809. public CoreReturnObject JudgeF(String material_no,String username,String status){
  18810. try{
  18811. ZjResultAll zra = new ZjResultAll();
  18812. if(status.equals("3")){
  18813. zra.setPhysresult("3");
  18814. zra.setPhysresult_desc("判次");
  18815. }else
  18816. {
  18817. zra.setPhysresult("4");
  18818. zra.setPhysresult_desc("判废");
  18819. }
  18820. zra.setBilletid(material_no);
  18821. zra.setPic_is_lock("0");
  18822. mapper.UpdateJugeResultB(zra);
  18823. ultimateJudgeAuto(material_no,username,status);
  18824. order_down(material_no,zra.getPhysresult_desc());
  18825. SqlSession.commit();
  18826. }catch(Exception ex){
  18827. cro.setV_errCode(-1);
  18828. cro.setV_errMsg("人工处理出错"+ex.getMessage());
  18829. logger.info(ex.getMessage());
  18830. SqlSession.rollback();
  18831. }
  18832. SqlSession.close();
  18833. return cro;
  18834. }
  18835. /*
  18836. * @desc coiljudge_status_call
  18837. * @param pline 产线'RZ1' 'SZ1' 'LT1'
  18838. * @param pcoilno 钢卷号
  18839. * @param chemrs 成分判定结果 '1'合格 '2'不合格
  18840. * @param qltyrs 材质判定结果 '1'合格 '2'不合格
  18841. * @param sizers 尺寸判定结果 '1'合格 '2'不合格
  18842. * @param exshrs 外观判定结果 '1'合格 '2'不合格,'3'次品 '4'废品
  18843. * @param totrs 综合判定
  18844. * @param fb_yn 是否封闭
  18845. * @param fb_reason 封闭原因
  18846. * @return void
  18847. *
  18848. * @date 2022/8/24 17:22
  18849. * @author Ljy
  18850. */
  18851. public void coiljudge_status_call(
  18852. String pline
  18853. , String pcoilno
  18854. , String chemrs
  18855. , String qltyrs
  18856. , String sizers
  18857. , String exshrs
  18858. , String totrs
  18859. , String fb_yn
  18860. , String fb_reason,String sf_lv) throws java.lang.Exception {
  18861. Connection conn = null;
  18862. CallableStatement cstmt = null;
  18863. ResultSet rs = null;
  18864. try {
  18865. conn = SqlSession.getConnection();
  18866. String callSql = "{call COILJUDGE_STATUSNEW(?,?,?,?,?,?,?,?,?,?,?,?) }";
  18867. cstmt = conn.prepareCall(callSql);
  18868. cstmt.setString(1, StringUtils.isBlank(pline) ? "" : pline);
  18869. cstmt.setString(2, StringUtils.isBlank(pcoilno) ? "" : pcoilno);
  18870. cstmt.setString(3, StringUtils.isBlank(chemrs) ? "" : chemrs);
  18871. cstmt.setString(4, StringUtils.isBlank(qltyrs) ? "" : qltyrs);
  18872. cstmt.setString(5, StringUtils.isBlank(sizers) ? "" : sizers);
  18873. cstmt.setString(6, StringUtils.isBlank(exshrs) ? "" : exshrs);
  18874. cstmt.setString(7, StringUtils.isBlank(totrs) ? "" : totrs);
  18875. cstmt.setString(8, StringUtils.isBlank(fb_yn) ? "" : fb_yn);
  18876. cstmt.setString(9, StringUtils.isBlank(fb_reason) ? "" : fb_reason);
  18877. cstmt.setString(10, StringUtils.isBlank(sf_lv) ? "" : sf_lv);
  18878. cstmt.registerOutParameter(11, java.sql.Types.INTEGER);
  18879. cstmt.registerOutParameter(12, java.sql.Types.VARCHAR);
  18880. cstmt.execute();
  18881. if(cstmt.getString(11) != null){
  18882. if(cstmt.getString(11).equals("2")){
  18883. throw new java.lang.Exception(cstmt.getString(12).toString());
  18884. }
  18885. }
  18886. if(cstmt.getString(11) != null){
  18887. if(cstmt.getString(11).equals("2")){
  18888. throw new java.lang.Exception(cstmt.getString(11).toString());
  18889. }
  18890. }
  18891. } catch (Exception e) {
  18892. throw new Exception(e.getMessage());
  18893. } finally {
  18894. try {
  18895. if (rs != null) {
  18896. rs.close();
  18897. }
  18898. } catch (Exception e) {
  18899. throw new Exception(e.getMessage());
  18900. }
  18901. try {
  18902. if (cstmt != null) {
  18903. cstmt.close();
  18904. }
  18905. } catch (Exception e) {
  18906. throw new Exception(e.getMessage());
  18907. }
  18908. }
  18909. }
  18910. /**
  18911. * 获取成分判定标准(交付/客户/内控)
  18912. *
  18913. * @param designKey
  18914. * @param psc 产品码
  18915. * @param plineCode 产线编号
  18916. * @param mscPline 制程号
  18917. * @return
  18918. */
  18919. public CoreReturnObject GetOrdJudgeStdCic(String designKey) {
  18920. try {
  18921. /*String sql = "select * from qcm_ord_design_std where design_key = '"+designKey+"' and psc = '"+psc+"'";
  18922. List<QCMOrdDesignStd> _designStd=mapper.queryQCMOrdDesignStd(sql);
  18923. if(SqlJoint.IsNullOrSpace(_designStd.get(0).getCic())){
  18924. cro.setV_errCode(-1);
  18925. cro.setV_errMsg("成分索引号不能为空");
  18926. return cro;
  18927. }*/
  18928. OrdJudgeStd<QCMOrdDesignStdCic> stdCic = new OrdJudgeStd<QCMOrdDesignStdCic>();
  18929. //交付标准.
  18930. String condition = "";
  18931. String sql = "select * from QCM_ORD_DESIGN_STD_CIC where 1=1";
  18932. condition = " and SPECL_FL = '0'" + " and STD_TYPE_CODE = 'C' And DESIGN_KEY='" + SqlJoint.TrimSqlDangerMark(designKey) + "'";
  18933. List<QCMOrdDesignStdCic> listStdGB = mapper.queryQCMOrdDesignStdCic(sql + condition);
  18934. stdCic.setListStdGB(listStdGB);
  18935. //客户标准
  18936. condition = " and SPECL_FL = '1'" + " and STD_TYPE_CODE = 'C' And DESIGN_KEY='" + SqlJoint.TrimSqlDangerMark(designKey) + "'";
  18937. List<QCMOrdDesignStdCic> listStdKH = mapper.queryQCMOrdDesignStdCic(sql + condition);
  18938. stdCic.setListStdKH(listStdKH);
  18939. //内控标准
  18940. condition = "and SPECL_FL = '2'" + " and STD_TYPE_CODE = 'C' And DESIGN_KEY='" + SqlJoint.TrimSqlDangerMark(designKey) + "'";
  18941. List<QCMOrdDesignStdCic> listStdNK = mapper.queryQCMOrdDesignStdCic(sql + condition);
  18942. stdCic.setListStdNK(listStdNK);
  18943. cro.setResult(stdCic);
  18944. } catch (Exception ex) {
  18945. cro.setV_errCode(-1);
  18946. cro.setV_errMsg("获取数据出错" + ex.getMessage());
  18947. }
  18948. return cro;
  18949. }
  18950. /**
  18951. * 获取成分检验实绩信息
  18952. *
  18953. * @param com
  18954. * @return
  18955. */
  18956. public CoreReturnObject GetElementsInfo(QcmJhyInspElements com, String design_key) {
  18957. try {
  18958. //"length(chem_name) desc" 这个排序对复合元素计算有用,慎重更改
  18959. String sql = "select * from (select a.assay_no,a.heat_no,a.batch_no,a.inspection_lot,a.smp_no,a.specimen_no, "
  18960. + " a.material_no, a.pline_code, a.pline_name,a.steel_code,a.steel_name,a.assay_type, "
  18961. + " a.chem_code,a.chem_name,case when a.chem_value > -1 and a.chem_value < 1 and a.chem_value != 0 then '0' || round(a.chem_value,7) else '' || round(a.chem_value,7) end chem_value,a.coil_sort, "
  18962. + " a.source,a.sample_type,a.memo, a.create_id, a.create_name, a.create_time from QCM_JHY_INSP_ELEMENTS a where SPECIMEN_NO = '" + com.getSpecimen_no() + "' order by length(chem_name) desc) where rownum <= 1";
  18963. List<QcmJhyInspElements> listEle = mapper.queryQcmJhyInspElements(sql);
  18964. cro.setResult(listEle);
  18965. } catch (Exception ex) {
  18966. cro.setV_errCode(-1);
  18967. cro.setV_errMsg("获取成分检验信息出错" + ex.getMessage());
  18968. SqlSession.rollback();
  18969. }
  18970. return cro;
  18971. }
  18972. /**
  18973. * 获取对比结果
  18974. *
  18975. * @param stdCic 标准数据
  18976. * @param listEle 检验数据
  18977. * @return
  18978. */
  18979. public boolean CompareResult(List<QCMOrdDesignStdCic> stdCic, List<QcmJhyInspElements> listEle) throws Exception {
  18980. try {
  18981. for (QCMOrdDesignStdCic cic : stdCic) {
  18982. if (cic.getIsjudge().equals("0")) {
  18983. continue;
  18984. }
  18985. int i = 0;
  18986. /*if(cic.getChem_type().equals("B")){ //复合元素
  18987. String express=cic.getChem_formula();
  18988. for (QcmJhyInspElements qcmJhyElements : listEle) {
  18989. express=express.replaceAll(qcmJhyElements.getChem_name(), qcmJhyElements.getChem_value());
  18990. }
  18991. double result=SqlJoint.GetFormulaResult(express);
  18992. boolean pass=SqlJoint.checkSignAndValue(cic.getStdmax_sign(),SqlJoint.GetDouble(cic.getStdmax()),SqlJoint.GetString(result));
  18993. if(!pass){
  18994. return false;
  18995. }
  18996. pass=SqlJoint.checkSignAndValue(cic.getStdmin_sign(),SqlJoint.GetDouble(cic.getStdmin()),SqlJoint.GetString(result));
  18997. if(!pass){
  18998. return false;
  18999. }
  19000. i++;
  19001. continue;
  19002. }*/
  19003. for (QcmJhyInspElements ele : listEle) {
  19004. if (ele.getChem_code().equals(cic.getChem_code())) {
  19005. boolean pass = SqlJoint.checkSignAndValue(cic.getStdmax_sign(), SqlJoint.GetDouble(cic.getStdmax()), ele.getChem_value());
  19006. if (!pass) {
  19007. return false;
  19008. }
  19009. pass = SqlJoint.checkSignAndValue(cic.getStdmin_sign(), SqlJoint.GetDouble(cic.getStdmin()), ele.getChem_value());
  19010. if (!pass) {
  19011. return false;
  19012. }
  19013. i++;
  19014. break;
  19015. }
  19016. }
  19017. if (i == 0) {
  19018. return false;
  19019. }
  19020. }
  19021. } catch (Exception ex) {
  19022. throw new Exception(ex.getMessage());
  19023. }
  19024. return true;
  19025. }
  19026. /**
  19027. * 获取封锁原因
  19028. *
  19029. * @param stdCic 标准数据
  19030. * @param listEle 检验数据
  19031. * @return
  19032. */
  19033. public String CompareResults(String memo, List<QCMOrdDesignStdCic> stdCic, List<QcmJhyInspElements> listEle) throws Exception {
  19034. try {
  19035. DecimalFormat df = new DecimalFormat("#.00");
  19036. for (QCMOrdDesignStdCic cic : stdCic) {
  19037. if (cic.getIsjudge().equals("0")) {
  19038. continue;
  19039. }
  19040. int i = 0;
  19041. /*if(cic.getChem_type().equals("B")){ //复合元素
  19042. String express=cic.getChem_formula();
  19043. for (QcmJhyInspElements qcmJhyElements : listEle) {
  19044. express=express.replaceAll(qcmJhyElements.getChem_name(), qcmJhyElements.getChem_value());
  19045. }
  19046. double result=SqlJoint.GetFormulaResult(express);
  19047. boolean pass=SqlJoint.checkSignAndValue(cic.getStdmax_sign(),SqlJoint.GetDouble(cic.getStdmax()),SqlJoint.GetString(result));
  19048. if(!pass){
  19049. if(memo.equals("")){
  19050. memo = cic.getChem_code() + ":" +df.format(result);
  19051. }
  19052. else{
  19053. memo = memo + "," + cic.getChem_code() + ":" +df.format(result);
  19054. }
  19055. }
  19056. pass=SqlJoint.checkSignAndValue(cic.getStdmin_sign(),SqlJoint.GetDouble(cic.getStdmin()),SqlJoint.GetString(result));
  19057. if(!pass){
  19058. if(memo.equals("")){
  19059. memo = cic.getChem_code() + ":" +df.format(result);
  19060. }
  19061. else{
  19062. memo = memo + "," + cic.getChem_code() + ":" +df.format(result);
  19063. }
  19064. }
  19065. i++;
  19066. continue;
  19067. }*/
  19068. for (QcmJhyInspElements ele : listEle) {
  19069. if (ele.getChem_code().equals(cic.getChem_code())) {
  19070. boolean pass = SqlJoint.checkSignAndValue(cic.getStdmax_sign(), SqlJoint.GetDouble(cic.getStdmax()), ele.getChem_value());
  19071. if (!pass) {
  19072. if (memo.equals("")) {
  19073. memo = cic.getChem_code() + ":" + ele.getChem_value();
  19074. } else {
  19075. memo = memo + "," + cic.getChem_code() + ":" + ele.getChem_value();
  19076. }
  19077. }
  19078. pass = SqlJoint.checkSignAndValue(cic.getStdmin_sign(), SqlJoint.GetDouble(cic.getStdmin()), ele.getChem_value());
  19079. if (!pass) {
  19080. if (memo.equals("")) {
  19081. memo = cic.getChem_code() + ":" + ele.getChem_value();
  19082. } else {
  19083. memo = memo + "," + cic.getChem_code() + ":" + ele.getChem_value();
  19084. }
  19085. }
  19086. i++;
  19087. break;
  19088. }
  19089. }
  19090. if (i == 0) {
  19091. if (memo.equals("")) {
  19092. memo = cic.getChem_code() + ":" + "";
  19093. } else {
  19094. memo = memo + "," + cic.getChem_code() + ":" + "";
  19095. }
  19096. }
  19097. }
  19098. } catch (Exception ex) {
  19099. throw new Exception(ex.getMessage());
  19100. }
  19101. return memo;
  19102. }
  19103. /**
  19104. * 根据炉号获取化验号
  19105. *
  19106. * @param com
  19107. * @return
  19108. */
  19109. public List<String> GetAssay_no(String heatno,String assay_no) {
  19110. List<String> listEle=new ArrayList<String>();
  19111. try{
  19112. //"length(chem_name) desc" 这个排序对复合元素计算有用,慎重更改
  19113. String sql = "select assay_no from (select * from (select a.assay_no, max(a.create_time) create_time "
  19114. + " from QCM_JHY_INSP_ELEMENTS a where a.heat_no = '"+heatno+"' and a.assay_no like '%"+assay_no+"%' and assay_type = 'L' group by a.assay_no) order by create_time asc) ";
  19115. //System.out.print(sql);
  19116. List<HashMap> list = mapper.query(sql);
  19117. if(list.size() ==0){
  19118. return listEle;
  19119. }
  19120. if(list.size() > 1){
  19121. listEle.add(list.get(0).get("ASSAY_NO").toString());
  19122. listEle.add(list.get(1).get("ASSAY_NO").toString());
  19123. }
  19124. //System.out.print(sql);
  19125. listEle.add(list.get(0).get("ASSAY_NO").toString());
  19126. }catch(Exception ex){
  19127. cro.setV_errCode(-1);
  19128. cro.setV_errMsg("获取化验号出错"+ex.getMessage());
  19129. SqlSession.rollback();
  19130. }
  19131. return listEle;
  19132. }
  19133. /**
  19134. * 获取判定原因
  19135. *
  19136. * @param stdCic 标准数据
  19137. * @param listEle 检验数据
  19138. * @return
  19139. */
  19140. @SuppressWarnings({"unchecked", "rawtypes"})
  19141. public List<ArrayList> CompareResultInfo(List<ArrayList> list, List<QCMOrdDesignStdCic> stdCic, List<QcmJhyInspElements> listEle) throws Exception {
  19142. try {
  19143. DecimalFormat df = new DecimalFormat("#.00");
  19144. for (QCMOrdDesignStdCic cic : stdCic) {
  19145. if (cic.getIsjudge().equals("0")) {
  19146. continue;
  19147. }
  19148. int i = 0;
  19149. /*if(cic.getChem_type().equals("B")){ //复合元素
  19150. String express=cic.getChem_formula();
  19151. for (QcmJhyInspElements qcmJhyElements : listEle) {
  19152. express=express.replaceAll(qcmJhyElements.getChem_name(), qcmJhyElements.getChem_value());
  19153. }
  19154. double result=SqlJoint.GetFormulaResult(express);
  19155. boolean pass1=SqlJoint.checkSignAndValue(cic.getStdmax_sign(),SqlJoint.GetDouble(cic.getStdmax()),SqlJoint.GetString(result));
  19156. boolean pass2=SqlJoint.checkSignAndValue(cic.getStdmin_sign(),SqlJoint.GetDouble(cic.getStdmin()),SqlJoint.GetString(result));
  19157. if(!pass1 || !pass2){
  19158. ArrayList list2 = new ArrayList();
  19159. list2.add(cic.getChem_code());
  19160. list2.add(cic.getChem_name());
  19161. list2.add(df.format(result));
  19162. list2.add(cic.getStdmax());
  19163. list2.add(cic.getStdmax_sign());
  19164. list2.add(cic.getStdmin());
  19165. list2.add(cic.getStdmin_sign());
  19166. list.add(list2);
  19167. }
  19168. i++;
  19169. continue;
  19170. }*/
  19171. for (QcmJhyInspElements ele : listEle) {
  19172. if (ele.getChem_code().equals(cic.getChem_code())) {
  19173. boolean pass1 = SqlJoint.checkSignAndValue(cic.getStdmax_sign(), SqlJoint.GetDouble(cic.getStdmax()), ele.getChem_value());
  19174. boolean pass2 = SqlJoint.checkSignAndValue(cic.getStdmin_sign(), SqlJoint.GetDouble(cic.getStdmin()), ele.getChem_value());
  19175. if (!pass1 || !pass2) {
  19176. ArrayList list2 = new ArrayList();
  19177. list2.add(cic.getChem_code());
  19178. list2.add(cic.getChem_name());
  19179. list2.add(ele.getChem_value());
  19180. list2.add(cic.getStdmax());
  19181. list2.add(cic.getStdmax_sign());
  19182. list2.add(cic.getStdmin());
  19183. list2.add(cic.getStdmin_sign());
  19184. list.add(list2);
  19185. }
  19186. i++;
  19187. break;
  19188. }
  19189. }
  19190. if (i == 0) {
  19191. ArrayList list2 = new ArrayList();
  19192. list2.add(cic.getChem_code());
  19193. list2.add(cic.getChem_name());
  19194. list2.add("");
  19195. list2.add(cic.getStdmax());
  19196. list2.add(cic.getStdmax_sign());
  19197. list2.add(cic.getStdmin());
  19198. list2.add(cic.getStdmin_sign());
  19199. list.add(list2);
  19200. }
  19201. }
  19202. return list;
  19203. } catch (Exception ex) {
  19204. throw new Exception(ex.getMessage());
  19205. }
  19206. }
  19207. /**
  19208. * 炼钢熔炼成分自动判定 0 复样 1.验样 2.改判
  19209. */
  19210. @SuppressWarnings("unchecked")
  19211. public CoreReturnObject JudgeCheck1(String heat_no, String material_no, String design_key, String username, String grade_name, String prod_name, String prodline,String status) throws Exception {
  19212. List<HashMap> hashmap = new ArrayList<HashMap>();
  19213. try {
  19214. String memo = "";
  19215. hashmap = (List<HashMap>) getLgRejudgeInfobyMaterial_no("", "", material_no, prodline, prod_name, "C").getResult();
  19216. if (hashmap.size() == 0) {
  19217. cro.setV_errCode(2);
  19218. return cro;
  19219. }
  19220. QcmJudgePhysicalServiceImpl qjp = new QcmJudgePhysicalServiceImpl();
  19221. String assay_no1 = "";
  19222. if(status.equals("0")){
  19223. assay_no1 = "CF000";
  19224. }else if(status.equals("1")){
  19225. assay_no1 = "CY000";
  19226. }
  19227. //QcmJhySampleConsignD _consignD=new QcmJhySampleConsignD();
  19228. List<String> assay_no = GetAssay_no(heat_no,assay_no1);
  19229. if (assay_no.size() == 0) {
  19230. cro.setV_errCode(2);
  19231. return cro;
  19232. }
  19233. if (assay_no.size() > 1) {
  19234. cro.setV_errCode(2);
  19235. return cro;
  19236. }
  19237. CoreReturnObject cro = GetElementsInfo1(assay_no);
  19238. List<QcmJhyInspElements> listEle = (List<QcmJhyInspElements>) cro.getResult();
  19239. if (listEle.size() < 1) {
  19240. cro.setV_errCode(2);
  19241. return cro;
  19242. }
  19243. String result = "";
  19244. String[] orderno = design_key.split(",");
  19245. for (String x : orderno) {
  19246. if (result.equals("")) {
  19247. result = "('" + x + "'";
  19248. } else {
  19249. result = result + ",'" + x + "'";
  19250. }
  19251. }
  19252. if (result == "") {
  19253. result = "('')";
  19254. } else {
  19255. result = result + ")";
  19256. }
  19257. //查询判定标准,最后一个参数需要调用生产计划相关接口获取当前使用的制程号
  19258. CoreReturnObject cicModel = GetOrdJudgeStdCicLgR(result, grade_name, prodline);
  19259. OrdJudgeStd<QCMOrdDesignStdCic> stdCic = (OrdJudgeStd<QCMOrdDesignStdCic>) cicModel.getResult();
  19260. List<ArrayList> list = new ArrayList();
  19261. //开始判定:内控>客户>交付
  19262. boolean pass = true;
  19263. boolean pass1 = true;
  19264. if (stdCic.getListStdNK().size() == 0 || stdCic.getListStdLG().size() == 0) {
  19265. cro.setV_errCode(-1);
  19266. return cro;
  19267. }
  19268. if (stdCic.getListStdNK().size() > 0) {
  19269. pass1 = CompareResult(stdCic.getListStdNK(), listEle);
  19270. }
  19271. //判定客户、交付标准
  19272. if (pass) {
  19273. if (stdCic.getListStdKH() != null && pass) {
  19274. pass = CompareResult(stdCic.getListStdKH(), listEle);
  19275. memo = CompareResults(memo, stdCic.getListStdKH(), listEle);
  19276. list = CompareResultInfo(list, stdCic.getListStdKH(), listEle);
  19277. }
  19278. if (pass) {
  19279. pass = CompareResult(stdCic.getListStdGB(), listEle);
  19280. memo = CompareResults(memo, stdCic.getListStdGB(), listEle);
  19281. list = CompareResultInfo(list, stdCic.getListStdGB(), listEle);
  19282. if (pass) {
  19283. pass = CompareResult(stdCic.getListStdLG(), listEle);
  19284. memo = CompareResults(memo, stdCic.getListStdLG(), listEle);
  19285. list = CompareResultInfo(list, stdCic.getListStdLG(), listEle);
  19286. }
  19287. }
  19288. }
  19289. String proAssaynos = "", semiAssaynos = "";//成品化验号、熔炼化验号
  19290. for (QcmJhyInspElements qcmJhyElements : listEle) {
  19291. if (qcmJhyElements.getAssay_type().equals("L")) {
  19292. if (!semiAssaynos.contains(qcmJhyElements.getAssay_no())) {
  19293. semiAssaynos += "," + qcmJhyElements.getAssay_no();
  19294. }
  19295. } else {
  19296. if (!proAssaynos.contains(qcmJhyElements.getAssay_no())) {
  19297. proAssaynos += "," + qcmJhyElements.getAssay_no();
  19298. }
  19299. }
  19300. }
  19301. if(!pass){
  19302. cro.setV_errCode(2);
  19303. return cro;
  19304. }
  19305. cro.setV_errCode(1);
  19306. SqlSession.commit();
  19307. } catch (Exception ex) {
  19308. SqlSession.rollback();
  19309. cro.setV_errCode(2);
  19310. cro.setV_errMsg("检验失败!" + ex.getMessage());
  19311. }
  19312. SqlSession.close();
  19313. return cro;
  19314. }
  19315. /**
  19316. * 炼钢熔炼成分自动判定 0 复样 1.验样 2.复样+放行 3 验样+放行 4 改判+放行
  19317. */
  19318. @SuppressWarnings("unchecked")
  19319. public void LGRlChemJudgeBySystem(String heat_no, String material_no, String design_key, String username, String grade_name, String prod_name, String prodline,String status) throws Exception {
  19320. List<HashMap> hashmap = new ArrayList<HashMap>();
  19321. try {
  19322. String memo = "";
  19323. hashmap = (List<HashMap>) getLgRejudgeInfobyMaterial_no("", "", material_no, prodline, prod_name, "C").getResult();
  19324. if (hashmap.size() == 0) {
  19325. throw new Exception(material_no+"未找到待判数据或该数据已判!");
  19326. }
  19327. QcmJudgePhysicalServiceImpl qjp = new QcmJudgePhysicalServiceImpl();
  19328. String assay_no1 = "";
  19329. if(status.equals("0") || status.equals("2")){
  19330. assay_no1 = "CF000";
  19331. }else if(status.equals("1") || status.equals("3")){
  19332. assay_no1 = "CY000";
  19333. }
  19334. //QcmJhySampleConsignD _consignD=new QcmJhySampleConsignD();
  19335. List<String> assay_no = GetAssay_no(heat_no,assay_no1);
  19336. if (assay_no.size() == 0) {
  19337. return;
  19338. }
  19339. if (assay_no.size() > 1) {
  19340. return;
  19341. }
  19342. CoreReturnObject cro = GetElementsInfo1(assay_no);
  19343. List<QcmJhyInspElements> listEle = (List<QcmJhyInspElements>) cro.getResult();
  19344. if (listEle.size() < 1) {
  19345. return;
  19346. }
  19347. String result = "";
  19348. if(design_key != null)
  19349. {
  19350. String[] orderno = design_key.split(",");
  19351. for (String x : orderno) {
  19352. if (result.equals("")) {
  19353. result = "('" + x + "'";
  19354. } else {
  19355. result = result + ",'" + x + "'";
  19356. }
  19357. }
  19358. if (result == "") {
  19359. result = "('')";
  19360. } else {
  19361. result = result + ")";
  19362. }
  19363. }else
  19364. {
  19365. result = "('')";
  19366. }
  19367. //查询判定标准,最后一个参数需要调用生产计划相关接口获取当前使用的制程号
  19368. CoreReturnObject cicModel = GetOrdJudgeStdCicLgR(result, grade_name, prodline);
  19369. OrdJudgeStd<QCMOrdDesignStdCic> stdCic = (OrdJudgeStd<QCMOrdDesignStdCic>) cicModel.getResult();
  19370. List<ArrayList> list = new ArrayList();
  19371. //开始判定:内控>客户>交付
  19372. boolean pass = true;
  19373. boolean pass1 = true;
  19374. if (stdCic.getListStdNK().size() == 0 || stdCic.getListStdLG().size() == 0) {
  19375. return;
  19376. }
  19377. if (stdCic.getListStdNK().size() > 0) {
  19378. pass1 = CompareResult(stdCic.getListStdNK(), listEle);
  19379. }
  19380. //判定客户、交付标准
  19381. if (pass) {
  19382. if (stdCic.getListStdKH() != null && pass) {
  19383. pass = CompareResult(stdCic.getListStdKH(), listEle);
  19384. memo = CompareResults(memo, stdCic.getListStdKH(), listEle);
  19385. list = CompareResultInfo(list, stdCic.getListStdKH(), listEle);
  19386. }
  19387. if (pass) {
  19388. pass = CompareResult(stdCic.getListStdGB(), listEle);
  19389. memo = CompareResults(memo, stdCic.getListStdGB(), listEle);
  19390. list = CompareResultInfo(list, stdCic.getListStdGB(), listEle);
  19391. if (pass) {
  19392. pass = CompareResult(stdCic.getListStdLG(), listEle);
  19393. memo = CompareResults(memo, stdCic.getListStdLG(), listEle);
  19394. list = CompareResultInfo(list, stdCic.getListStdLG(), listEle);
  19395. }
  19396. }
  19397. }
  19398. String proAssaynos = "", semiAssaynos = "";//成品化验号、熔炼化验号
  19399. for (QcmJhyInspElements qcmJhyElements : listEle) {
  19400. if (qcmJhyElements.getAssay_type().equals("L")) {
  19401. if (!semiAssaynos.contains(qcmJhyElements.getAssay_no())) {
  19402. semiAssaynos += "," + qcmJhyElements.getAssay_no();
  19403. }
  19404. } else {
  19405. if (!proAssaynos.contains(qcmJhyElements.getAssay_no())) {
  19406. proAssaynos += "," + qcmJhyElements.getAssay_no();
  19407. }
  19408. }
  19409. }
  19410. for (HashMap listh : hashmap) {
  19411. QcmJudgeChemical judge = new QcmJudgeChemical();
  19412. int count = 0;
  19413. SimpleDateFormat sdf = new SimpleDateFormat("yyMMdd");
  19414. String date = sdf.format(new Date());
  19415. // 获取材质结果集编号最大值
  19416. List<QcmJudgeChemical> qrlist = mapper.QueryQcmJudgeChemicals("R" + date);
  19417. if (qrlist != null && qrlist.size() > 0) {
  19418. String s = qrlist.get(0).getCic_id();
  19419. count = Integer.parseInt(s.substring(s.length() - 4, s.length()));
  19420. }
  19421. count++;
  19422. String cic_id = "R" + sdf.format(new Date()) + String.format("%04d", count);
  19423. String cic_memo = "";
  19424. if (username.equals("system")) {
  19425. cic_memo = "系统自动判定";
  19426. } else {
  19427. cic_memo = "人工判定";
  19428. }
  19429. judge.setCic_id(cic_id);
  19430. judge.setAssay_no_cp(proAssaynos.replaceFirst(",", ""));
  19431. judge.setAssay_no_rl(semiAssaynos.replaceFirst(",", ""));
  19432. judge.setBatch_no(listh.get("MATERIAL_NO") == null ? "" : listh.get("MATERIAL_NO").toString());
  19433. judge.setHeat_no(heat_no);
  19434. judge.setCic_memo(cic_memo);
  19435. judge.setCic_result_code(pass ? "1" : "2");
  19436. judge.setCic_result_desc(pass ? "合格" : "不合格");
  19437. judge.setDesign_key(design_key);
  19438. judge.setHeat_no(heat_no);
  19439. judge.setInspection_lot("");
  19440. judge.setProd_name(prod_name);
  19441. judge.setMaterial_no(listh.get("MATERIAL_NO") == null ? "" : listh.get("MATERIAL_NO").toString());
  19442. judge.setDelivery_state_code("");
  19443. judge.setDelivery_state_desc(listh.get("DELIVERY_STATE_DESC") == null ? "" : listh.get("DELIVERY_STATE_DESC").toString());
  19444. judge.setThick(listh.get("THICK") == null ? "" : listh.get("THICK").toString());
  19445. judge.setWidth(listh.get("WIDTH") == null ? "" : listh.get("WIDTH").toString());
  19446. judge.setLength(listh.get("LENGTH") == null ? "" : listh.get("LENGTH").toString());
  19447. judge.setJudge_name(username);
  19448. judge.setJudge_ttime(new Date());
  19449. judge.setGrade_code("");
  19450. judge.setGrade_name(listh.get("GRADE_NAME") == null ? "" : listh.get("GRADE_NAME").toString());
  19451. judge.setPline_code(listh.get("PLINE_CODE") == null ? "" : listh.get("PLINE_CODE").toString());
  19452. judge.setPline_name(listh.get("PLINE_NAME") == null ? "" : listh.get("PLINE_NAME").toString());
  19453. judge.setPsc("");
  19454. judge.setPsc_desc("");
  19455. judge.setSteel_code("");
  19456. judge.setSteel_name("");
  19457. judge.setSmp_no("");
  19458. judge.setBoard_no("");
  19459. judge.setStd_code("");
  19460. judge.setStd_name(listh.get("STD_NAME") == null ? "" : listh.get("STD_NAME").toString());
  19461. //插入成分判定表
  19462. mapper.insertqcmjudgechemcial(judge);
  19463. if (!pass) {
  19464. QCMJudgeLocking qjb = new QCMJudgeLocking();
  19465. count = 0;
  19466. String condition = " and MATERIAL_NO = '" + listh.get("MATERIAL_NO").toString() + "' order by LOCK_SEQ desc ";
  19467. List<QCMJudgeLocking> qjl = mapper.queryQCMJudgeLocking(condition);
  19468. if (qjl.size() > 0) {
  19469. count = qjl.get(0).getLock_seq();
  19470. }
  19471. count++;
  19472. //锁定记录号
  19473. int lock_seq = count;
  19474. qjb.setMaterial_no(listh.get("MATERIAL_NO").toString());
  19475. qjb.setLock_type_code("C");
  19476. qjb.setLock_id(cic_id);
  19477. qjb.setLock_type_desc("成分判定");
  19478. qjb.setLock_seq(lock_seq);
  19479. qjb.setLock_memo(memo);
  19480. /*if (design_key.equals("")) {
  19481. qjb.setLock_memo("无订单");
  19482. }
  19483. */ qjb.setBoard_no(listh.get("MATERIAL_NO").toString());
  19484. qjb.setPline_code("");
  19485. qjb.setPline_name("");
  19486. qjb.setLock_name(username.equals("system") ? "系统自动判定" : username);
  19487. qjb.setCic_locking("1");
  19488. qjb.setLock_time(new Date());
  19489. qjb.setHeat_no(hashmap.get(0).get("HEAT_NO") == null ? "" : hashmap.get(0).get("HEAT_NO").toString());
  19490. qjb.setBatch_no(hashmap.get(0).get("MATERIAL_NO") == null ? "" : hashmap.get(0).get("MATERIAL_NO").toString());
  19491. qjb.setBoard_no("");
  19492. qjb.setPlan_no("");
  19493. qjb.setHt_no("");
  19494. qjb.setDesign_key(hashmap.get(0).get("DESIGN_KEY").toString());
  19495. qjb.setPsc("");
  19496. qjb.setPline_code(hashmap.get(0).get("PLINE_CODE").toString());
  19497. qjb.setPline_name(hashmap.get(0).get("PLINE_NAME").toString());
  19498. qjb.setPsc_desc("");
  19499. qjb.setStd_code(hashmap.get(0).get("STD_NAME").toString());
  19500. qjb.setStd_name(hashmap.get(0).get("STD_NAME").toString());
  19501. qjb.setProd_code("");
  19502. qjb.setProd_name(hashmap.get(0).get("PROD_NAME").toString());
  19503. qjb.setSteel_code(hashmap.get(0).get("GRADE_NAME").toString());
  19504. qjb.setSteel_name(hashmap.get(0).get("GRADE_NAME").toString());
  19505. if(status.equals("2")||status.equals("3")||status.equals("4")){
  19506. qjb.setUnlock_type_code("0");
  19507. qjb.setUnlock_type_desc("放行");
  19508. qjb.setUnlock_name(username);
  19509. qjb.setUnlock_time(new Date());
  19510. }
  19511. //插入异常锁定表
  19512. mapper.insertQCMJudgeLocking(qjb);
  19513. //List<QcmJudgeChemical> qjc = mapper.queryQcmJudgeChemical("select * from qcm_judge_chemical where material_no = '" + listh.get("MATERIAL_NO").toString() + "' order by JUDGE_TTIME desc");
  19514. int seq1 = 1;
  19515. //插入判定原因表
  19516. for (ArrayList listz : list) {
  19517. QcmJudgeUltimateReason qjr = new QcmJudgeUltimateReason();
  19518. qjr.setMaterial_no(listh.get("MATERIAL_NO").toString());
  19519. qjr.setType_code("C");
  19520. qjr.setRecord_id(cic_id);
  19521. qjr.setSeq(seq1);
  19522. qjr.setPhy_code_s(listz.get(0).toString());
  19523. qjr.setPhy_name_s(listz.get(1).equals("")?listz.get(0).toString():listz.get(1).toString());
  19524. qjr.setVal1(listz.get(2).toString());
  19525. qjr.setStdmax(listz.get(3) == null ? "" : listz.get(3).toString());
  19526. qjr.setStdmax_sign(listz.get(4) == null ? "" : listz.get(4).toString());
  19527. qjr.setStdmin(listz.get(5) == null ? "" : listz.get(5).toString());
  19528. qjr.setStdmin_sign(listz.get(6) == null ? "" : listz.get(6).toString());
  19529. qjr.setCreate_name(username);
  19530. qjr.setCreate_time(new Date());
  19531. seq1++;
  19532. mapper.insertQcmJudgeUltimateReason(qjr);
  19533. }
  19534. }
  19535. /*String z_result = "";
  19536. if(prodline.equals("4001LGX") && judge.getCic_result_code().equals("2")){
  19537. z_result = "8";
  19538. }*/
  19539. String is_fx ="";
  19540. //调用单项判定
  19541. JSONObject jsobj2 = new JSONObject();
  19542. JSONArray ttmaps = new JSONArray();
  19543. JSONObject jsobj1 = new JSONObject();
  19544. jsobj1.put("CHEMRESULT_LK", pass1 ? "1" : "2");
  19545. jsobj1.put("FACERESULT", "");
  19546. jsobj1.put("COMPREHENSIVERESULT", "");
  19547. jsobj1.put("CHEMJUDGEID", cic_id);
  19548. jsobj1.put("FACECHECKID", "");
  19549. jsobj1.put("COMPREHENSIVEID", "");
  19550. jsobj1.put("JUDGE_TYPE", "C");
  19551. jsobj1.put("PROD_LINE", prodline);
  19552. jsobj1.put("ISJUDGE", "1");
  19553. jsobj1.put("PROD_TYPE", prod_name);
  19554. jsobj1.put("SLAB_NO", material_no);
  19555. jsobj1.put("CHECKNO", assay_no.get(0).toString());
  19556. jsobj1.put("OPTMAN", username);
  19557. jsobj1.put("ISFX", ((status.equals("2")||status.equals("3")||status.equals("4")) && judge.getCic_result_code().equals("2"))?"1":"0");
  19558. jsobj1.put("CHEMRESULT_FX", (status.equals("2")||status.equals("3")||status.equals("4"))?"5":judge.getCic_result_code());
  19559. ttmaps.add(jsobj1);
  19560. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  19561. result = callWebserviceASMX(url, "ChemJudge", JSON.toJSONString(ttmaps));
  19562. JSONObject jo = JSONObject.parseObject(result);
  19563. if (jo.get("code").toString().equals("1")) {
  19564. throw new Exception("成分判定失败!");//
  19565. }
  19566. }
  19567. cro.setV_errCode(1);
  19568. SqlSession.commit();
  19569. if (pass) {
  19570. //调用综合判定
  19571. qjp.LgultimateJudgeAutoBySystem(material_no, username, prodline, prod_name);
  19572. }
  19573. } catch (Exception ex) {
  19574. SqlSession.rollback();
  19575. cro.setV_errCode(-1);
  19576. cro.setV_errMsg("判定失败!" + ex.getMessage());
  19577. }
  19578. SqlSession.close();
  19579. }
  19580. /**
  19581. * 炼钢熔炼成分自动判定 0 复样 1.验样 2.复样+放行 3 验样+放行 4 改判+放行
  19582. */
  19583. @SuppressWarnings("unchecked")
  19584. public void LGRlChemJudgeBySystem1(String heat_no, String material_no, String design_key, String username, String grade_name, String prod_name, String prodline,String assay_no) throws Exception {
  19585. List<HashMap> hashmap = new ArrayList<HashMap>();
  19586. try {
  19587. String memo = "";
  19588. hashmap = (List<HashMap>) getLgRejudgeInfobyMaterial_no("", "", material_no, prodline, prod_name, "C").getResult();
  19589. if (hashmap.size() == 0) {
  19590. throw new Exception(material_no+"未找到待判数据或该数据已判!");
  19591. }
  19592. QcmJudgePhysicalServiceImpl qjp = new QcmJudgePhysicalServiceImpl();
  19593. CoreReturnObject cro = GetElementsInfo1(assay_no);
  19594. List<QcmJhyInspElements> listEle = (List<QcmJhyInspElements>) cro.getResult();
  19595. if (listEle.size() < 1) {
  19596. return;
  19597. }
  19598. String result = "";
  19599. if(design_key != null)
  19600. {
  19601. String[] orderno = design_key.split(",");
  19602. for (String x : orderno) {
  19603. if (result.equals("")) {
  19604. result = "('" + x + "'";
  19605. } else {
  19606. result = result + ",'" + x + "'";
  19607. }
  19608. }
  19609. if (result == "") {
  19610. result = "('')";
  19611. } else {
  19612. result = result + ")";
  19613. }
  19614. }else
  19615. {
  19616. result = "('')";
  19617. }
  19618. //查询判定标准,最后一个参数需要调用生产计划相关接口获取当前使用的制程号
  19619. CoreReturnObject cicModel = GetOrdJudgeStdCicLgR(result, grade_name, prodline);
  19620. OrdJudgeStd<QCMOrdDesignStdCic> stdCic = (OrdJudgeStd<QCMOrdDesignStdCic>) cicModel.getResult();
  19621. List<ArrayList> list = new ArrayList();
  19622. //开始判定:内控>客户>交付
  19623. boolean pass = true;
  19624. boolean pass1 = true;
  19625. if (stdCic.getListStdNK().size() == 0 || stdCic.getListStdLG().size() == 0) {
  19626. return;
  19627. }
  19628. if (stdCic.getListStdNK().size() > 0) {
  19629. pass1 = CompareResult(stdCic.getListStdNK(), listEle);
  19630. }
  19631. //判定客户、交付标准
  19632. if (pass) {
  19633. if (stdCic.getListStdKH() != null && pass) {
  19634. pass = CompareResult(stdCic.getListStdKH(), listEle);
  19635. memo = CompareResults(memo, stdCic.getListStdKH(), listEle);
  19636. list = CompareResultInfo(list, stdCic.getListStdKH(), listEle);
  19637. }
  19638. if (pass) {
  19639. pass = CompareResult(stdCic.getListStdGB(), listEle);
  19640. memo = CompareResults(memo, stdCic.getListStdGB(), listEle);
  19641. list = CompareResultInfo(list, stdCic.getListStdGB(), listEle);
  19642. if (pass) {
  19643. pass = CompareResult(stdCic.getListStdLG(), listEle);
  19644. memo = CompareResults(memo, stdCic.getListStdLG(), listEle);
  19645. list = CompareResultInfo(list, stdCic.getListStdLG(), listEle);
  19646. }
  19647. }
  19648. }
  19649. String proAssaynos = "", semiAssaynos = "";//成品化验号、熔炼化验号
  19650. for (QcmJhyInspElements qcmJhyElements : listEle) {
  19651. if (qcmJhyElements.getAssay_type().equals("L")) {
  19652. if (!semiAssaynos.contains(qcmJhyElements.getAssay_no())) {
  19653. semiAssaynos += "," + qcmJhyElements.getAssay_no();
  19654. }
  19655. } else {
  19656. if (!proAssaynos.contains(qcmJhyElements.getAssay_no())) {
  19657. proAssaynos += "," + qcmJhyElements.getAssay_no();
  19658. }
  19659. }
  19660. }
  19661. for (HashMap listh : hashmap) {
  19662. QcmJudgeChemical judge = new QcmJudgeChemical();
  19663. int count = 0;
  19664. SimpleDateFormat sdf = new SimpleDateFormat("yyMMdd");
  19665. String date = sdf.format(new Date());
  19666. // 获取材质结果集编号最大值
  19667. List<QcmJudgeChemical> qrlist = mapper.QueryQcmJudgeChemicals("R" + date);
  19668. if (qrlist != null && qrlist.size() > 0) {
  19669. String s = qrlist.get(0).getCic_id();
  19670. count = Integer.parseInt(s.substring(s.length() - 4, s.length()));
  19671. }
  19672. count++;
  19673. String cic_id = "R" + sdf.format(new Date()) + String.format("%04d", count);
  19674. String cic_memo = "";
  19675. if (username.equals("system")) {
  19676. cic_memo = "系统自动判定";
  19677. } else {
  19678. cic_memo = "人工判定";
  19679. }
  19680. judge.setCic_id(cic_id);
  19681. judge.setAssay_no_cp(proAssaynos.replaceFirst(",", ""));
  19682. judge.setAssay_no_rl(semiAssaynos.replaceFirst(",", ""));
  19683. judge.setBatch_no(listh.get("MATERIAL_NO") == null ? "" : listh.get("MATERIAL_NO").toString());
  19684. judge.setHeat_no(heat_no);
  19685. judge.setCic_memo(cic_memo);
  19686. judge.setCic_result_code(pass ? "1" : "2");
  19687. judge.setCic_result_desc(pass ? "合格" : "不合格");
  19688. judge.setDesign_key(design_key);
  19689. judge.setHeat_no(heat_no);
  19690. judge.setInspection_lot("");
  19691. judge.setProd_name(prod_name);
  19692. judge.setMaterial_no(listh.get("MATERIAL_NO") == null ? "" : listh.get("MATERIAL_NO").toString());
  19693. judge.setDelivery_state_code("");
  19694. judge.setDelivery_state_desc(listh.get("DELIVERY_STATE_DESC") == null ? "" : listh.get("DELIVERY_STATE_DESC").toString());
  19695. judge.setThick(listh.get("THICK") == null ? "" : listh.get("THICK").toString());
  19696. judge.setWidth(listh.get("WIDTH") == null ? "" : listh.get("WIDTH").toString());
  19697. judge.setLength(listh.get("LENGTH") == null ? "" : listh.get("LENGTH").toString());
  19698. judge.setJudge_name(username);
  19699. judge.setJudge_ttime(new Date());
  19700. judge.setGrade_code("");
  19701. judge.setGrade_name(listh.get("GRADE_NAME") == null ? "" : listh.get("GRADE_NAME").toString());
  19702. judge.setPline_code(listh.get("PLINE_CODE") == null ? "" : listh.get("PLINE_CODE").toString());
  19703. judge.setPline_name(listh.get("PLINE_NAME") == null ? "" : listh.get("PLINE_NAME").toString());
  19704. judge.setPsc("");
  19705. judge.setPsc_desc("");
  19706. judge.setSteel_code("");
  19707. judge.setSteel_name("");
  19708. judge.setSmp_no("");
  19709. judge.setBoard_no("");
  19710. judge.setStd_code("");
  19711. judge.setStd_name(listh.get("STD_NAME") == null ? "" : listh.get("STD_NAME").toString());
  19712. //插入成分判定表
  19713. mapper.insertqcmjudgechemcial(judge);
  19714. if (!pass) {
  19715. QCMJudgeLocking qjb = new QCMJudgeLocking();
  19716. count = 0;
  19717. String condition = " and MATERIAL_NO = '" + listh.get("MATERIAL_NO").toString() + "' order by LOCK_SEQ desc ";
  19718. List<QCMJudgeLocking> qjl = mapper.queryQCMJudgeLocking(condition);
  19719. if (qjl.size() > 0) {
  19720. count = qjl.get(0).getLock_seq();
  19721. }
  19722. count++;
  19723. //锁定记录号
  19724. int lock_seq = count;
  19725. qjb.setMaterial_no(listh.get("MATERIAL_NO").toString());
  19726. qjb.setLock_type_code("C");
  19727. qjb.setLock_id(cic_id);
  19728. qjb.setLock_type_desc("成分判定");
  19729. qjb.setLock_seq(lock_seq);
  19730. qjb.setLock_memo(memo);
  19731. /*if (design_key.equals("")) {
  19732. qjb.setLock_memo("无订单");
  19733. }
  19734. */ qjb.setBoard_no(listh.get("MATERIAL_NO").toString());
  19735. qjb.setPline_code("");
  19736. qjb.setPline_name("");
  19737. qjb.setLock_name(username.equals("system") ? "系统自动判定" : username);
  19738. qjb.setCic_locking("1");
  19739. qjb.setLock_time(new Date());
  19740. qjb.setHeat_no(hashmap.get(0).get("HEAT_NO") == null ? "" : hashmap.get(0).get("HEAT_NO").toString());
  19741. qjb.setBatch_no(hashmap.get(0).get("MATERIAL_NO") == null ? "" : hashmap.get(0).get("MATERIAL_NO").toString());
  19742. qjb.setBoard_no("");
  19743. qjb.setPlan_no("");
  19744. qjb.setHt_no("");
  19745. qjb.setDesign_key(hashmap.get(0).get("DESIGN_KEY").toString());
  19746. qjb.setPsc("");
  19747. qjb.setPline_code(hashmap.get(0).get("PLINE_CODE").toString());
  19748. qjb.setPline_name(hashmap.get(0).get("PLINE_NAME").toString());
  19749. qjb.setPsc_desc("");
  19750. qjb.setStd_code(hashmap.get(0).get("STD_NAME").toString());
  19751. qjb.setStd_name(hashmap.get(0).get("STD_NAME").toString());
  19752. qjb.setProd_code("");
  19753. qjb.setProd_name(hashmap.get(0).get("PROD_NAME").toString());
  19754. qjb.setSteel_code(hashmap.get(0).get("GRADE_NAME").toString());
  19755. qjb.setSteel_name(hashmap.get(0).get("GRADE_NAME").toString());
  19756. qjb.setUnlock_type_code("0");
  19757. qjb.setUnlock_type_desc("放行");
  19758. qjb.setUnlock_name(username);
  19759. qjb.setUnlock_time(new Date());
  19760. //插入异常锁定表
  19761. mapper.insertQCMJudgeLocking(qjb);
  19762. //List<QcmJudgeChemical> qjc = mapper.queryQcmJudgeChemical("select * from qcm_judge_chemical where material_no = '" + listh.get("MATERIAL_NO").toString() + "' order by JUDGE_TTIME desc");
  19763. int seq1 = 1;
  19764. //插入判定原因表
  19765. for (ArrayList listz : list) {
  19766. QcmJudgeUltimateReason qjr = new QcmJudgeUltimateReason();
  19767. qjr.setMaterial_no(listh.get("MATERIAL_NO").toString());
  19768. qjr.setType_code("C");
  19769. qjr.setRecord_id(cic_id);
  19770. qjr.setSeq(seq1);
  19771. qjr.setPhy_code_s(listz.get(0).toString());
  19772. qjr.setPhy_name_s(listz.get(1).equals("")?listz.get(0).toString():listz.get(1).toString());
  19773. qjr.setVal1(listz.get(2).toString());
  19774. qjr.setStdmax(listz.get(3) == null ? "" : listz.get(3).toString());
  19775. qjr.setStdmax_sign(listz.get(4) == null ? "" : listz.get(4).toString());
  19776. qjr.setStdmin(listz.get(5) == null ? "" : listz.get(5).toString());
  19777. qjr.setStdmin_sign(listz.get(6) == null ? "" : listz.get(6).toString());
  19778. qjr.setCreate_name(username);
  19779. qjr.setCreate_time(new Date());
  19780. seq1++;
  19781. mapper.insertQcmJudgeUltimateReason(qjr);
  19782. }
  19783. }
  19784. /*String z_result = "";
  19785. if(prodline.equals("4001LGX") && judge.getCic_result_code().equals("2")){
  19786. z_result = "8";
  19787. }*/
  19788. String is_fx ="";
  19789. //调用单项判定
  19790. JSONObject jsobj2 = new JSONObject();
  19791. JSONArray ttmaps = new JSONArray();
  19792. JSONObject jsobj1 = new JSONObject();
  19793. jsobj1.put("CHEMRESULT_LK", pass1 ? "1" : "2");
  19794. jsobj1.put("FACERESULT", "");
  19795. jsobj1.put("COMPREHENSIVERESULT", "");
  19796. jsobj1.put("CHEMJUDGEID", cic_id);
  19797. jsobj1.put("FACECHECKID", "");
  19798. jsobj1.put("COMPREHENSIVEID", "");
  19799. jsobj1.put("JUDGE_TYPE", "C");
  19800. jsobj1.put("PROD_LINE", prodline);
  19801. jsobj1.put("ISJUDGE", "1");
  19802. jsobj1.put("PROD_TYPE", prod_name);
  19803. jsobj1.put("SLAB_NO", material_no);
  19804. jsobj1.put("CHECKNO", assay_no);
  19805. jsobj1.put("OPTMAN", username);
  19806. jsobj1.put("ISFX", "1");
  19807. jsobj1.put("CHEMRESULT_FX","5");
  19808. ttmaps.add(jsobj1);
  19809. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  19810. result = callWebserviceASMX(url, "ChemJudge", JSON.toJSONString(ttmaps));
  19811. JSONObject jo = JSONObject.parseObject(result);
  19812. if (jo.get("code").toString().equals("1")) {
  19813. throw new Exception("成分判定失败!");//
  19814. }
  19815. }
  19816. cro.setV_errCode(1);
  19817. SqlSession.commit();
  19818. if (pass) {
  19819. //调用综合判定
  19820. qjp.LgultimateJudgeAutoBySystem(material_no, username, prodline, prod_name);
  19821. }
  19822. } catch (Exception ex) {
  19823. SqlSession.rollback();
  19824. cro.setV_errCode(-1);
  19825. cro.setV_errMsg("判定失败!" + ex.getMessage());
  19826. }
  19827. SqlSession.close();
  19828. }
  19829. public static String callWebserviceASMX(String url, String method, String json) throws Exception {
  19830. System.out.println("Start invoking....");
  19831. String str = "";
  19832. try {
  19833. String endPoint = url;
  19834. String soapaction = "http://dao.hnshituo.com/";
  19835. Service service = new Service();
  19836. Call call = (Call) service.createCall();
  19837. call.setTargetEndpointAddress(new java.net.URL(endPoint));
  19838. call.setOperation(method);
  19839. call.setUseSOAPAction(true);
  19840. call.setSOAPActionURI(soapaction + method);
  19841. call.setOperationName(new QName(soapaction, method));
  19842. call.addParameter("arg0", org.apache.axis.encoding.XMLType.XSD_STRING, ParameterMode.IN);
  19843. call.setReturnType(org.apache.axis.encoding.XMLType.XSD_STRING);
  19844. str = (String) call.invoke(new Object[]{json});
  19845. System.out.println(str);
  19846. } catch (Exception e) {
  19847. throw new Exception(e.getMessage());
  19848. }
  19849. return str;
  19850. }
  19851. //中厚板表面检验
  19852. private void bmjy(String aPreBH,String aCBID,String aJudgeType, String aGZLB, String aGYLB,String aXGLB,String aJudgeSteelName, String aJudgePurposeID , String aJudgeStandNo, String aRecorder , String aSquadOrder, String aSquadName, String aMemo, String aZYDW) throws java.lang.Exception
  19853. {
  19854. Connection conn = null;
  19855. CallableStatement cstmt = null;
  19856. ResultSet rs = null;
  19857. try {
  19858. conn = SqlSession.getConnection();
  19859. String callSql = "{call GETJHTOMESPLAN.GET_BMJL@xgcx(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) }";
  19860. cstmt = conn.prepareCall(callSql);
  19861. cstmt.setString(1, aPreBH);
  19862. cstmt.setString(2, aCBID);
  19863. cstmt.setString(3, aJudgeType);
  19864. cstmt.setString(4, aGZLB);
  19865. cstmt.setString(5, aGYLB);
  19866. cstmt.setString(6, aXGLB);
  19867. cstmt.setString(7, aJudgeSteelName);
  19868. cstmt.setString(8, aJudgePurposeID);
  19869. cstmt.setString(9, aJudgeStandNo);
  19870. cstmt.setString(10, aRecorder);
  19871. cstmt.setString(11, aSquadOrder);
  19872. cstmt.setString(12, aSquadName);
  19873. cstmt.setString(13, aMemo);
  19874. cstmt.setString(14, aZYDW);
  19875. cstmt.registerOutParameter(15, java.sql.Types.INTEGER);
  19876. cstmt.registerOutParameter(16, java.sql.Types.VARCHAR);
  19877. cstmt.execute();
  19878. if(cstmt.getString(15) != null){
  19879. if(cstmt.getString(15).equals("0")){
  19880. throw new java.lang.Exception("["+ aCBID + "]" + " 调用接口失败: + "+cstmt.getString(16).toString()+"");
  19881. }
  19882. }
  19883. } catch (Exception e) {
  19884. throw new Exception(e.getMessage());
  19885. } finally {
  19886. try {
  19887. if (rs != null) {
  19888. rs.close();
  19889. }
  19890. } catch (Exception e) {
  19891. throw new Exception(e.getMessage());
  19892. }
  19893. try {
  19894. if (cstmt != null) {
  19895. cstmt.close();
  19896. }
  19897. } catch (Exception e) {
  19898. throw new Exception(e.getMessage());
  19899. }
  19900. }
  19901. }
  19902. /**
  19903. * 查询炼钢成分判定信息
  19904. */
  19905. @SuppressWarnings({"unused", "unchecked"})
  19906. public CoreReturnObject getLgjudgeInfobyMaterial_no1(String begintime, String endtime, String heatno, String prodline, String prod_type, String judge_type) {
  19907. try {
  19908. JSONObject jsobj2 = new JSONObject();
  19909. JSONArray ttmaps = new JSONArray();
  19910. JSONObject jsobj1 = new JSONObject();
  19911. jsobj1.put("START_TIME", begintime);
  19912. jsobj1.put("END_TIME", endtime);
  19913. jsobj1.put("HEAT_NO", heatno == null ? "" : heatno);
  19914. jsobj1.put("PROD_LINE", prodline);
  19915. jsobj1.put("PROD_TYPE", prod_type);
  19916. jsobj1.put("JUDGE_TYPE", judge_type);
  19917. jsobj1.put("ISJUDGE", "1");
  19918. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  19919. String result = callWebserviceASMX(url, "GetBilletInfoByBilletNo", JSON.toJSONString(jsobj1));
  19920. if (result.contains("DATA")) {
  19921. JSONObject jo = JSONObject.parseObject(result);
  19922. JSONArray ja = jo.getJSONArray("DATA");
  19923. List<HashMap> listqjb = new ArrayList<HashMap>();
  19924. for (int i = 0; i < ja.size(); i++) {
  19925. HashMap lists = new HashMap();
  19926. lists.put("heat_no", ja.getJSONObject(i).getString("HEATNO"));
  19927. lists.put("material_no", ja.getJSONObject(i).getString("BILLETNO"));
  19928. lists.put("grade_name", ja.getJSONObject(i).getString("STEELCODE"));
  19929. lists.put("prod_name", ja.getJSONObject(i).getString("PRODNAME"));
  19930. lists.put("delivery_state_desc", ja.getJSONObject(i).getString("STATUS"));
  19931. //lists.put("weight", ja.getJSONObject(i).getString("WEIGHT"));
  19932. lists.put("thick", ja.getJSONObject(i).getString("THICK"));
  19933. lists.put("length", ja.getJSONObject(i).getString("LENGTH"));
  19934. lists.put("width", ja.getJSONObject(i).getString("WIDTH"));
  19935. lists.put("judge_ttime", ja.getJSONObject(i).getString("CUTSTARTTIME"));
  19936. lists.put("design_key", ja.getJSONObject(i).getString("ORDERNO"));
  19937. lists.put("pline_code", ja.getJSONObject(i).getString("PROD_CODE"));
  19938. lists.put("pline_name", ja.getJSONObject(i).getString("PROD_NAME"));
  19939. lists.put("std_name", ja.getJSONObject(i).getString("USEDSTAND"));
  19940. lists.put("weight", ja.getJSONObject(i).getString("WEIGHT"));
  19941. lists.put("cic_id", ja.getJSONObject(i).getString("CHEMJUDGEID"));
  19942. lists.put("prod_thick", ja.getJSONObject(i).getString("PROD_THK"));
  19943. lists.put("prod_width", ja.getJSONObject(i).getString("PROD_WTH"));
  19944. lists.put("PLANSTEEL", ja.getJSONObject(i).getString("PLANSTEEL"));
  19945. lists.put("COMPREHENSIVEID", ja.getJSONObject(i).getString("COMPREHENSIVEID"));
  19946. lists.put("FACECHECKID", ja.getJSONObject(i).getString("FACECHECKID"));
  19947. lists.put("CHEMJUDGEID", ja.getJSONObject(i).getString("CHEMJUDGEID"));
  19948. lists.put("SC_MEMO", ja.getJSONObject(i).getString("SC_MEMO"));
  19949. lists.put("RATIFFLAG",ja.getJSONObject(i).getString("RATIFFLAG"));
  19950. lists.put("RATIFYQ", ja.getJSONObject(i).getString("RATIFYQ"));
  19951. lists.put("cic_result_desc", ja.getJSONObject(i).getString("CHEMRESULT_FX").equals("1") ? "合格" : (ja.getJSONObject(i).getString("CHEMRESULT_FX").equals("2") ? "不合格" : (ja.getJSONObject(i).getString("CHEMRESULT_FX").equals("3") ? "判次" : (ja.getJSONObject(i).getString("CHEMRESULT_FX").equals("3") ? "判废" : ""))));
  19952. /*List<QcmJudgeChemical> qjc = mapper.queryQcmJudgeChemical("select * from qcm_judge_chemical where cic_id = '"+ja.getJSONObject(i).getString("CHEMJUDGEID")+"'");
  19953. if(qjc.size() >0){
  19954. lists.put("judge_name", qjc.get(0).getJudge_name());
  19955. }else{
  19956. cro.setResult(listqjb);
  19957. return cro;
  19958. }*/
  19959. lists.put("isfx", ja.getJSONObject(i).getString("ISFX"));
  19960. String mome = mapper.GetLGMemo(ja.getJSONObject(i).getString("ORDERNO"));
  19961. lists.put("MEMO", mome);
  19962. listqjb.add(lists);
  19963. }
  19964. cro.setResult(listqjb);
  19965. }
  19966. } catch (Exception ex) {
  19967. cro.setV_errCode(-1);
  19968. cro.setV_errMsg("获取成分待判信息错误" + ex.getMessage());
  19969. SqlSession.rollback();
  19970. }
  19971. return cro;
  19972. }
  19973. /**
  19974. * 获取熔炼成分判定标准(交付/客户/内控)
  19975. *
  19976. * @param designKey
  19977. * @param psc 产品码
  19978. * @param plineCode 产线编号
  19979. * @param mscPline 制程号
  19980. * @return
  19981. */
  19982. public CoreReturnObject GetOrdJudgeStdCicLgR(String designKey, String grade_name, String prodline) {
  19983. try {
  19984. /*String sql = "select * from qcm_ord_design_std where design_key = '"+designKey+"' and psc = '"+psc+"'";
  19985. List<QCMOrdDesignStd> _designStd=mapper.queryQCMOrdDesignStd(sql);
  19986. if(SqlJoint.IsNullOrSpace(_designStd.get(0).getCic())){
  19987. cro.setV_errCode(-1);
  19988. cro.setV_errMsg("成分索引号不能为空");
  19989. return cro;
  19990. }*/
  19991. String pl = "";
  19992. if (prodline.equals("4001LG0")) {
  19993. pl = "LG1";
  19994. } else {
  19995. pl = "LG2";
  19996. }
  19997. OrdJudgeStd<QCMOrdDesignStdCic> stdCic = new OrdJudgeStd<QCMOrdDesignStdCic>();
  19998. //交付标准.
  19999. String condition = "";
  20000. String sql = "select * from QCM_ORD_DESIGN_STD_CIC where 1=1";
  20001. condition = " and SPECL_FL = '0'" + " and STD_TYPE_CODE = 'A' And DESIGN_KEY in " + designKey + " and pline_code = '" + pl + "'";
  20002. List<QCMOrdDesignStdCic> listStdGB = mapper.queryQCMOrdDesignStdCic(sql + condition);
  20003. stdCic.setListStdGB(listStdGB);
  20004. //客户标准
  20005. condition = " and SPECL_FL = '1'" + " and STD_TYPE_CODE = 'A' And DESIGN_KEY in " + designKey + " and pline_code = '" + pl + "'";
  20006. List<QCMOrdDesignStdCic> listStdKH = mapper.queryQCMOrdDesignStdCic(sql + condition);
  20007. stdCic.setListStdKH(listStdKH);
  20008. //内控标准
  20009. /*List<QCMOrdDesignStdCic> listStdNK = new ArrayList<QCMOrdDesignStdCic>();
  20010. sql = "select * from QCM_ORD_DESIGN_MSC_INNERCRAFT a where a.grade_name = '"+grade_name+"'";
  20011. List<HashMap> list = mapper.query(sql);
  20012. if(list.size() > 0){
  20013. for(HashMap list1:list){
  20014. QCMOrdDesignStdCic cic = new QCMOrdDesignStdCic();
  20015. cic.setChem_code(list1.get("ELEMENT")==null?"":list1.get("ELEMENT").toString());
  20016. cic.setChem_name(list1.get("ELEMENT")==null?"":list1.get("ELEMENT").toString());
  20017. cic.setStdmax(list1.get("MAX_VALUE")==null?null:list1.get("MAX_VALUE").toString());
  20018. cic.setStdmax_sign(list1.get("STDMAX_SIGN")==null?null:list1.get("STDMAX_SIGN").toString());
  20019. cic.setStdmin(list1.get("MIN_VALUE")==null?null:list1.get("MIN_VALUE").toString());
  20020. cic.setStdmin_sign(list1.get("STDMIN_SIGN")==null?null:list1.get("STDMIN_SIGN").toString());
  20021. cic.setIscheck(list1.get("ISCHECK")==null?"":list1.get("ISCHECK").toString());
  20022. cic.setIsjudge(list1.get("ISJUDGE")==null?"":list1.get("ISJUDGE").toString());
  20023. cic.setChem_formula(list1.get("CHEM_FORMULA")==null?"":list1.get("CHEM_FORMULA").toString());
  20024. cic.setChem_type(list1.get("CHEM_TYPE")==null?"":list1.get("CHEM_TYPE").toString());
  20025. listStdNK.add(cic);
  20026. }
  20027. }
  20028. stdCic.setListStdNK(listStdNK);*/
  20029. condition = " and SPECL_FL = '2'" + " and STD_TYPE_CODE = 'A' And DESIGN_KEY in " + designKey + " ";//and pline_code = '"+pl+"'
  20030. List<QCMOrdDesignStdCic> listStdNK = mapper.queryQCMOrdDesignStdCic(sql + condition);
  20031. if (listStdNK.size() == 0 || grade_name.startsWith("LQ")) {
  20032. listStdNK = new ArrayList<QCMOrdDesignStdCic>();
  20033. String sqls = "select * from QCM_ORD_DESIGN_MSC_INNERCRAFT a where a.grade_name = '" + grade_name + "'";
  20034. List<HashMap> list = mapper.query(sqls);
  20035. if (list.size() > 0) {
  20036. for (HashMap list1 : list) {
  20037. QCMOrdDesignStdCic cic = new QCMOrdDesignStdCic();
  20038. cic.setChem_code(list1.get("ELEMENT") == null ? "" : list1.get("ELEMENT").toString());
  20039. cic.setChem_name(list1.get("ELEMENT") == null ? "" : list1.get("ELEMENT").toString());
  20040. cic.setStdmax(list1.get("MAX_VALUE") == null ? null : list1.get("MAX_VALUE").toString());
  20041. cic.setStdmax_sign(list1.get("STDMAX_SIGN") == null ? null : list1.get("STDMAX_SIGN").toString());
  20042. cic.setStdmin(list1.get("MIN_VALUE") == null ? null : list1.get("MIN_VALUE").toString());
  20043. cic.setStdmin_sign(list1.get("STDMIN_SIGN") == null ? null : list1.get("STDMIN_SIGN").toString());
  20044. cic.setIscheck(list1.get("ISCHECK") == null ? "" : list1.get("ISCHECK").toString());
  20045. cic.setIsjudge(list1.get("ISJUDGE") == null ? "" : list1.get("ISJUDGE").toString());
  20046. cic.setChem_formula(list1.get("CHEM_FORMULA") == null ? "" : list1.get("CHEM_FORMULA").toString());
  20047. cic.setChem_type(list1.get("CHEM_TYPE") == null ? "" : list1.get("CHEM_TYPE").toString());
  20048. listStdNK.add(cic);
  20049. }
  20050. }
  20051. }
  20052. stdCic.setListStdNK(listStdNK);
  20053. //炼钢放行
  20054. condition = " and SPECL_FL = '3'" + " and STD_TYPE_CODE = 'A' And DESIGN_KEY in " + designKey + " ";//and pline_code = '"+pl+"'
  20055. List<QCMOrdDesignStdCic> listStdLG = mapper.queryQCMOrdDesignStdCic(sql + condition);
  20056. if (listStdLG.size() == 0 || grade_name.startsWith("LQ")) {
  20057. listStdLG = new ArrayList<QCMOrdDesignStdCic>();
  20058. String sqls = "select * from QCM_ORD_DESIGN_GRADE_CHEM a where a.grade_desc = '" + grade_name + "' and VALIDFLAG = '1'";
  20059. List<HashMap> list = mapper.query(sqls);
  20060. if (list.size() > 0) {
  20061. for (HashMap list1 : list) {
  20062. QCMOrdDesignStdCic cic = new QCMOrdDesignStdCic();
  20063. cic.setChem_code(list1.get("CHEM_CODE") == null ? "" : list1.get("CHEM_CODE").toString());
  20064. cic.setChem_name(list1.get("CHEM_NAME") == null ? "" : list1.get("CHEM_NAME").toString());
  20065. cic.setStdmax(list1.get("STDMAX") == null ? null : list1.get("STDMAX").toString());
  20066. cic.setStdmax_sign(list1.get("STDMAX_SIGN") == null ? null : list1.get("STDMAX_SIGN").toString());
  20067. cic.setStdmin(list1.get("STDMIN") == null ? null : list1.get("STDMIN").toString());
  20068. cic.setStdmin_sign(list1.get("STDMIN_SIGN") == null ? null : list1.get("STDMIN_SIGN").toString());
  20069. cic.setIscheck(list1.get("ISCHECK") == null ? "" : list1.get("ISCHECK").toString());
  20070. cic.setIsjudge(list1.get("ISJUDGE") == null ? "" : list1.get("ISJUDGE").toString());
  20071. cic.setChem_formula(list1.get("CHEM_FORMULA") == null ? "" : list1.get("CHEM_FORMULA").toString());
  20072. cic.setChem_type(list1.get("CHEM_TYPE") == null ? "" : list1.get("CHEM_TYPE").toString());
  20073. listStdLG.add(cic);
  20074. }
  20075. }
  20076. }
  20077. stdCic.setListStdLG(listStdLG);
  20078. /*List<QCMOrdDesignStdCic> listStdLG = new ArrayList<QCMOrdDesignStdCic>();
  20079. sql = "select * from QCM_ORD_DESIGN_GRADE_CHEM a where a.grade_desc = '"+grade_name+"' and VALIDFLAG = '1'";
  20080. list = mapper.query(sql);
  20081. if(list.size() > 0){
  20082. for(HashMap list1:list){
  20083. QCMOrdDesignStdCic cic = new QCMOrdDesignStdCic();
  20084. cic.setChem_code(list1.get("CHEM_CODE")==null?"":list1.get("CHEM_CODE").toString());
  20085. cic.setChem_name(list1.get("CHEM_NAME")==null?"":list1.get("CHEM_NAME").toString());
  20086. cic.setStdmax(list1.get("STDMAX")==null?null:list1.get("STDMAX").toString());
  20087. cic.setStdmax_sign(list1.get("STDMAX_SIGN")==null?null:list1.get("STDMAX_SIGN").toString());
  20088. cic.setStdmin(list1.get("STDMIN")==null?null:list1.get("STDMIN").toString());
  20089. cic.setStdmin_sign(list1.get("STDMIN_SIGN")==null?null:list1.get("STDMIN_SIGN").toString());
  20090. cic.setIscheck(list1.get("ISCHECK")==null?"":list1.get("ISCHECK").toString());
  20091. cic.setIsjudge(list1.get("ISJUDGE")==null?"":list1.get("ISJUDGE").toString());
  20092. cic.setChem_formula(list1.get("CHEM_FORMULA")==null?"":list1.get("CHEM_FORMULA").toString());
  20093. cic.setChem_type(list1.get("CHEM_TYPE")==null?"":list1.get("CHEM_TYPE").toString());
  20094. listStdLG.add(cic);
  20095. }
  20096. }
  20097. stdCic.setListStdLG(listStdLG);*/
  20098. //炼钢牌号
  20099. cro.setResult(stdCic);
  20100. } catch (Exception ex) {
  20101. cro.setV_errCode(-1);
  20102. cro.setV_errMsg("获取数据出错" + ex.getMessage());
  20103. }
  20104. return cro;
  20105. }
  20106. /**
  20107. * 获取熔炼成分判定标准(交付/客户/内控)
  20108. *
  20109. * @param designKey
  20110. * @param psc 产品码
  20111. * @param plineCode 产线编号
  20112. * @param mscPline 制程号
  20113. * @return
  20114. */
  20115. public CoreReturnObject GetOrdJudgeStdCicR(String designKey, String grade_name) {
  20116. try {
  20117. /*String sql = "select * from qcm_ord_design_std where design_key = '"+designKey+"' and psc = '"+psc+"'";
  20118. List<QCMOrdDesignStd> _designStd=mapper.queryQCMOrdDesignStd(sql);
  20119. if(SqlJoint.IsNullOrSpace(_designStd.get(0).getCic())){
  20120. cro.setV_errCode(-1);
  20121. cro.setV_errMsg("成分索引号不能为空");
  20122. return cro;
  20123. }*/
  20124. OrdJudgeStd<QCMOrdDesignStdCic> stdCic = new OrdJudgeStd<QCMOrdDesignStdCic>();
  20125. //交付标准.
  20126. String condition = "";
  20127. String sql = "select * from QCM_ORD_DESIGN_STD_CIC where 1=1";
  20128. condition = " and SPECL_FL = '0'" + " and STD_TYPE_CODE = 'A' And DESIGN_KEY='" + SqlJoint.TrimSqlDangerMark(designKey) + "'"
  20129. + " and chem_code not in (select chem_code from QCM_ORD_DESIGN_STD_CIC a where a.design_key = '"+SqlJoint.TrimSqlDangerMark(designKey)+"' and SPECL_FL = '1' and STD_TYPE_CODE = 'A') ";
  20130. List<QCMOrdDesignStdCic> listStdGB = mapper.queryQCMOrdDesignStdCic(sql + condition);
  20131. stdCic.setListStdGB(listStdGB);
  20132. //客户标准
  20133. condition = " and SPECL_FL = '1'" + " and STD_TYPE_CODE = 'A' And DESIGN_KEY='" + SqlJoint.TrimSqlDangerMark(designKey) + "'";
  20134. List<QCMOrdDesignStdCic> listStdKH = mapper.queryQCMOrdDesignStdCic(sql + condition);
  20135. stdCic.setListStdKH(listStdKH);
  20136. //内控标准
  20137. condition = " and SPECL_FL = '2'" + " and STD_TYPE_CODE = 'A' And DESIGN_KEY='" + designKey + "' ";
  20138. List<QCMOrdDesignStdCic> listStdNK = mapper.queryQCMOrdDesignStdCic(sql + condition);
  20139. if (listStdNK.size() == 0) {
  20140. listStdNK = new ArrayList<QCMOrdDesignStdCic>();
  20141. String sqls = "select * from QCM_ORD_DESIGN_MSC_INNERCRAFT a where a.grade_name = '" + grade_name + "'";
  20142. List<HashMap> list = mapper.query(sqls);
  20143. if (list.size() > 0) {
  20144. for (HashMap list1 : list) {
  20145. QCMOrdDesignStdCic cic = new QCMOrdDesignStdCic();
  20146. cic.setChem_code(list1.get("ELEMENT") == null ? "" : list1.get("ELEMENT").toString());
  20147. cic.setChem_name(list1.get("ELEMENT") == null ? "" : list1.get("ELEMENT").toString());
  20148. cic.setStdmax(list1.get("MAX_VALUE") == null ? null : list1.get("MAX_VALUE").toString());
  20149. cic.setStdmax_sign(list1.get("STDMAX_SIGN") == null ? null : list1.get("STDMAX_SIGN").toString());
  20150. cic.setStdmin(list1.get("MIN_VALUE") == null ? null : list1.get("MIN_VALUE").toString());
  20151. cic.setStdmin_sign(list1.get("STDMIN_SIGN") == null ? null : list1.get("STDMIN_SIGN").toString());
  20152. cic.setIscheck(list1.get("ISCHECK") == null ? "" : list1.get("ISCHECK").toString());
  20153. cic.setIsjudge(list1.get("ISJUDGE") == null ? "" : list1.get("ISJUDGE").toString());
  20154. cic.setChem_formula(list1.get("CHEM_FORMULA") == null ? "" : list1.get("CHEM_FORMULA").toString());
  20155. cic.setChem_type(list1.get("CHEM_TYPE") == null ? "" : list1.get("CHEM_TYPE").toString());
  20156. listStdNK.add(cic);
  20157. }
  20158. }
  20159. }
  20160. stdCic.setListStdNK(listStdNK);
  20161. //炼钢放行
  20162. condition = " and SPECL_FL = '3'" + " and STD_TYPE_CODE = 'A' And DESIGN_KEY='" + designKey + "' ";
  20163. List<QCMOrdDesignStdCic> listStdLG = mapper.queryQCMOrdDesignStdCic(sql + condition);
  20164. if (listStdLG.size() == 0) {
  20165. listStdLG = new ArrayList<QCMOrdDesignStdCic>();
  20166. String sqls = "select * from QCM_ORD_DESIGN_GRADE_CHEM a where a.grade_desc = '" + grade_name + "' and VALIDFLAG = '1'";
  20167. List<HashMap> list = mapper.query(sqls);
  20168. if (list.size() > 0) {
  20169. for (HashMap list1 : list) {
  20170. QCMOrdDesignStdCic cic = new QCMOrdDesignStdCic();
  20171. cic.setChem_code(list1.get("CHEM_CODE") == null ? "" : list1.get("CHEM_CODE").toString());
  20172. cic.setChem_name(list1.get("CHEM_NAME") == null ? "" : list1.get("CHEM_NAME").toString());
  20173. cic.setStdmax(list1.get("STDMAX") == null ? null : list1.get("STDMAX").toString());
  20174. cic.setStdmax_sign(list1.get("STDMAX_SIGN") == null ? null : list1.get("STDMAX_SIGN").toString());
  20175. cic.setStdmin(list1.get("STDMIN") == null ? null : list1.get("STDMIN").toString());
  20176. cic.setStdmin_sign(list1.get("STDMIN_SIGN") == null ? null : list1.get("STDMIN_SIGN").toString());
  20177. cic.setIscheck(list1.get("ISCHECK") == null ? "" : list1.get("ISCHECK").toString());
  20178. cic.setIsjudge(list1.get("ISJUDGE") == null ? "" : list1.get("ISJUDGE").toString());
  20179. cic.setChem_formula(list1.get("CHEM_FORMULA") == null ? "" : list1.get("CHEM_FORMULA").toString());
  20180. cic.setChem_type(list1.get("CHEM_TYPE") == null ? "" : list1.get("CHEM_TYPE").toString());
  20181. listStdLG.add(cic);
  20182. }
  20183. }
  20184. }
  20185. stdCic.setListStdLG(listStdLG);
  20186. //炼钢牌号
  20187. cro.setResult(stdCic);
  20188. } catch (Exception ex) {
  20189. cro.setV_errCode(-1);
  20190. cro.setV_errMsg("获取数据出错" + ex.getMessage());
  20191. }
  20192. return cro;
  20193. }
  20194. /**
  20195. * 获取熔炼成分判定标准(交付/客户/内控)
  20196. *
  20197. * @param designKey
  20198. * @param psc 产品码
  20199. * @param plineCode 产线编号
  20200. * @param mscPline 制程号
  20201. * @return
  20202. */
  20203. public CoreReturnObject GetOrdJudgeStdCicR1(String designKey) {
  20204. try {
  20205. /*String sql = "select * from qcm_ord_design_std where design_key = '"+designKey+"' and psc = '"+psc+"'";
  20206. List<QCMOrdDesignStd> _designStd=mapper.queryQCMOrdDesignStd(sql);
  20207. if(SqlJoint.IsNullOrSpace(_designStd.get(0).getCic())){
  20208. cro.setV_errCode(-1);
  20209. cro.setV_errMsg("成分索引号不能为空");
  20210. return cro;
  20211. }*/
  20212. OrdJudgeStd<QCMOrdDesignStdCic> stdCic = new OrdJudgeStd<QCMOrdDesignStdCic>();
  20213. //交付标准.
  20214. String condition = "";
  20215. String sql = "select * from QCM_ORD_DESIGN_STD_CIC where 1=1";
  20216. condition = " and SPECL_FL = '0'" + " and STD_TYPE_CODE = 'A' And DESIGN_KEY='" + SqlJoint.TrimSqlDangerMark(designKey) + "'"
  20217. + "and chem_code not in (select chem_code from QCM_ORD_DESIGN_STD_CIC a where a.design_key = '"+SqlJoint.TrimSqlDangerMark(designKey)+"' and SPECL_FL = '1' and STD_TYPE_CODE = 'A') ";
  20218. List<QCMOrdDesignStdCic> listStdGB = mapper.queryQCMOrdDesignStdCic(sql + condition);
  20219. stdCic.setListStdGB(listStdGB);
  20220. //客户标准
  20221. condition = " and SPECL_FL = '1'" + " and STD_TYPE_CODE = 'A' And DESIGN_KEY='" + SqlJoint.TrimSqlDangerMark(designKey) + "'";
  20222. List<QCMOrdDesignStdCic> listStdKH = mapper.queryQCMOrdDesignStdCic(sql + condition);
  20223. stdCic.setListStdKH(listStdKH);
  20224. //内控标准
  20225. condition = " and SPECL_FL = '2'" + " and STD_TYPE_CODE = 'A' And DESIGN_KEY='" + designKey + "' ";
  20226. List<QCMOrdDesignStdCic> listStdNK = mapper.queryQCMOrdDesignStdCic(sql + condition);
  20227. stdCic.setListStdNK(listStdNK);
  20228. //炼钢放行
  20229. condition = " and SPECL_FL = '3'" + " and STD_TYPE_CODE = 'A' And DESIGN_KEY='" + designKey + "' ";
  20230. List<QCMOrdDesignStdCic> listStdLG = mapper.queryQCMOrdDesignStdCic(sql + condition);
  20231. stdCic.setListStdLG(listStdLG);
  20232. //炼钢牌号
  20233. cro.setResult(stdCic);
  20234. } catch (Exception ex) {
  20235. cro.setV_errCode(-1);
  20236. cro.setV_errMsg("获取数据出错" + ex.getMessage());
  20237. }
  20238. return cro;
  20239. }
  20240. /**
  20241. * 根据炉号获取成分检验实绩信息
  20242. *
  20243. * @param com
  20244. * @return
  20245. */
  20246. @SuppressWarnings("rawtypes")
  20247. public CoreReturnObject GetElementsInfo1(List<String> list) {
  20248. try {
  20249. String assay_no = "";
  20250. //"length(chem_name) desc" 这个排序对复合元素计算有用,慎重更改
  20251. for (String assaynos : list) {
  20252. if (assay_no.equals("")) {
  20253. assay_no = "'" + assaynos + "'";
  20254. } else {
  20255. assay_no = assay_no + ",'" + assaynos + "'";
  20256. }
  20257. }
  20258. String sql = "select a.assay_no,a.heat_no,a.batch_no,a.inspection_lot,a.smp_no,a.specimen_no, "
  20259. + " a.material_no, a.pline_code, a.pline_name,a.steel_code,a.steel_name,a.assay_type, "
  20260. + " a.chem_code,a.chem_name,case when a.chem_value > -1 and a.chem_value < 1 and a.chem_value != 0 then '0' || round(a.chem_value,7) else '' || round(a.chem_value,7) end chem_value,a.coil_sort, "
  20261. + " a.source,a.sample_type,a.memo, a.create_id, a.create_name, a.create_time from QCM_JHY_INSP_ELEMENTS a where assay_no in (" + assay_no + ") order by length(chem_name) desc";
  20262. List<QcmJhyInspElements> listEle = mapper.queryQcmJhyInspElements(sql);
  20263. cro.setResult(listEle);
  20264. } catch (Exception ex) {
  20265. cro.setV_errCode(-1);
  20266. cro.setV_errMsg("获取成分检验信息出错" + ex.getMessage());
  20267. SqlSession.rollback();
  20268. }
  20269. return cro;
  20270. }
  20271. /**
  20272. * 查询炼钢待判信息
  20273. */
  20274. @SuppressWarnings({"unused", "unchecked"})
  20275. public CoreReturnObject getLgRejudgeInfobyMaterial_no(String begintime, String endtime, String heatno, String prodline, String prod_type, String judge_type) {
  20276. try {
  20277. JSONObject jsobj2 = new JSONObject();
  20278. JSONArray ttmaps = new JSONArray();
  20279. JSONObject jsobj1 = new JSONObject();
  20280. jsobj1.put("START_TIME", begintime);
  20281. jsobj1.put("END_TIME", endtime);
  20282. jsobj1.put("HEAT_NO", heatno == null ? "" : heatno);
  20283. jsobj1.put("PROD_LINE", prodline);
  20284. jsobj1.put("PROD_TYPE", prod_type);
  20285. jsobj1.put("JUDGE_TYPE", judge_type);
  20286. jsobj1.put("ISJUDGE", "0");
  20287. String url = "http://10.70.0.237:9000/LgdoChemJudgeService?wsdl";
  20288. String result = callWebserviceASMX(url, "StorageForJudge", JSON.toJSONString(jsobj1));
  20289. if (result.contains("DATA")) {
  20290. JSONObject jo = JSONObject.parseObject(result);
  20291. JSONArray ja = jo.getJSONArray("DATA");
  20292. List<HashMap> listqjb = new ArrayList<HashMap>();
  20293. for (int i = 0; i < ja.size(); i++) {
  20294. HashMap lists = new HashMap();
  20295. lists.put("HEAT_NO", ja.getJSONObject(i).getString("HEATNO"));
  20296. lists.put("MATERIAL_NO", ja.getJSONObject(i).getString("BILLETNO"));
  20297. lists.put("GRADE_NAME", ja.getJSONObject(i).getString("STEELCODE"));
  20298. lists.put("PROD_NAME", ja.getJSONObject(i).getString("PRODNAME"));
  20299. lists.put("DELIVERY_STATE_DESC", ja.getJSONObject(i).getString("STATUS"));
  20300. lists.put("WEIGHT", ja.getJSONObject(i).getString("WEIGHT"));
  20301. lists.put("THICK", ja.getJSONObject(i).getString("THICK"));
  20302. lists.put("REMARK", ja.getJSONObject(i).get("SLAB_DETAIL"));
  20303. lists.put("LENGTH", ja.getJSONObject(i).getString("LENGTH"));
  20304. lists.put("WIDTH", ja.getJSONObject(i).getString("WIDTH"));
  20305. lists.put("PRODUCETIME", ja.getJSONObject(i).getString("CUTSTARTTIME"));
  20306. lists.put("DESIGN_KEY", ja.getJSONObject(i).getString("ORDERNO"));
  20307. lists.put("PLINE_CODE", ja.getJSONObject(i).getString("PROD_CODE"));
  20308. lists.put("PLINE_NAME", ja.getJSONObject(i).getString("PROD_NAME"));
  20309. lists.put("STD_NAME", ja.getJSONObject(i).getString("USEDSTAND"));
  20310. lists.put("CHEMRESULT_LK", ja.getJSONObject(i).getString("CHEMRESULT_FX"));
  20311. lists.put("FACERESULT", ja.getJSONObject(i).getString("FACERESULT"));
  20312. lists.put("CHEMJUDGEID", ja.getJSONObject(i).getString("CHEMJUDGEID"));
  20313. lists.put("FACECHECKID", ja.getJSONObject(i).getString("FACECHECKID"));
  20314. lists.put("PROD_THICK", ja.getJSONObject(i).getString("PROD_THK"));
  20315. lists.put("PROD_WIDTH", ja.getJSONObject(i).getString("PROD_WTH"));
  20316. lists.put("PLANSTEEL", ja.getJSONObject(i).getString("PLANSTEEL"));
  20317. String mome = mapper.GetLGMemo(ja.getJSONObject(i).getString("ORDERNO"));
  20318. lists.put("MEMO", mome);
  20319. listqjb.add(lists);
  20320. }
  20321. cro.setResult(listqjb);
  20322. }
  20323. } catch (Exception ex) {
  20324. cro.setV_errCode(-1);
  20325. cro.setV_errMsg("获取成分待判信息错误" + ex.getMessage());
  20326. SqlSession.rollback();
  20327. }
  20328. return cro;
  20329. }
  20330. /** 判定调用
  20331. * 查询对应项目实测值,标准值
  20332. */
  20333. public CoreReturnObject querryJudgetItemInfo(String smp_no, String design_key,String steel_name,String prod_line,String phy_id) {
  20334. try {
  20335. List<QcmJhySampleConsignD> qd = mapper.findQcmJhySampleConsignD2(smp_no);
  20336. List<QcmJhySampleROrd> qrd = mapper.queryQcmJhySampleROrd1("select * from qcm_jhy_sample_r_ord where smp_no ='"+smp_no+"'");
  20337. List<QcmOrdDesignStdPic> itemAll = new ArrayList<QcmOrdDesignStdPic>();
  20338. List<QcmOrdDesignStdPic> pic = new ArrayList<QcmOrdDesignStdPic>();
  20339. if(prod_line.equals("LT1")){
  20340. pic = mapper.findQcmOrdDesignStdPic2(design_key,steel_name.equals("SWRH82B-YL-Ⅰ")?"SWRH82B-YL":steel_name,"LT1");
  20341. }else if(prod_line.equals("RZ1")){
  20342. pic = mapper.findQcmOrdDesignStdPic2(design_key,steel_name.equals("SWRH82B-YL-Ⅰ")?"SWRH82B-YL":steel_name,"RZ1");
  20343. }else if(prod_line.equals("YT1")){
  20344. pic = mapper.findQcmOrdDesignStdPic2(design_key,steel_name.equals("SWRH82B-YL-Ⅰ")?"SWRH82B-YL":steel_name,"YT1");
  20345. }else
  20346. {
  20347. pic = mapper.findQcmOrdDesignStdPic4(design_key);
  20348. }
  20349. //List<QcmOrdDesignStdPic> pic = mapper.findQcmOrdDesignStdPic(design_key,steel_name.equals("SWRH82B-YL-Ⅰ")?"SWRH82B-YL":steel_name);
  20350. itemAll.addAll(pic);
  20351. String oldProject = null;
  20352. String newProject = null;
  20353. List<QcmJhySampleConsignDItem> targets=new ArrayList<QcmJhySampleConsignDItem>();
  20354. for (QcmJhySampleConsignD qcmJhySampleConsignD : qd) {
  20355. List<QcmJhySampleConsignDItem> items = new ArrayList<QcmJhySampleConsignDItem>();
  20356. if(prod_line.equals("RZ1") && phy_id == null && !SqlJoint.IsNullOrSpace(qcmJhySampleConsignD.getRz_old_sampl_no())){
  20357. items = mapper.findQcmJhySampleConsignDItem5(qcmJhySampleConsignD.getSpecimen_no());
  20358. }else{
  20359. items = mapper.findQcmJhySampleConsignDItem4(qcmJhySampleConsignD.getSpecimen_no(),phy_id);
  20360. }
  20361. for (QcmJhySampleConsignDItem qi : items) {
  20362. oldProject = qi.getPhy_code_l() + qi.getPhy_code_m() + qi.getPhy_code_s() + qi.getItem_code_d()
  20363. + qi.getItem_code_s() + qi.getItem_code_t();
  20364. //获取标准
  20365. for (QcmOrdDesignStdPic si : itemAll) {
  20366. newProject = si.getPhy_code_l() + si.getPhy_code_m() + si.getPhy_code_s() + si.getItem_code_d()
  20367. + si.getItem_code_s() + si.getItem_code_t();
  20368. if (oldProject.equals(newProject)) {
  20369. if ("0".equals(si.getSpecl_fl())) {
  20370. qi.setJf_stdmax(si.getStdmax());
  20371. qi.setJf_stdmax_sign(si.getStdmax_sign());
  20372. qi.setJf_stdmin(si.getStdmin());
  20373. qi.setJf_stdmin_sign(si.getStdmin_sign());
  20374. qi.setJudge_basis(si.getJudge_basis());
  20375. if(SqlJoint.IsNullOrSpace(si.getIsjudge())){
  20376. qi.setIsjudge("1");
  20377. }else{
  20378. qi.setIsjudge(si.getIsjudge());
  20379. }
  20380. qi.setQuote_consign_no(qcmJhySampleConsignD.getQuote_consign_no());
  20381. qi.setOld_consign_no(qcmJhySampleConsignD.getOld_consign_no());
  20382. qi.setAddcondition(si.getAddcondition());
  20383. qi.setAddstdcon_code(si.getAddstdcon_code());
  20384. qi.setAddstd_max(si.getAddstd_max());
  20385. qi.setAdd_std_max_sign(si.getAddstd_max_sign());
  20386. qi.setAddstd_min(si.getAddstd_min());
  20387. qi.setAddstd_min_sign(si.getAddstd_min_sign());
  20388. qi.setAddpercent(si.getAddpercent());
  20389. } else if ("1".equals(si.getSpecl_fl())) {
  20390. qi.setKh_stdmax(si.getStdmax());
  20391. qi.setKh_stdmax_sign(si.getStdmax_sign());
  20392. qi.setKh_stdmin(si.getStdmin());
  20393. qi.setKh_stdmin_sign(si.getStdmin_sign());
  20394. qi.setJudge_basis(si.getJudge_basis());
  20395. if(SqlJoint.IsNullOrSpace(si.getIsjudge())){
  20396. qi.setIsjudge("1");
  20397. }else{
  20398. qi.setIsjudge(si.getIsjudge());
  20399. }
  20400. qi.setQuote_consign_no(qcmJhySampleConsignD.getQuote_consign_no());
  20401. qi.setOld_consign_no(qcmJhySampleConsignD.getOld_consign_no());
  20402. qi.setAddcondition(si.getAddcondition());
  20403. qi.setAddstdcon_code(si.getAddstdcon_code());
  20404. qi.setAddstd_max(si.getAddstd_max());
  20405. qi.setAdd_std_max_sign(si.getAddstd_max_sign());
  20406. qi.setAddstd_min(si.getAddstd_min());
  20407. qi.setAddstd_min_sign(si.getAddstd_min_sign());
  20408. qi.setAddpercent(si.getAddpercent());
  20409. } else if ("2".equals(si.getSpecl_fl())) {
  20410. qi.setNk_stdmax(si.getStdmax());
  20411. qi.setNk_stdmax_sign(si.getStdmax_sign());
  20412. qi.setNk_stdmin(si.getStdmin());
  20413. qi.setNk_stdmin_sign(si.getStdmin_sign());
  20414. qi.setJudge_basis(si.getJudge_basis());
  20415. if(SqlJoint.IsNullOrSpace(si.getIsjudge())){
  20416. qi.setIsjudge("1");
  20417. }else{
  20418. qi.setIsjudge(si.getIsjudge());
  20419. }
  20420. qi.setQuote_consign_no(qcmJhySampleConsignD.getQuote_consign_no());
  20421. qi.setOld_consign_no(qcmJhySampleConsignD.getOld_consign_no());
  20422. qi.setAddcondition(si.getAddcondition());
  20423. qi.setAddstdcon_code(si.getAddstdcon_code());
  20424. qi.setAddstd_max(si.getAddstd_max());
  20425. qi.setAdd_std_max_sign(si.getAddstd_max_sign());
  20426. qi.setAddstd_min(si.getAddstd_min());
  20427. qi.setAddstd_min_sign(si.getAddstd_min_sign());
  20428. qi.setAddpercent(si.getAddpercent());
  20429. }else if ("3".equals(si.getSpecl_fl())) {
  20430. qi.setFx_stdmax(si.getStdmax());
  20431. qi.setFx_stdmax_sign(si.getStdmax_sign());
  20432. qi.setFx_stdmin(si.getStdmin());
  20433. qi.setFx_stdmin_sign(si.getStdmin_sign());
  20434. qi.setJudge_basis(si.getJudge_basis());
  20435. if (SqlJoint.IsNullOrSpace(si.getIsjudge())) {
  20436. qi.setIsjudge("1");
  20437. } else {
  20438. qi.setIsjudge(si.getIsjudge());
  20439. }
  20440. qi.setQuote_consign_no(qcmJhySampleConsignD.getQuote_consign_no());
  20441. qi.setOld_consign_no(qcmJhySampleConsignD.getOld_consign_no());
  20442. qi.setAddcondition(si.getAddcondition());
  20443. qi.setAddstdcon_code(qi.getAddstdcon_code());
  20444. qi.setAddstd_max(si.getAddstd_max());
  20445. qi.setAdd_std_max_sign(si.getAddstd_max_sign());
  20446. qi.setAddstd_min(si.getAddstd_min());
  20447. qi.setAddstd_min_sign(si.getAddstd_min_sign());
  20448. qi.setAddpercent(si.getAddpercent());
  20449. }else if ("4".equals(si.getSpecl_fl())) {
  20450. qi.setNk_stdmax(si.getStdmax());
  20451. qi.setNk_stdmax_sign(si.getStdmax_sign());
  20452. qi.setNk_stdmin(si.getStdmin());
  20453. qi.setNk_stdmin_sign(si.getStdmin_sign());
  20454. qi.setJudge_basis(si.getJudge_basis());
  20455. if(SqlJoint.IsNullOrSpace(si.getIsjudge())){
  20456. qi.setIsjudge("1");
  20457. }else{
  20458. qi.setIsjudge(si.getIsjudge());
  20459. }
  20460. qi.setQuote_consign_no(qcmJhySampleConsignD.getQuote_consign_no());
  20461. qi.setOld_consign_no(qcmJhySampleConsignD.getOld_consign_no());
  20462. qi.setAddcondition(si.getAddcondition());
  20463. qi.setAddstdcon_code(si.getAddstdcon_code());
  20464. qi.setAddstd_max(si.getAddstd_max());
  20465. qi.setAdd_std_max_sign(si.getAddstd_max_sign());
  20466. qi.setAddstd_min(si.getAddstd_min());
  20467. qi.setAddstd_min_sign(si.getAddstd_min_sign());
  20468. qi.setAddpercent(si.getAddpercent());
  20469. }
  20470. }
  20471. }
  20472. //获取实测值
  20473. List<QcmJhyPhyresult> qpt = new ArrayList<QcmJhyPhyresult>();
  20474. if(prod_line.equals("RZ1") && phy_id == null && !SqlJoint.IsNullOrSpace(qcmJhySampleConsignD.getRz_old_sampl_no())){
  20475. qpt = mapper.findphyresult3(qi.getSpecimen_no(),qi.getSeq());
  20476. }else{
  20477. qpt = mapper.findphyresult2(qi.getSpecimen_no(),qi.getSeq(),phy_id);
  20478. }
  20479. //if (SqlJoint.IsNullOrSpace(qi.getQuote_specimen_no())) {
  20480. for (QcmJhyPhyresult qp : qpt) {
  20481. String str = qp.getPhy_code_l() + qp.getPhy_code_m() + qp.getPhy_code_s() + qp.getItem_code_d()
  20482. + qp.getItem_code_s() + qp.getItem_code_t();
  20483. if (!SqlJoint.IsNullOrSpace(oldProject)&&!SqlJoint.IsNullOrSpace(str)) {
  20484. if (str.equals(oldProject)) {
  20485. //if (SqlJoint.IsNullOrSpace(qi.getQuote_consign_no())) {
  20486. qi.setVal1(qp.getVal1());
  20487. qi.setVal2(qp.getVal2());
  20488. qi.setVal3(qp.getVal3());
  20489. qi.setVal4(qp.getVal4());
  20490. qi.setVal5(qp.getVal5());
  20491. qi.setVal6(qp.getVal6());
  20492. qi.setVal7(qp.getVal7());
  20493. qi.setVal8(qp.getVal8());
  20494. qi.setVal9(qp.getVal9());
  20495. qi.setDefect_flag(qp.getDefect_flag());
  20496. qi.setAvg_val(qp.getAvg_val());
  20497. //}
  20498. }
  20499. }
  20500. }
  20501. //}
  20502. /*else {//不为空则获取引用检验项目的实测值
  20503. List<QcmJhyPhyresult> q = mapper.findphyresult(qi.getQuote_specimen_no());
  20504. for (QcmJhyPhyresult qjp : q) {
  20505. String qutospe=qjp.getPhy_code_l() + qjp.getPhy_code_m() + qjp.getPhy_code_s() + qjp.getItem_code_d()
  20506. + qjp.getItem_code_s() + qjp.getItem_code_t();
  20507. String qutospeI=qi.getQuote_phy_code_l()+qi.getQuote_phy_code_m()+qi.getQuote_phy_code_s()+qi.getQuote_item_code_d()
  20508. +qi.getQuote_item_code_s()+qi.getQuote_item_code_t();
  20509. if (qutospe.endsWith(qutospeI)) {
  20510. qi.setVal1(qjp.getVal1());
  20511. qi.setVal2(qjp.getVal2());
  20512. qi.setVal3(qjp.getVal3());
  20513. qi.setVal4(qjp.getVal4());
  20514. qi.setVal5(qjp.getVal5());
  20515. qi.setVal6(qjp.getVal6());
  20516. qi.setVal7(qjp.getVal7());
  20517. qi.setVal8(qjp.getVal8());
  20518. qi.setVal9(qjp.getVal9());
  20519. qi.setDefect_flag(qjp.getDefect_flag());
  20520. qi.setAvg_val(qjp.getAvg_val());
  20521. }
  20522. }
  20523. }*/
  20524. if(!SqlJoint.IsNullOrSpace(qi.getFy_quote_specimen_no())){
  20525. qi.setSmp_type_code("0");
  20526. qi.setSmp_type_name("初样");
  20527. }
  20528. else
  20529. {
  20530. qi.setSmp_type_code(qcmJhySampleConsignD.getSmp_type_code());
  20531. if(qcmJhySampleConsignD.getSmp_type_code().equals("0") && (!qrd.get(0).getCert_inst_code().equals("BV") && !qrd.get(0).getCert_inst_code().equals("KR") && !qrd.get(0).getCert_inst_code().equals("IC001") && !qrd.get(0).getCert_inst_code().equals("IC010") && !qrd.get(0).getCert_inst_code().equals("5000"))){
  20532. qi.setSmp_type_name("认证样");
  20533. }
  20534. else{
  20535. qi.setSmp_type_name(qcmJhySampleConsignD.getSmp_type_name());
  20536. }
  20537. }
  20538. qi.setHt_no(qcmJhySampleConsignD.getProcess_no());
  20539. /*List<HashMap> hashmap = new ArrayList<HashMap>();
  20540. if(qcmJhySampleConsignD.getMaterial_no().startsWith("Z")){
  20541. hashmap = mapper.doQueryMaterialInfoZB(qcmJhySampleConsignD.getMaterial_no());
  20542. }else if(qcmJhySampleConsignD.getMaterial_no().startsWith("H")){
  20543. hashmap = mapper.doQueryMaterialInfoHB(qcmJhySampleConsignD.getMaterial_no());
  20544. }
  20545. if(hashmap.size() > 0){
  20546. if(hashmap.get(0).get("HT_NO") != null) {
  20547. qi.setHt_no(hashmap.get(0).get("HT_NO").toString());
  20548. }
  20549. }*/
  20550. targets.add(qi);
  20551. }
  20552. }
  20553. cro.setResult(targets);
  20554. } catch (Exception e) {
  20555. cro.setV_errCode(-1);
  20556. cro.setV_errMsg("查询失败!"+e.getMessage());
  20557. }
  20558. return cro;
  20559. }
  20560. /**
  20561. * 查询物料明细信息 根据物料号 需增加炼钢牌号
  20562. * @return
  20563. */
  20564. @SuppressWarnings("rawtypes")
  20565. public List<HashMap> doQueryMaterialInfoZhb(String material_no) {
  20566. String swhere = "";
  20567. String swhere1 = "";
  20568. if (!SqlJoint.IsNullOrSpace(material_no)) { //产品序号
  20569. swhere += " and a.billetid = '"+material_no+"'";
  20570. }
  20571. String sql = "select a.RCL_STATE ht_no, 'HB1' PLINE_CODE,C2N@xgcx('4001HB1') PLINE_NAME,STOVENO HEAT_NO,to_char((SELECT substr(MAX(BILLETID),1,12)||'0' FROM zyhb_plandetailofplate@xgcx where MOTHERSLAB = MOTHERBOARDNUMBER)) BOARD_NO, a.ROLLNUMBER batchno, a.PLANNUMBER plan_no, a.BILLETID material_no, "
  20572. + " case when allotorderform is null then planorderform else allotorderform end design_key,planorderform PLANORDERNO,allotorderform ORDERNO, "
  20573. + " PLY thick, a.WIDTH, a.LENGTH,THEORYWEIGHT weight, (select name_ from scm_base_info@xgcx where id_ = CUTSIDESTATE) CUTSIDESTATE, "
  20574. + " (select name_ from scm_base_info@xgcx where id_ = ROLE) FIXSIZE, PRODUCETIME, b.sizeid,(select BIGSHOPSIGN from kch_storagelist@xgcx "
  20575. + " where BILLETID = (select BILLETID from zyhb_planofmotherplate@xgcx where MOTHERPLATEID = A.MOTHERBOARDNUMBER)) grade_code, "
  20576. + " (select BIGSHOPSIGN from kch_storagelist@xgcx where BILLETID = (select BILLETID from zyhb_planofmotherplate@xgcx "
  20577. + " where MOTHERPLATEID = A.MOTHERBOARDNUMBER)) grade_name,b.BILLETID_jy INSPECTION_LOT, t2.STEELCODE steel_code, C2N@xgcx(t2.STEELCODE)steel_name , t2.USEDSTAND std_code, C2N@xgcx(t2.USEDSTAND) std_name, "
  20578. + " t2.PURPOSEID prod_code, C2N@xgcx(t2.PURPOSEID) prod_name,t2.PSRNO psc,t2.DEV_SPEC_CD psc_desc,psel_get_standroll@XGCX(t2.STANDROLLER) DELIVERY_STATE_DESC from kch_turnofflist@xgcx a "
  20579. + " left join zj_result_all@xgcx b on a.BILLETID = b.BILLETID join sel_pactdetail_new@xgcx t2 on a.allotorderform = t2.ORDERNO where 1=1 "+swhere1+swhere+" "
  20580. + " union all "
  20581. + " select RCL_STATE ht_no, 'ZB1' PLINE_CODE,C2N@xgcx('4001ZB1') PLINE_NAME,a.STOVENO HEAT_NO,to_char((SELECT substr(MAX(BILLETID),1,12)||'0' FROM mb_plandetailofplate@xgcx where MOTHERPLATEID = MOTHERBOARDNUMBER)) BOARD_NO,ROLLNUMBER batchno, PLANNO plan_no, a.BILLETID material_no, case when a.orderno is null then planorderno else a.orderno end DESIGN_KEY, "
  20582. + " A.PLANORDERNO,A.ORDERNO,a.PLY thick, a.WIDTH, "
  20583. + " a.LENGTH, a.THEORYWEIGHT weight, (select name_ from scm_base_info@xgcx where id_ = CUTSIDESTATE) CUTSIDESTATE, (select name_ from scm_base_info@xgcx where id_ = RuLE) FIXSIZE, "
  20584. + " PTIME PRODUCETIME, b.sizeid,(select BIGSHOPSIGN from kcz_storagelist@xgcx where BILLETID = (select BILLETID "
  20585. + " from mb_planofmotherplate@xgcx where MOTHERPLATEID = A.MOTHERBOARDNUMBER)) GRADE_CODE, (select BIGSHOPSIGN "
  20586. + " from kcz_storagelist@xgcx where BILLETID = (select BILLETID from mb_planofmotherplate@xgcx "
  20587. + " where MOTHERPLATEID = A.MOTHERBOARDNUMBER)) GRADE_NAME,b.BILLETID_jy INSPECTION_LOT, t2.STEELCODE steel_code, C2N@xgcx(t2.STEELCODE)steel_name , t2.USEDSTAND std_code, C2N@xgcx(t2.USEDSTAND) std_name, "
  20588. + " t2.PURPOSEID prod_code, C2N@xgcx(t2.PURPOSEID) prod_name,t2.PSRNO psc,t2.DEV_SPEC_CD psc_desc,psel_get_standroll@XGCX(t2.STANDROLLER) DELIVERY_STATE_DESC from kcz_turnofflist@xgcx a left join zj_result_all@xgcx b on a.BILLETID = b.BILLETID join sel_pactdetail_new@xgcx t2 on a.ORDERNO = t2.ORDERNO "
  20589. + " where 1=1 "+swhere1+swhere+" ";
  20590. try {
  20591. System.out.print(sql);
  20592. List<HashMap> list = mapper.query(sql);
  20593. return list;
  20594. } catch (Exception ex) {
  20595. ex.printStackTrace();
  20596. }
  20597. return null;
  20598. }
  20599. /**
  20600. * 查询物料明细信息 根据物料号
  20601. * @return
  20602. */
  20603. /*@SuppressWarnings("rawtypes")
  20604. public List<HashMap> doQueryMaterialInfos(String material_no) {
  20605. String swhere = "";
  20606. String swhere1 = "";
  20607. if (!SqlJoint.IsNullOrSpace(material_no)) { //产品序号
  20608. swhere += " and material_no in "+material_no+"";
  20609. }
  20610. String sql =
  20611. "select t1.*,t2.STEELCODE steel_code,C2N@xgcx(t2.STEELCODE) steel_name,t2.USEDSTAND std_code, "
  20612. + " C2N@xgcx(t2.USEDSTAND) std_name,t2.PURPOSEID prod_code,C2N@xgcx(t2.PURPOSEID) prod_name, psel_get_standroll@XGCX(t2.STANDROLLER) DELIVERY_STATE_DESC,"
  20613. + " t2.PSRNO psc, t2.DEV_SPEC_CD psc_desc from (select '' ht_no, 'HB1' PLINE_CODE,C2N@xgcx('4001HB1') PLINE_NAME,to_char(a.heatno) heatno,MOTHERSLAB BOARD_NO, batchno, a.taskno plan_no, "
  20614. + " a.slabno material_no, a.ORDERID design_key, a.thick, a.width, a.len length, a.weight, "
  20615. + " (select name_ from scm_base_info where id_ = a.cutsizestate) CUTSIDESTATE, (select name_ from scm_base_info where id_ = a.SIZEMODE) FIXSIZE, "
  20616. + " a.maketime PRODUCETIME, b.sizeid, b.SURFACEID surface_id,b.up_surface_result_id_desc,b.ud_surface_result_id_desc, b.billetid_jy INSPECTION_LOT"
  20617. + " from zyhb_plandetailofplate@xgcx a,zj_result_all@xgcx b where a.SLABNO = b.BILLETID "
  20618. + " "+swhere1+") T1 left join sel_pactdetail@xgcx t2 "
  20619. + " on t1.design_key = t2.ORDERNO where 1 = 1 "+swhere+""
  20620. + " union all "
  20621. +"select t1.*,t2.STEELCODE steel_code,C2N@xgcx(t2.STEELCODE) steel_name,t2.USEDSTAND std_code, "
  20622. + " C2N@xgcx(t2.USEDSTAND) std_name,t2.PURPOSEID prod_code,C2N@xgcx(t2.PURPOSEID) prod_name, psel_get_standroll@XGCX(t2.STANDROLLER) DELIVERY_STATE_DESC,"
  20623. + " t2.PSRNO psc, t2.DEV_SPEC_CD psc_desc from (select '' ht_no, 'HB1' PLINE_CODE,C2N@xgcx('4001HB1') PLINE_NAME,to_char(a.heatno) heatno,MOTHERSLAB BOARD_NO, batchno, a.taskno plan_no, "
  20624. + " a.slabno material_no, a.ORDERID design_key, a.thick, a.width, a.len length, a.weight, "
  20625. + " (select name_ from scm_base_info where id_ = a.cutsizestate) CUTSIDESTATE, (select name_ from scm_base_info where id_ = a.SIZEMODE) FIXSIZE, "
  20626. + " a.maketime PRODUCETIME, b.sizeid, b.SURFACEID surface_id,b.up_surface_result_id_desc,b.ud_surface_result_id_desc, b.billetid_jy INSPECTION_LOT"
  20627. + " from ZYHB_PLANDETAILOFPLATE_ZJNEW@xgcx a,zj_result_all@xgcx b where a.SLABNO = b.BILLETID "
  20628. + " "+swhere1+") T1 left join sel_pactdetail@xgcx t2 "
  20629. + " on t1.design_key = t2.ORDERNO where 1 = 1 "+swhere+""
  20630. + " union all "
  20631. + "select t1.*, t2.STEELCODE steel_code, "
  20632. + " C2N@xgcx(t2.STEELCODE) steel_name, t2.USEDSTAND std_code, C2N@xgcx(t2.USEDSTAND) std_name, t2.PURPOSEID prod_code, "
  20633. + " C2N@xgcx(t2.PURPOSEID) prod_name,psel_get_standroll@XGCX(t2.STANDROLLER) DELIVERY_STATE_DESC,t2.PSRNO psc,t2.DEV_SPEC_CD psc_desc "
  20634. + " from (select '' ht_no, 'ZB1' PLINE_CODE,C2N@xgcx('4001ZB1') PLINE_NAME,to_char(a.heatno) heat_no,MOTHERPLATEID BOARD_NO, A.batchno, a.taskno plan_no, a.PRODUCTNO material_no, a.ORDERNO design_key, "
  20635. + " a.HEIGHT thick, a.width,a.lenGTH, a.weight,(select name_ from scm_base_info where id_ = a.CUTSTYLE) CUTSIDESTATE, "
  20636. + " (select name_ from scm_base_info where id_ = a.SIZESTYLE) FIXSIZE,a.maketime PRODUCETIME, b.sizeid,b.SURFACEID surface_id,b.up_surface_result_id_desc,b.ud_surface_result_id_desc,b.billetid_jy INSPECTION_LOT "
  20637. + " from mb_plandetailofplate@xgcx a, zj_result_all@xgcx b "
  20638. + " where a.PRODUCTNO = b.BILLETID "+swhere1+") T1 left join sel_pactdetail@xgcx t2 "
  20639. + " on t1.design_key = t2.ORDERNO where 1=1 "+swhere+""
  20640. +" union all select t1.*, t2.STEELCODE steel_code, "
  20641. + " C2N@xgcx(t2.STEELCODE) steel_name, t2.USEDSTAND std_code, C2N@xgcx(t2.USEDSTAND) std_name, t2.PURPOSEID prod_code, "
  20642. + " C2N@xgcx(t2.PURPOSEID) prod_name,psel_get_standroll@XGCX(t2.STANDROLLER) DELIVERY_STATE_DESC,t2.PSRNO psc,t2.DEV_SPEC_CD psc_desc "
  20643. + " from (select '' ht_no,a.PLD PLINE_CODE,C2N@xgcx(a.PLD) PLINE_NAME,substr(a.STOVENO,1,10) HEAT_NO,ROLLNUMBER BOARD_NO,ROLLNUMBER batchno, PLANNO plan_no,a.BILLETID material_no, "
  20644. + " ORDERNO design_key, a.PLY thick, "
  20645. + " a.WIDTH, a.LENGTH, a.THEORYWEIGHT weight, '' CUTSIDESTATE, (select name_ from scm_base_info@xgcx where id_ = RuLE) FIXSIZE, "
  20646. + " PTIME PRODUCETIME, b.sizeid,b.SURFACEID surface_id,b.up_surface_result_id_desc,b.ud_surface_result_id_desc,b.BILLETID_jy INSPECTION_LOT from kcx_turnofflist@xgcx a left join zj_result_all@xgcx b on a.BILLETID = b.BILLETID LEFT JOIN kcx_stufflist@xgcx C ON C.STOVENO = A.STOVENO"
  20647. + " where 1=1 "+swhere1+")T1 left join sel_pactdetail@xgcx t2 on t1.design_key = t2.ORDERNO where 1=1 "+swhere+" "
  20648. + "union all select * from (select ''ht_no,'RZ1','热轧线',SUBSTR(T.SLAB_NO, 1, 10),T.SLAB_NO,SUBSTR(t.OLD_SAMPL_NO, 1, 10) batchno,t1.ROLL_MANA_NO plan_no, T.OLD_SAMPL_NO material_no, T.ORD_NO || T.ORD_SEQ, "
  20649. + " T.instr_COIL_THK,T.instr_COIL_WTH, T.instr_COIL_LEN,T.ACT_WGT/1000,''CUTSIDESTATE,''FIXSIZE, to_date(substr(t.MILL_DTIME,'0','8'), 'yyyy-mm-dd') PRODUCETIME,b.sizeid, b.SURFACEID surface_id,b.up_surface_result_id_desc,b.ud_surface_result_id_desc,b.INSPECTION_LOT,T.SPEC_STL_GRD steel_code,"
  20650. + " T.SPEC_STL_GRD steel_name,T.SPEC_ABBSYM std_code,T.SPEC_ABBSYM std_name, T.ORD_USE_CD prod_code,PKG_QUALITY_COMM.PK00_COMM('A01007',T.ORD_USE_CD) prod_name,t.PRODNM_CD,'' psc,'' psc_desc "
  20651. + " from tbh02_coil_comm t,tbf02_spec_mill t1,QCM_JUDGE_COIL_RESULT b,tbg02_slab_comm t2 where t.COIL_NO=t1.COIL_NO(+) AND t.SLAB_NO = t2.SLAB_NO and t.OLD_SAMPL_NO=b.coil_no "+swhere1+" "
  20652. + "union all select '' ht_no,'SZ1','酸轧线',SUBSTR(T.SLAB_NO, 1, 10),T.SLAB_NO,SUBSTR(t.OLD_SAMPL_NO, 1, 9), t1.ROLL_MANA_NO, T.OLD_SAMPL_NO, T.ORD_NO || T.ORD_SEQ, "
  20653. + " T.instr_COIL_THK, T.instr_COIL_WTH,T.instr_COIL_LEN,T.ACT_WGT/1000,'','',to_date(substr(t.MILL_DTIME,'0','8'), 'yyyy-mm-dd') PRODUCETIME,b.sizeid, b.SURFACEID surface_id,b.up_surface_result_id_desc,b.ud_surface_result_id_desc,b.INSPECTION_LOT,T.SPEC_STL_GRD,"
  20654. + "T.SPEC_STL_GRD,T.SPEC_ABBSYM,T.SPEC_ABBSYM, T.ORD_USE_CD,PKG_QUALITY_COMM.PK00_COMM('A01007',T.ORD_USE_CD),t.PRODNM_CD,'' psc,'' psc_desc "
  20655. + " from c_tbl02_coil_comm t,c_tbf03_spec_mill t1,QCM_JUDGE_COIL_RESULT b,tbg02_slab_comm t2 where t.COIL_NO=t1.C_COIL_NO(+) AND t.SLAB_NO = t2.SLAB_NO and t.OLD_SAMPL_NO=b.coil_no "+swhere1+""
  20656. + " union all select '' ht_no,'LT1','连退线',SUBSTR(T.SLAB_NO, 1, 10),T.SLAB_NO,SUBSTR(t.OLD_SAMPL_NO, 1, 9), t1.CAL_NO, T.OLD_SAMPL_NO,T.ORD_NO || T.ORD_SEQ, "
  20657. + "T.instr_COIL_THK,T.instr_COIL_WTH,T.instr_COIL_LEN,T.ACT_WGT/1000,'','',to_date(substr(t.MILL_DTIME,'0','8'), 'yyyy-mm-dd') PRODUCETIME,b.sizeid, b.SURFACEID surface_id,b.up_surface_result_id_desc,b.ud_surface_result_id_desc,b.INSPECTION_LOT,T.SPEC_STL_GRD,"
  20658. + "T.SPEC_STL_GRD,T.SPEC_ABBSYM,T.SPEC_ABBSYM, T.ORD_USE_CD,PKG_QUALITY_COMM.PK00_COMM('A01007',T.ORD_USE_CD),t.PRODNM_CD,'' psc,'' psc_desc "
  20659. + " from c_tbc02_coil_comm t,l_tbf03_spec_mill t1,QCM_JUDGE_COIL_RESULT b,tbg02_slab_comm t2 where t.ORI_OLD_SAMPL_NO=t1.C_COIL_NO(+) AND t.SLAB_NO = t2.SLAB_NO and t.OLD_SAMPL_NO=b.coil_no "+swhere1+") where 1= 1 "+swhere+"";
  20660. try {
  20661. System.out.print(sql);
  20662. List<HashMap> list = mapper.query(sql);
  20663. return list;
  20664. } catch (Exception ex) {
  20665. ex.printStackTrace();
  20666. }
  20667. return null;
  20668. }*/
  20669. private void Coil_updateOrdreNo(String pact_no,String pact_seq,String coil_no,String prod_line)throws java.lang.Exception
  20670. {
  20671. Connection conn = null;
  20672. CallableStatement cstmt = null;
  20673. ResultSet rs = null;
  20674. try {
  20675. if(prod_line.equals("RZ1")){
  20676. prod_line = "R";
  20677. pact_no = "39";
  20678. }
  20679. conn = SqlSession.getConnection();
  20680. String callSql = "{call C_JH_ORD_REP.YTH_COIL_STAT(?,?,?,?,?,?,?,?,?,?) }";
  20681. cstmt = conn.prepareCall(callSql);
  20682. cstmt.setString(1, pact_no);
  20683. cstmt.setString(2, pact_seq);
  20684. cstmt.setString(3, "");
  20685. cstmt.setString(4, "");
  20686. cstmt.setString(5, coil_no);
  20687. cstmt.setString(6, prod_line);
  20688. cstmt.setString(7, "JJ");
  20689. cstmt.setString(8, "A");
  20690. cstmt.setString(9, "1");
  20691. cstmt.registerOutParameter(10, java.sql.Types.VARCHAR);
  20692. cstmt.execute();
  20693. if(cstmt.getString(10) != null){
  20694. if(!cstmt.getString(10).equals("脱单成功")){
  20695. throw new java.lang.Exception("脱单失败!");
  20696. }
  20697. }
  20698. } catch (Exception e) {
  20699. throw new Exception(e.getMessage());
  20700. } finally {
  20701. try {
  20702. if (rs != null) {
  20703. rs.close();
  20704. }
  20705. } catch (Exception e) {
  20706. throw new Exception(e.getMessage());
  20707. }
  20708. try {
  20709. if (cstmt != null) {
  20710. cstmt.close();
  20711. }
  20712. } catch (Exception e) {
  20713. throw new Exception(e.getMessage());
  20714. }
  20715. }
  20716. }
  20717. public static String post1(String json,String URL) {
  20718. HttpClient client = new DefaultHttpClient();
  20719. HttpPost post = new HttpPost(URL);
  20720. post.setHeader("Content-Type", "application/x-www-form-urlencoded");
  20721. post.addHeader("Authorization", "Basic YWRtaW46");
  20722. String result = "";
  20723. try {
  20724. StringEntity s = new StringEntity(json, "utf-8");
  20725. s.setContentEncoding(new BasicHeader(HTTP.CONTENT_TYPE,
  20726. "application/json"));
  20727. post.setEntity(s);
  20728. // 发送请求
  20729. HttpResponse httpResponse = client.execute(post);
  20730. // 获取响应输入流
  20731. InputStream inStream = httpResponse.getEntity().getContent();
  20732. BufferedReader reader = new BufferedReader(new InputStreamReader(
  20733. inStream, "utf-8"));
  20734. StringBuilder strber = new StringBuilder();
  20735. String line = null;
  20736. while ((line = reader.readLine()) != null)
  20737. strber.append(line + "\n");
  20738. inStream.close();
  20739. result = strber.toString();
  20740. System.out.println(result);
  20741. if (httpResponse.getStatusLine().getStatusCode() == HttpStatus.SC_OK) {
  20742. System.out.println("请求服务器成功,做相应处理");
  20743. } else {
  20744. System.out.println("请求服务端失败");
  20745. }
  20746. } catch (Exception e) {
  20747. System.out.println("请求异常");
  20748. throw new RuntimeException(e);
  20749. }
  20750. return result;
  20751. }
  20752. @SuppressWarnings("rawtypes")
  20753. public CoreReturnObject doYthLt(ArrayList param1) throws Exception{
  20754. try{
  20755. //连退粗选度放行给一体化重传
  20756. String sqlLT = " select physid,t.inspection_lot,COIL_NO,r.design_key from qcm_jhy_sample_consign_d d,qcm_jhy_sample_r_ord r,qcm_judge_coil_result t "
  20757. +" where d.smp_no = r.smp_no "
  20758. +" and d.inspection_lot = t.inspection_lot "
  20759. +" and r.inspection_lot = t.inspection_lot "
  20760. +" and d.inspection_lot = r.inspection_lot "
  20761. +" and t.COIL_NO ='"+param1.get(0).toString()+"' "
  20762. +" and t.Physresult = '1' "
  20763. +" and r.inspection_lot is not null "
  20764. +" and t.Physid is not null and rownum=1 ";
  20765. List<HashMap> qjcr = mapper.query(sqlLT);
  20766. if(qjcr.size() > 0){
  20767. for(HashMap listcz :qjcr){
  20768. String strinfo="SELECT t.* FROM QCM_JUDGE_ULTIMATE_SENDINFO t where t.result_type = 'P' "
  20769. + " AND t.material_no = '"+listcz.get("COIL_NO")+"' and t.judge_id = '"+listcz.get("PHYSID")+"' ";
  20770. List<HashMap> hm = mapper.query(strinfo);
  20771. if(hm.size() <= 0){
  20772. QcmJudgeUltimateSendinfo qjus = new QcmJudgeUltimateSendinfo();
  20773. qjus.setMaterial_no(listcz.get("COIL_NO")==null?"":listcz.get("COIL_NO").toString());
  20774. qjus.setDesign_key(listcz.get("DESIGN_KEY")==null?"":listcz.get("DESIGN_KEY").toString());
  20775. qjus.setResult_type("P");
  20776. qjus.setJudge_id(listcz.get("PHYSID")==null?"":listcz.get("PHYSID").toString());
  20777. qjus.setCreate_name("sysLT");
  20778. mapper.insertQcmJudgeUltimateSendinfo(qjus);
  20779. SqlSession.commit();
  20780. }
  20781. }
  20782. }
  20783. }catch(Exception e){
  20784. cro.setV_errCode(-1);
  20785. cro.setV_errMsg(e.getMessage());
  20786. SqlSession.rollback();
  20787. logger.info(new Date().toString() + " QCM.QCM03.QCM0307.QcmRejudgeApplyServiceImpl.doYthLt:【" + param1.toString() + "】" + e);
  20788. }
  20789. SqlSession.close();
  20790. return cro;
  20791. }
  20792. }