| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898 |
-
- using Dongke.IBOSS.PRD.Basics.BaseResources;
- using Dongke.IBOSS.PRD.Basics.DataAccess;
- using Dongke.IBOSS.PRD.Basics.Library;
- using Dongke.IBOSS.PRD.Service.WMSDataService;
- using Dongke.IBOSS.PRD.WCF.DataModels;
- using Newtonsoft.Json.Linq;
- using Oracle.ManagedDataAccess.Client;
- using System;
- using System.Collections.Generic;
- using System.Data;
- using System.IO;
- using System.Linq;
- using System.Net;
- using System.Reflection;
- using System.Text;
- using System.Threading;
- namespace Dongke.IBOSS.PRD.Service.SAPHegiiDataService
- {
- public partial class SAPDataLogic
- {
- #region 跨车间作业
- /// <summary>
- /// 同步SAP数据(自动)
- /// </summary>
- /// <param name="date"></param>
- public static void CrossWorkshopToSAP(DateTime date, DateTime ndate)
- {
- IDBTransaction oracleConn = null;
- ServiceResultEntity sre = new ServiceResultEntity();
- OracleParameter[] paras = null;
- int logid = 0;
- string message = string.Empty;
- string sqlString = string.Empty;
- try
- {
- #region 生成日志
- paras = new OracleParameter[]
- {
- new OracleParameter("in_dateend", OracleDbType.Date, ndate, ParameterDirection.Input),
- new OracleParameter("out_logid", OracleDbType.Int32, null, ParameterDirection.Output),
- new OracleParameter("out_msg", OracleDbType.NVarchar2, 500, null, ParameterDirection.Output)
- };
- oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- DataSet ds = oracleConn.ExecStoredProcedure("pro_sap_hegii_workdata_kcjzy", paras);
- int.TryParse(paras[1].Value + "", out logid);
- message = paras[2].Value + "";
- oracleConn.Commit();
- #endregion
- #region 同步SAP
- // 手动推
- //logid = 28;
- oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- sqlString = @"
- SELECT TO_CHAR(B.EXECUTEDATEBEGIN, 'yyyymmddhh24miss') AS ZYWKS,
- TO_CHAR(B.EXECUTEDATEEND - 1 / 24 / 60 / 60, 'yyyymmddhh24miss') AS ZYWJS,
- TO_CHAR(SYSDATE, 'yyyymmddhh24miss') AS ZMONT,
- A.WORKCODE AS WERKS,
- A.SAPCODE AS MATNR,
- A.GOODSCODE AS GROES,
- A.WORKSHOP AS ZSCCJ,
- A.WORKSHOP AS ZSSCJ,
- A.DATACODE AS ZJDNU,
- A.ITEM AS ZZYLX,
- A.NUM AS MENGE,
- 'T' AS ZSCS,
- CASE WHEN A.TESTMOULDFLAG = 1 THEN 'Y' ELSE 'C' END AS ZSCMS,
- '' AS ZTYPE1,
- '' AS ZMSG1
- FROM TSAP_HEGII_WORKDATA_KCJZY A
- INNER JOIN TSAP_HEGII_DATALOG_KCJZY B
- ON B.LOGID = A.LOGID
- WHERE A.LOGID = :LOGID ";
- paras = new OracleParameter[]
- {
- new OracleParameter(":LOGID", OracleDbType.Int32, logid, ParameterDirection.Input),
- };
- DataTable workData = oracleConn.GetSqlResultToDt(sqlString, paras);
- //sqlString = "select SAP_INI_BG from TP_SYS_SAPCONFIG";
- //string SAP_ING_NEW = oracleConn.GetSqlResultToStr(sqlString);
- if (workData != null && workData.Rows.Count > 0)
- {
- string postString = "{\"IT_INPUT\":{\"item\":" + JsonHelper.ToJson(ModelConvertHelper<CrossWorkShopToSAP>.ConvertToModel(workData)) + "}}";
- // 配置文件
- INIUtility ini = INIUtility.Instance(INIUtility.IniFile.SAP_HEGII);
- string url033 = ini.ReadIniData("SAP_NEW_INFO", "Url033");
- // 测试
- //string url033 = "http://hgs4podev.hegii.com:50200/RESTAdapter/DKMES/ZPPFM033";
- // 正式
- //string url033 = "http://hgs4powd1.hegii.com:8000/RESTAdapter/DKMES/ZPPFM033";
- string ztype, msg = string.Empty;
- try
- {
- string result = PostData(url033, postString, "POST");
- ztype = JObject.Parse(result)["ZTYPE"].ToString();
- msg = JObject.Parse(result)["ZMSG"].ToString();
- }
- catch (Exception ex)
- {
- ztype = "E";
- msg = ex.Message;
- }
- sqlString = "update TSAP_HEGII_DATALOG_KCJZY t set t.EndTime = sysdate, DataStuts = :DataStuts, DataMSG =:msg where logid = :logid";
- paras = new OracleParameter[]
- {
- new OracleParameter(":logid", OracleDbType.Varchar2, logid, ParameterDirection.Input),
- new OracleParameter(":DataStuts", OracleDbType.Varchar2, ztype, ParameterDirection.Input),
- new OracleParameter(":msg", OracleDbType.Varchar2, msg, ParameterDirection.Input),
- };
- oracleConn.ExecuteNonQuery(sqlString, paras);
- oracleConn.Commit();
- }
- #endregion
- }
- catch (Exception ex)
- {
- OutputLog.TraceLog(LogPriority.Error,
- "CrossWorkshopToSAP",
- "跨车间作业量" + date.ToString("yyyy-MM-dd HH:mm:ss"),
- ex.ToString(),
- LocalPath.LogExePath + "SAP_HEGII\\Error_");
- }
- finally
- {
- if (oracleConn != null)
- {
- oracleConn.Close();
- }
- }
- }
- public static void CrossWorkshopToSAP_test(DateTime date, DateTime ndate)
- {
- IDBTransaction oracleConn = null;
- ServiceResultEntity sre = new ServiceResultEntity();
- int logid = 0;
- string message = string.Empty;
- string sqlString = string.Empty;
- try
- {
- #region 同步SAP
- oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- //sqlString = "select workcode from tp_mst_account where rownum = 1";
- //string workcode = oracleConn.GetSqlResultToStr(sqlString);
- //workcode = "5000";
- sqlString = @"SELECT
- to_char(:v_datebegin, 'yyyymmddhh24miss') AS ZYWKS,
- to_char(:in_dateend, 'yyyymmddhh24miss') AS ZYWJS,
- to_char(SYSDATE,'yyyymmddhh24miss') AS ZMONT,
- '5000' AS WERKS,
- MATERIALCODE AS MATNR,
- GOODSCODE AS GROES,
- to_char(WORKSHOP) AS ZSCCJ,
- to_char(DATACODE) AS ZJDNU,
- to_char(ITEM) AS ZZYLX,
- to_char(count( * )) AS MENGE,
- 'T' AS ZSCS,
- CASE WHEN TESTMOULDFLAG = 1 THEN 'Y' ELSE 'C' END AS ZSCMS,
- '' AS ZTYPE1,
- '' AS ZMSG1
- FROM
- (--产量
- SELECT
- GDD.MATERIALCODE,
- gdd.goodscode,
- HGDI.WORKSHOP,
- HGDI.DATACODE,
- 1 AS ITEM,
- GDD.TESTMOULDFLAG,
- G.GOODS_LINE_CODE AS ZSCS
- FROM
- TP_PM_PRODUCTIONDATA PD
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD ON GDD.GROUTINGDAILYDETAILID = PD.GROUTINGDAILYDETAILID
- INNER JOIN TP_MST_GOODS G ON PD.GOODSID = G.GOODSID
- INNER JOIN TP_MST_GOODSTYPE GT ON GT.GOODSTYPEID = G.GOODSTYPEID
- INNER JOIN TSAP_HEGII_DATAITEM HGDI ON(HGDI.DATACODE = '30' OR HGDI.DATACODE = '40' OR HGDI.DATACODE = '50')
- AND HGDI.ITEMTYPE = 1
- AND HGDI.ITEMID = PD.PROCEDUREID
- AND(HGDI.ITEMID <> 104 OR(PD.ISREFIRE = '0' AND PD.CHECKFLAG = '1'))
- WHERE
- PD.VALUEFLAG = 1
- AND PD.CREATETIME >= :v_datebegin
- AND PD.CREATETIME < :in_dateend
- AND(
- (HGDI.WORKSHOP = 2 AND INSTR(GDD.GROUTINGLINECODE, 'C') = 1)
- OR(
- HGDI.WORKSHOP = 3
- AND(INSTR(GDD.GROUTINGLINECODE, 'B') = 1 OR INSTR(GDD.GROUTINGLINECODE, 'D') = 1)
- )
- )
- AND INSTR(GT.GOODSTYPECODE, '001001' ) = 1
- UNION ALL
- --产量撤销
- SELECT
- GDD.MATERIALCODE,
- GDD.goodscode,
- HGDI.WORKSHOP,
- HGDI.DATACODE AS DATACODE,
- 2 AS ITEM,
- GDD.TESTMOULDFLAG,
- G.GOODS_LINE_CODE AS ZSCS
- FROM
- TP_PM_PRODUCTIONDATA PD
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD ON GDD.GROUTINGDAILYDETAILID = PD.GROUTINGDAILYDETAILID
- INNER JOIN TP_MST_GOODS G ON PD.GOODSID = G.GOODSID
- INNER JOIN TP_MST_GOODSTYPE GT ON GT.GOODSTYPEID = G.GOODSTYPEID
- INNER JOIN TSAP_HEGII_DATAITEM HGDI ON(HGDI.DATACODE = '30' OR HGDI.DATACODE = '40' OR HGDI.DATACODE = '50')
- AND HGDI.ITEMID = PD.PROCEDUREID
- AND(HGDI.ITEMID <> 104 OR(PD.ISREFIRE = '0' AND PD.CHECKFLAG = '1'))
- WHERE
- PD.VALUEFLAG = 0
- AND PD.BACKOUTTIME >= :v_datebegin
- AND PD.BACKOUTTIME < :in_dateend
- AND(
- (HGDI.WORKSHOP = 2 AND INSTR(GDD.GROUTINGLINECODE, 'C') = 1)
- OR(
- HGDI.WORKSHOP = 3
- AND(INSTR(GDD.GROUTINGLINECODE, 'B') = 1 OR INSTR(GDD.GROUTINGLINECODE, 'D') = 1)
- )
- )
- AND INSTR(GT.GOODSTYPECODE, '001001' ) = 1-- 工序报损
- UNION ALL
- SELECT
- GDD.MATERIALCODE,
- GDD.goodscode,
- HGDI.WORKSHOP,
- HGDI.DATACODE AS DATACODE,
- 3 AS ITEM,
- GDD.TESTMOULDFLAG,
- G.GOODS_LINE_CODE AS ZSCS
- FROM
- TP_PM_SCRAPPRODUCT SP
- INNER JOIN tp_pm_productiondata pd ON pd.productiondataid = sp.productiondataid
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD ON GDD.GROUTINGDAILYDETAILID = PD.GROUTINGDAILYDETAILID
- INNER JOIN TP_MST_GOODS G ON PD.GOODSID = G.GOODSID
- INNER JOIN TP_MST_GOODSTYPE GT ON GT.GOODSTYPEID = G.GOODSTYPEID
- INNER JOIN TSAP_HEGII_DATAITEM HGDI ON(HGDI.DATACODE = '30' OR HGDI.DATACODE = '40' OR HGDI.DATACODE = '50')
- AND HGDI.ITEMTYPE = 2
- AND HGDI.ITEMID = PD.PROCEDUREID
- AND(HGDI.ITEMID <> 104 OR(PD.ISREFIRE = '0' AND PD.CHECKFLAG = '1'))
- WHERE
- SP.AUDITSTATUS = 1
- AND SP.AUDITDATE >= :v_datebegin
- AND SP.AUDITDATE < :in_dateend
- AND(
- (HGDI.WORKSHOP = 2 AND INSTR(GDD.GROUTINGLINECODE, 'C') = 1)
- OR(
- HGDI.WORKSHOP = 3
- AND(INSTR(GDD.GROUTINGLINECODE, 'B') = 1 OR INSTR(GDD.GROUTINGLINECODE, 'D') = 1)
- )
- )
- AND INSTR(GT.GOODSTYPECODE, '001001' ) = 1-- 工序报损撤销
- UNION ALL
- SELECT
- GDD.MATERIALCODE,
- GDD.goodscode,
- HGDI.WORKSHOP,
- HGDI.DATACODE AS DATACODE,
- 4 AS ITEM,
- GDD.TESTMOULDFLAG,
- G.GOODS_LINE_CODE AS ZSCS
- FROM
- TP_PM_SCRAPPRODUCT SP
- INNER JOIN tp_pm_productiondata pd ON pd.productiondataid = sp.productiondataid
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD ON GDD.GROUTINGDAILYDETAILID = PD.GROUTINGDAILYDETAILID
- INNER JOIN TP_MST_GOODS G ON PD.GOODSID = G.GOODSID
- INNER JOIN TP_MST_GOODSTYPE GT ON GT.GOODSTYPEID = G.GOODSTYPEID
- INNER JOIN TSAP_HEGII_DATAITEM HGDI ON(HGDI.DATACODE = '30' OR HGDI.DATACODE = '40' OR HGDI.DATACODE = '50')
- AND HGDI.ITEMTYPE = 2
- AND HGDI.ITEMID = PD.PROCEDUREID
- AND(HGDI.ITEMID <> 104 OR(PD.ISREFIRE = '0' AND PD.CHECKFLAG = '1'))
- WHERE
- SP.AUDITSTATUS = 1
- AND SP.VALUEFLAG = '0'
- AND SP.BACKOUTTIME >= :v_datebegin
- AND SP.BACKOUTTIME < :in_dateend
- AND(
- (HGDI.WORKSHOP = 2 AND INSTR(GDD.GROUTINGLINECODE, 'C') = 1)
- OR(
- HGDI.WORKSHOP = 3
- AND(INSTR(GDD.GROUTINGLINECODE, 'B') = 1 OR INSTR(GDD.GROUTINGLINECODE, 'D') = 1)
- )
- )
- AND INSTR(GT.GOODSTYPECODE, '001001' ) = 1-- 盘点清除
- UNION ALL
- SELECT
- GDD.MATERIALCODE,
- GDD.GOODSCODE,
- HGDI.WORKSHOP,
- HGDI.DATACODE,
- 5 AS ITEM,
- GDD.TESTMOULDFLAG ,
- G.GOODS_LINE_CODE AS ZSCS
- FROM
- TP_PM_GOODSCHANGEHISTORY GH
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD ON GDD.GROUTINGDAILYDETAILID = GH.GROUTINGDAILYDETAILID
- INNER JOIN TP_MST_GOODS G ON GH.GOODSID = G.GOODSID
- INNER JOIN TP_MST_GOODSTYPE GT ON GT.GOODSTYPEID = G.GOODSTYPEID
- INNER JOIN TSAP_HEGII_DATAITEM HGDI ON(HGDI.DATACODE = '30' OR HGDI.DATACODE = '40' OR HGDI.DATACODE = '50')
- AND HGDI.ITEMTYPE = 2
- AND HGDI.ITEMID = GH.OTHERID
- WHERE
- GH.CREATETIME >= :v_datebegin
- AND GH.CREATETIME < :in_dateend
- AND GH.DATATYPE IN( 11, 12 )
- AND(
- (HGDI.WORKSHOP = 2 AND INSTR(GDD.GROUTINGLINECODE, 'C') = 1)
- OR(
- HGDI.WORKSHOP = 3
- AND(INSTR(GDD.GROUTINGLINECODE, 'B') = 1 OR INSTR(GDD.GROUTINGLINECODE, 'D') = 1)
- )
- )
- AND INSTR(GT.GOODSTYPECODE, '001001' ) = 1-- 干补
- UNION ALL
- SELECT
- GDD.MATERIALCODE,
- GDD.GOODSCODE,
- HGDI.WORKSHOP,
- HGDI.DATACODE,
- 6 AS ITEM,
- GDD.TESTMOULDFLAG,
- G.GOODS_LINE_CODE AS ZSCS
- FROM
- TP_PM_SCRAPPRODUCT SP
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD ON GDD.GROUTINGDAILYDETAILID = SP.GROUTINGDAILYDETAILID
- INNER JOIN TP_MST_GOODS G ON SP.GOODSID = G.GOODSID
- INNER JOIN TP_MST_GOODSTYPE GT ON GT.GOODSTYPEID = G.GOODSTYPEID
- INNER JOIN TSAP_HEGII_DATAITEM HGDI ON(HGDI.DATACODE = '30' OR HGDI.DATACODE = '40' OR HGDI.DATACODE = '50')
- AND HGDI.ITEMTYPE = 2
- AND HGDI.ITEMID = SP.PROCEDUREID
- WHERE
- SP.AUDITSTATUS = 1
- AND SP.VALUEFLAG = '1'
- AND SP.GOODSLEVELTYPEID = 9
- AND SP.SPECIALREPAIRTIME >= :v_datebegin
- AND SP.SPECIALREPAIRTIME < :in_dateend
- AND(
- (HGDI.WORKSHOP = 2 AND INSTR(GDD.GROUTINGLINECODE, 'C') = 1)
- OR(
- HGDI.WORKSHOP = 3
- AND(INSTR(GDD.GROUTINGLINECODE, 'B') = 1 OR INSTR(GDD.GROUTINGLINECODE, 'D') = 1)
- )
- )
- AND INSTR(GT.GOODSTYPECODE, '001001' ) = 1-- 回收
- UNION ALL
- SELECT
- GDD.MATERIALCODE,
- GDD.GOODSCODE,
- HGDI.WORKSHOP,
- HGDI.DATACODE,
- 7 AS ITEM,
- GDD.TESTMOULDFLAG,
- G.GOODS_LINE_CODE AS ZSCS
- FROM
- TP_PM_SCRAPPRODUCT SP
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD ON GDD.GROUTINGDAILYDETAILID = SP.GROUTINGDAILYDETAILID
- INNER JOIN TP_MST_GOODS G ON SP.GOODSID = G.GOODSID
- INNER JOIN TP_MST_GOODSTYPE GT ON GT.GOODSTYPEID = G.GOODSTYPEID
- INNER JOIN TSAP_HEGII_DATAITEM HGDI ON(HGDI.DATACODE = '30' OR HGDI.DATACODE = '40' OR HGDI.DATACODE = '50')
- AND HGDI.ITEMTYPE = 2
- AND HGDI.ITEMID = SP.PROCEDUREID
- WHERE
- SP.AUDITSTATUS = 1
- AND SP.VALUEFLAG = '1'
- AND SP.RECYCLINGFLAG = '1'
- AND SP.RECYCLINGTIME >= :v_datebegin
- AND SP.RECYCLINGTIME < :in_dateend
- AND(
- (HGDI.WORKSHOP = 2 AND INSTR(GDD.GROUTINGLINECODE, 'C') = 1)
- OR(
- HGDI.WORKSHOP = 3
- AND(INSTR(GDD.GROUTINGLINECODE, 'B') = 1 OR INSTR(GDD.GROUTINGLINECODE, 'D') = 1)
- )
- )
- AND INSTR(GT.GOODSTYPECODE, '001001' ) = 1
- )
- GROUP BY
- MATERIALCODE,
- GOODSCODE,
- WORKSHOP,
- DATACODE,
- ITEM,
- TESTMOULDFLAG,
- ZSCS
- ORDER BY
- DATACODE,
- ITEM,
- WORKSHOP";
- OracleParameter[] paras = new OracleParameter[]
- {
- new OracleParameter(":v_datebegin", OracleDbType.Date, date, ParameterDirection.Input),
- new OracleParameter(":in_dateend", OracleDbType.Date, ndate, ParameterDirection.Input),
- };
- DataTable workData = oracleConn.GetSqlResultToDt(sqlString, paras);
- sqlString = "select SAP_INI_BG from TP_SYS_SAPCONFIG";
- string SAP_ING_NEW = oracleConn.GetSqlResultToStr(sqlString);
- if (workData != null && workData.Rows.Count > 0 && SAP_ING_NEW == "0")
- {
- string postString = "{\"IT_INPUT\":{\"item\":" + JsonHelper.ToJson(ModelConvertHelper<CrossWorkShopToSAP>.ConvertToModel(workData)) + "}}";
- //INIUtility ini = INIUtility.Instance(INIUtility.IniFile.SAP_HEGII);
- //string url033 = ini.ReadIniData("SAP_NEW_INFO", "Url033");
- string url033 = "http://hgs4podev.hegii.com:50200/RESTAdapter/DKMES/ZPPFM033";
- string result = PostData(url033, postString, "POST");
- string ztype = JObject.Parse(result)["ZTYPE"].ToString();
- string msg = JObject.Parse(result)["ZMSG"].ToString();
- //sqlString = "update TSAP_HEGII_DATALOG_KCJZY t set t.EndTime = sysdate, DataStuts = :DataStuts, DataMSG =:msg where logid = :logid";
- //paras = new OracleParameter[]
- //{
- // new OracleParameter(":logid", OracleDbType.Varchar2, logid, ParameterDirection.Input),
- // new OracleParameter(":DataStuts", OracleDbType.Varchar2, ztype, ParameterDirection.Input),
- // new OracleParameter(":msg", OracleDbType.Varchar2, msg, ParameterDirection.Input),
- //};
- //oracleConn.ExecuteNonQuery(sqlString, paras);
- oracleConn.Commit();
- }
- #endregion
- }
- catch (Exception ex)
- {
- OutputLog.TraceLog(LogPriority.Error,
- "CrossWorkshopToSAP",
- "跨车间作业量" + date.ToString("yyyy-MM-dd HH:mm:ss"),
- ex.ToString(),
- LocalPath.LogExePath + "SAP_HEGII\\Error_");
- }
- finally
- {
- if (oracleConn != null)
- {
- oracleConn.Close();
- }
- }
- }
- /// <summary>
- /// 查询跨车间作业同步日志
- /// </summary>
- /// <param name="cre"></param>
- /// <param name="userInfo"></param>
- /// <returns></returns>
- public static ServiceResultEntity GetDataLog_kczzy(ClientRequestEntity cre)
- {
- IDBConnection oracleConn = ClsDbFactory.CreateDBConnection(DataBaseType.ORACLE, DataManager.ConnectionString);
- ServiceResultEntity sre = new ServiceResultEntity();
- try
- {
- string sqlString = "SELECT\n" +
- " dl.logid,\n" +
- " dl.begintime,\n" +
- " dl.endtime,\n" +
- " dl.yyyymmdd,\n" +
- " dl.workcode,\n" +
- " dl.datastuts,\n" +
- " dl.datamsg,\n" +
- " dl.executedatebegin,\n" +
- " dl.executedateend,\n" +
- " u.usercode synusercode\n" +
- "FROM\n" +
- " tsap_hegii_datalog_kcjzy dl\n" +
- " LEFT JOIN tp_mst_user u ON u.userid = dl.createuserid \n" +
- "WHERE\n" +
- " dl.EXECUTEDATEBEGIN >= :datebegin \n" +
- " AND dl.EXECUTEDATEEND <= :dateend \n";
- OracleParameter[] oracleParameter = new OracleParameter[]
- {
- new OracleParameter(":datebegin",OracleDbType.Date, cre.Properties["datebegin"], ParameterDirection.Input),
- new OracleParameter(":dateend",OracleDbType.Date, cre.Properties["dateend"], ParameterDirection.Input),
- };
- string datastuts = cre.Properties["datastuts"] + "";
- if (!string.IsNullOrEmpty(datastuts))
- {
- sqlString += " and dl.datastuts in (" + datastuts + ")\n";
- }
- sqlString += "ORDER BY dl.logid DESC\n";
- sre.Data = oracleConn.GetSqlResultToDs(sqlString, oracleParameter);
- return sre;
- }
- catch (Exception ex)
- {
- throw ex;
- }
- finally
- {
- if (oracleConn != null)
- {
- oracleConn.Close();
- }
- }
- }
- /// <summary>
- /// 查询同步明细
- /// </summary>
- /// <param name="logid"></param>
- /// <param name="userInfo"></param>
- /// <returns></returns>
- public static ServiceResultEntity GetWorkData_kczzy(ClientRequestEntity cre)
- {
- IDBConnection oracleConn = ClsDbFactory.CreateDBConnection(DataBaseType.ORACLE, DataManager.ConnectionString);
- ServiceResultEntity sre = new ServiceResultEntity();
- try
- {
- int logid = Convert.ToInt32(cre.Request);
- string sqlString = "\n" +
- "select wd.workshop\n" +
- " ,case when wd.workshop = 2 then '二车间' when wd.workshop = 3 then '三车间' else '-' end workshopname\n " +
- " ,case when wd.item = 1 then '产量' when wd.item = 2 then '产量撤销' when wd.item = 3 then '工序报损' when wd.item = 4 then '工序报损撤销' \n" +
- " when wd.item = 5 then '盘点清除' when wd.item = 6 then '干补' when wd.item = 7 then '回收' else '-' end as itemname\n" +
- " ,item\n" +
- " ,wd.datacode\n" +
- " ,dc.datacodename\n" +
- " ,wd.goodscode\n" +
- " ,wd.sapcode\n" +
- " ,wd.num\n" +
- " ,wd.createtime\n" +
- " ,wd.testmouldflag\n" +
- " ,wd.zscs\n" +
- " ,case when wd.zscs = 'L' then '立浇【L】' when wd.zscs = 'G' then '高压【G】' when wd.zscs = 'M' then '粘接高压(三水厂)【M】' when wd.zscs = 'Q' then '吊装线【Q】' else '-' end as zscsname\n" +
- " ,wd.logid\n" +
- " from tsap_hegii_workdata_kcjzy wd\n" +
- " inner join tsap_hegii_datacode dc\n" +
- " on dc.datacode = wd.datacode\n";
- if (logid > 0)
- {
- sqlString += " where wd.logid = :logid \n";
- }
- else
- {
- sqlString += " inner join tsap_hegii_datalog_kcjzy dl\n" +
- " on wd.logid=dl.logid \n" +
- " where dl.EXECUTEDATEBEGIN>= :datebegin \n" +
- " and dl.EXECUTEDATEEND<= :dateend \n";
- }
- sqlString += " order by wd.datacode,wd.item,wd.workshop \n";
- OracleParameter[] oracleParameter = new OracleParameter[]
- {
- new OracleParameter(":logid",OracleDbType.Int32, logid, ParameterDirection.Input),
- new OracleParameter(":datebegin",OracleDbType.Date, cre.Properties["datebegin"], ParameterDirection.Input),
- new OracleParameter(":dateend",OracleDbType.Date, cre.Properties["dateend"], ParameterDirection.Input),
- };
- sre.Data = oracleConn.GetSqlResultToDs(sqlString, oracleParameter);
- return sre;
- }
- catch (Exception ex)
- {
- throw ex;
- }
- finally
- {
- if (oracleConn != null)
- {
- oracleConn.Close();
- }
- }
- }
- #endregion
- #region 报工
- ///// <summary>
- ///// 同步SAP数据(自动)
- ///// </summary>
- ///// <param name="date"></param>
- //public static void AutoWorkDataToSAP5000(DateTime date, string funCode)
- //{
- // if (string.IsNullOrWhiteSpace(funCode))
- // {
- // //return;
- // funCode = "ALL";
- // }
- // funCode = "," + funCode + ",";
- // ServiceResultEntity sre = null;
- // // 10 模具
- // if (funCode == ",ALL," || funCode.Contains(",10,"))
- // {
- // try
- // {
- // sre = SetWorkData10_50(date, "10", 0);
- // if (sre.Status != Constant.ServiceResultStatus.Success ||
- // "S" != sre.Result + "")
- // {
- // OutputLog.TraceLog(LogPriority.Warning,
- // "AutoWorkDataToSAP",
- // "10 模具 " + date.ToString("yyyy-MM-dd HH:mm:ss"),
- // JsonHelper.ToJson(sre),
- // LocalPath.LogExePath + "SAP_HEGII\\Warn_");
- // }
- // }
- // catch (Exception ex)
- // {
- // OutputLog.TraceLog(LogPriority.Error,
- // "AutoWorkDataToSAP",
- // "10 模具 " + date.ToString("yyyy-MM-dd HH:mm:ss"),
- // ex.ToString(),
- // LocalPath.LogExePath + "SAP_HEGII\\Error_");
- // }
- // }
- // // 20 湿坯
- // if (funCode == ",ALL," || funCode.Contains(",20,"))
- // {
- // try
- // {
- // sre = SetWorkData10_50(date, "20", 0);
- // if (sre.Status != Constant.ServiceResultStatus.Success ||
- // "S" != sre.Result + "")
- // {
- // OutputLog.TraceLog(LogPriority.Warning,
- // "AutoWorkDataToSAP",
- // "20 湿坯 " + date.ToString("yyyy-MM-dd HH:mm:ss"),
- // JsonHelper.ToJson(sre),
- // LocalPath.LogExePath + "SAP_HEGII\\Warn_");
- // }
- // }
- // catch (Exception ex)
- // {
- // OutputLog.TraceLog(LogPriority.Error,
- // "AutoWorkDataToSAP",
- // "20 湿坯 " + date.ToString("yyyy-MM-dd HH:mm:ss"),
- // ex.ToString(),
- // LocalPath.LogExePath + "SAP_HEGII\\Error_");
- // }
- // }
- // // 30 精坯
- // if (funCode == ",ALL," || funCode.Contains(",30,"))
- // {
- // try
- // {
- // sre = SetWorkData10_50(date, "30", 0);
- // if (sre.Status != Constant.ServiceResultStatus.Success ||
- // "S" != sre.Result + "")
- // {
- // OutputLog.TraceLog(LogPriority.Warning,
- // "AutoWorkDataToSAP",
- // "30 精坯 " + date.ToString("yyyy-MM-dd HH:mm:ss"),
- // JsonHelper.ToJson(sre),
- // LocalPath.LogExePath + "SAP_HEGII\\Warn_");
- // }
- // }
- // catch (Exception ex)
- // {
- // OutputLog.TraceLog(LogPriority.Error,
- // "AutoWorkDataToSAP",
- // "30 精坯 " + date.ToString("yyyy-MM-dd HH:mm:ss"),
- // ex.ToString(),
- // LocalPath.LogExePath + "SAP_HEGII\\Error_");
- // }
- // }
- // // 40 釉坯
- // if (funCode == ",ALL," || funCode.Contains(",40,"))
- // {
- // try
- // {
- // sre = SetWorkData10_50(date, "40", 0);
- // if (sre.Status != Constant.ServiceResultStatus.Success ||
- // "S" != sre.Result + "")
- // {
- // OutputLog.TraceLog(LogPriority.Warning,
- // "AutoWorkDataToSAP",
- // "40 釉坯 " + date.ToString("yyyy-MM-dd HH:mm:ss"),
- // JsonHelper.ToJson(sre),
- // LocalPath.LogExePath + "SAP_HEGII\\Warn_");
- // }
- // }
- // catch (Exception ex)
- // {
- // OutputLog.TraceLog(LogPriority.Error,
- // "AutoWorkDataToSAP",
- // "40 釉坯 " + date.ToString("yyyy-MM-dd HH:mm:ss"),
- // ex.ToString(),
- // LocalPath.LogExePath + "SAP_HEGII\\Error_");
- // }
- // }
- // // 50 烧成
- // if (funCode == ",ALL," || funCode.Contains(",50,"))
- // {
- // try
- // {
- // sre = SetWorkData10_50(date, "50", 0);
- // if (sre.Status != Constant.ServiceResultStatus.Success ||
- // "S" != sre.Result + "")
- // {
- // OutputLog.TraceLog(LogPriority.Warning,
- // "AutoWorkDataToSAP",
- // "50 烧成 " + date.ToString("yyyy-MM-dd HH:mm:ss"),
- // JsonHelper.ToJson(sre),
- // LocalPath.LogExePath + "SAP_HEGII\\Warn_");
- // }
- // }
- // catch (Exception ex)
- // {
- // OutputLog.TraceLog(LogPriority.Error,
- // "AutoWorkDataToSAP",
- // "50 烧成 " + date.ToString("yyyy-MM-dd HH:mm:ss"),
- // ex.ToString(),
- // LocalPath.LogExePath + "SAP_HEGII\\Error_");
- // }
- // }
- // //// 6001 成品明细
- // //if (funCode == ",ALL," || funCode.Contains(",6001,"))
- // //{
- // // try
- // // {
- // // sre = SetFP6001(date, 0);
- // // if (sre.Status != Constant.ServiceResultStatus.Success ||
- // // "S" != sre.Result + "")
- // // {
- // // OutputLog.TraceLog(LogPriority.Warning,
- // // "AutoWorkDataToSAP",
- // // "6001 成品明细 " + date.ToString("yyyy-MM-dd HH:mm:ss"),
- // // JsonHelper.ToJson(sre),
- // // LocalPath.LogExePath + "SAP_HEGII\\Warn_");
- // // }
- // // }
- // // catch (Exception ex)
- // // {
- // // OutputLog.TraceLog(LogPriority.Error,
- // // "AutoWorkDataToSAP",
- // // "6001 成品明细 " + date.ToString("yyyy-MM-dd HH:mm:ss"),
- // // ex.ToString(),
- // // LocalPath.LogExePath + "SAP_HEGII\\Error_");
- // // }
- // //}
- // //// 6001 成品明细(小时)-20分钟
- // //if (funCode == ",6002,")
- // //{
- // // try
- // // {
- // // sre = SetFP6002(date, 0);
- // // if (sre.Status != Constant.ServiceResultStatus.Success ||
- // // "S" != sre.Result + "")
- // // {
- // // OutputLog.TraceLog(LogPriority.Warning,
- // // "AutoWorkDataToSAP",
- // // "6002 成品明细(小时) " + date.ToString("yyyy-MM-dd HH:mm:ss"),
- // // JsonHelper.ToJson(sre),
- // // LocalPath.LogExePath + "SAP_HEGII\\Warn_");
- // // }
- // // }
- // // catch (Exception ex)
- // // {
- // // OutputLog.TraceLog(LogPriority.Error,
- // // "AutoWorkDataToSAP",
- // // "6002 成品明细(小时) " + date.ToString("yyyy-MM-dd HH:mm:ss"),
- // // ex.ToString(),
- // // LocalPath.LogExePath + "SAP_HEGII\\Error_");
- // // }
- // //}
- //}
- /// <summary>
- /// 同步SAP数据(自动)(重载)
- /// </summary>
- /// <param name="date">当前时间</param>
- /// <param name="funCode">工序码</param>
- /// <param name="ndate">本次要执行到的时间</param>
- public static void AutoWorkDataToSAP5000(string funCode, DateTime ndate)
- {
- if (string.IsNullOrWhiteSpace(funCode))
- {
- //return;
- funCode = "ALL";
- }
- funCode = "," + funCode + ",";
- ServiceResultEntity sre = null;
- // 1001 模具生产
- if (funCode == ",ALL," || funCode.Contains(",1001,"))
- {
- try
- {
- sre = SetWorkData1001_5000("1001", ndate);
- if (sre.Status != Constant.ServiceResultStatus.Success ||
- "S" != sre.Result + "")
- {
- OutputLog.TraceLog(LogPriority.Warning,
- "AutoWorkDataToSAP5000",
- "1001 模具生产 " + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- JsonHelper.ToJson(sre),
- LocalPath.LogExePath + "SAP_HEGII\\Warn_");
- }
- }
- catch (Exception ex)
- {
- OutputLog.TraceLog(LogPriority.Error,
- "AutoWorkDataToSAP5000",
- "1001 模具生产 " + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- ex.ToString(),
- LocalPath.LogExePath + "SAP_HEGII\\Error_");
- }
- }
- // 10 模具
- if (funCode == ",ALL," || funCode.Contains(",10,"))
- {
- try
- {
- sre = SetWorkData10_50_5000("10", ndate);
- if (sre.Status != Constant.ServiceResultStatus.Success ||
- "S" != sre.Result + "")
- {
- OutputLog.TraceLog(LogPriority.Warning,
- "AutoWorkDataToSAP5000",
- "10 模具 " + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- JsonHelper.ToJson(sre),
- LocalPath.LogExePath + "SAP_HEGII\\Warn_");
- }
- }
- catch (Exception ex)
- {
- OutputLog.TraceLog(LogPriority.Error,
- "AutoWorkDataToSAP5000",
- "10 模具 " + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- ex.ToString(),
- LocalPath.LogExePath + "SAP_HEGII\\Error_");
- }
- }
- // 20 湿坯
- if (funCode == ",ALL," || funCode.Contains(",20,"))
- {
- try
- {
- sre = SetWorkData10_50_5000("20", ndate);
- if (sre.Status != Constant.ServiceResultStatus.Success ||
- "S" != sre.Result + "")
- {
- OutputLog.TraceLog(LogPriority.Warning,
- "AutoWorkDataToSAP5000",
- "20 湿坯 " + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- JsonHelper.ToJson(sre),
- LocalPath.LogExePath + "SAP_HEGII\\Warn_");
- }
- }
- catch (Exception ex)
- {
- OutputLog.TraceLog(LogPriority.Error,
- "AutoWorkDataToSAP5000",
- "20 湿坯 " + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- ex.ToString(),
- LocalPath.LogExePath + "SAP_HEGII\\Error_");
- }
- }
- // 30 精坯
- if (funCode == ",ALL," || funCode.Contains(",30,"))
- {
- try
- {
- sre = SetWorkData10_50_5000("30", ndate);
- if (sre.Status != Constant.ServiceResultStatus.Success ||
- "S" != sre.Result + "")
- {
- OutputLog.TraceLog(LogPriority.Warning,
- "AutoWorkDataToSAP5000",
- "30 精坯 " + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- JsonHelper.ToJson(sre),
- LocalPath.LogExePath + "SAP_HEGII\\Warn_");
- }
- }
- catch (Exception ex)
- {
- OutputLog.TraceLog(LogPriority.Error,
- "AutoWorkDataToSAP5000",
- "30 精坯 " + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- ex.ToString(),
- LocalPath.LogExePath + "SAP_HEGII\\Error_");
- }
- }
- // 40 釉坯
- if (funCode == ",ALL," || funCode.Contains(",40,"))
- {
- try
- {
- sre = SetWorkData10_50_5000("40", ndate);
- if (sre.Status != Constant.ServiceResultStatus.Success ||
- "S" != sre.Result + "")
- {
- OutputLog.TraceLog(LogPriority.Warning,
- "AutoWorkDataToSAP5000",
- "40 釉坯 " + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- JsonHelper.ToJson(sre),
- LocalPath.LogExePath + "SAP_HEGII\\Warn_");
- }
- }
- catch (Exception ex)
- {
- OutputLog.TraceLog(LogPriority.Error,
- "AutoWorkDataToSAP5000",
- "40 釉坯 " + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- ex.ToString(),
- LocalPath.LogExePath + "SAP_HEGII\\Error_");
- }
- }
- // 50 烧成
- if (funCode == ",ALL," || funCode.Contains(",50,"))
- {
- try
- {
- sre = SetWorkData10_50_5000("50", ndate);
- if (sre.Status != Constant.ServiceResultStatus.Success ||
- "S" != sre.Result + "")
- {
- OutputLog.TraceLog(LogPriority.Warning,
- "AutoWorkDataToSAP5000",
- "50 烧成 " + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- JsonHelper.ToJson(sre),
- LocalPath.LogExePath + "SAP_HEGII\\Warn_");
- }
- }
- catch (Exception ex)
- {
- OutputLog.TraceLog(LogPriority.Error,
- "AutoWorkDataToSAP5000",
- "50 烧成 " + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- ex.ToString(),
- LocalPath.LogExePath + "SAP_HEGII\\Error_");
- }
- }
- // 55 裸辞包装
- if (funCode == ",ALL," || funCode.Contains(",55,"))
- {
- try
- {
- sre = SetWorkData10_50_5000("55", ndate);
- if (sre.Status != Constant.ServiceResultStatus.Success ||
- "S" != sre.Result + "")
- {
- OutputLog.TraceLog(LogPriority.Warning,
- "AutoWorkDataToSAP5000",
- "55 裸辞包装 " + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- JsonHelper.ToJson(sre),
- LocalPath.LogExePath + "SAP_HEGII\\Warn_");
- }
- }
- catch (Exception ex)
- {
- OutputLog.TraceLog(LogPriority.Error,
- "AutoWorkDataToSAP5000",
- "55 裸辞包装" + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- ex.ToString(),
- LocalPath.LogExePath + "SAP_HEGII\\Error_");
- }
- }
- // 60 产成品
- if (funCode == ",ALL," || funCode.Contains(",60,"))
- {
- try
- {
- sre = SyncSap5000_60(ndate);
- if (sre.Status != Constant.ServiceResultStatus.Success ||
- "S" != sre.Result + "")
- {
- OutputLog.TraceLog(LogPriority.Warning,
- "AutoWorkDataToSAP5000",
- "60 产成品 " + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- JsonHelper.ToJson(sre),
- LocalPath.LogExePath + "SAP_HEGII\\Warn_");
- }
- }
- catch (Exception ex)
- {
- OutputLog.TraceLog(LogPriority.Error,
- "AutoWorkDataToSAP5000",
- "60 产成品 " + ndate.ToString("yyyy-MM-dd HH:mm:ss"),
- ex.ToString(),
- LocalPath.LogExePath + "SAP_HEGII\\Error_");
- }
- }
- }
- /// <summary>
- /// 商标变更插入数据
- /// </summary>
- /// <param name="date">当前时间</param>
- /// <param name="ndate">本次要执行到的时间</param>
- public static void AutoWorkDataToSAP5000SBBG(DateTime ndate)
- {
- IDBTransaction oracleTrConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- ServiceResultEntity sre = new ServiceResultEntity();
- try
- {
- // 查询该时间段内的所有商标变更 的条码
- string sqlString = "SELECT T.*\n" +
- " FROM (SELECT lh.barcode\n" +
- " ,lh.oldlogoid\n" +
- " ,nvl(gls.materialcode, g.materialcode) materialcode\n" +
- " ,nvl(gls1.materialcode, g.materialcode) newmaterialcode\n" +
- " ,lh.newlogoid\n" +
- " ,gdd.goodsid\n" +
- " ,lh.createtime\n" +
- " ,lh.SAPFLAG\n" +
- " FROM tp_pm_logochangedrecord lh\n" +
- " LEFT JOIN tp_pm_groutingdailydetail gdd\n" +
- " ON gdd.barcode = lh.barcode\n" +
- " INNER JOIN tp_mst_goods g\n" +
- " ON g.goodsid = gdd.goodsid\n" +
- " LEFT JOIN tp_mst_goodslogosap gls\n" +
- " ON gdd.goodsid = gls.goodsid\n" +
- " AND gls.logoid = lh.oldlogoid\n" +
- " LEFT JOIN tp_mst_goodslogosap gls1\n" +
- " ON gdd.goodsid = gls1.goodsid\n" +
- " AND gls1.logoid = lh.newlogoid\n" +
- " WHERE lh.createtime >= DATE '2024-03-01'\n" +
- " AND lh.SAPFLAG = 0 " +
- " AND lh.oldlogoid <> lh.newlogoid " +
- " AND nvl(gls.materialcode, g.materialcode) <> nvl(gls1.materialcode, g.materialcode) " +
- " order by lh.createtime) T\n" +
- " WHERE rownum < 15";
- DataTable barcodeTable = oracleTrConn.GetSqlResultToDt(sqlString, null);
- int returnRows = 0;
- if (barcodeTable != null && barcodeTable.Rows.Count > 0)
- {
- for (int i = 0; i < barcodeTable.Rows.Count; i++)
- {
- string barcode = barcodeTable.Rows[i]["barcode"].ToString();
- string oldMatnr = barcodeTable.Rows[i]["materialcode"].ToString();
- string newMatnr = barcodeTable.Rows[i]["newmaterialcode"].ToString();
- string cretetime = barcodeTable.Rows[i]["createtime"].ToString();
- int logoid = Convert.ToInt32(barcodeTable.Rows[i]["newlogoid"]);
- if (oldMatnr != newMatnr)
- {
- #region 先查询sap数据
- DataSet sapDataSet = new DataSet();
- //查询变更的型号信息
- OracleParameter[] paras = new OracleParameter[]
- {
- new OracleParameter("IN_BARCODE", OracleDbType.Varchar2, barcode, ParameterDirection.Input),
- new OracleParameter("IN_GOODSID", OracleDbType.Int32, 0, ParameterDirection.Input),
- new OracleParameter("IN_LOGOID", OracleDbType.Int32, logoid, ParameterDirection.Input),
- new OracleParameter("OUT_RESULT", OracleDbType.RefCursor, null, ParameterDirection.Output),
- };
- sapDataSet = oracleTrConn.ExecStoredProcedure("PRO_SAP_HEGII_WORKDATA_BG_BIANGENG", paras);
- #endregion
- #region sap报工
- if (sapDataSet != null && sapDataSet.Tables.Count > 0 && sapDataSet.Tables[0].Rows.Count > 0 && !string.IsNullOrEmpty(oldMatnr))
- {
- DataTable sapresultTable = sapDataSet.Tables[0];
- //记录所有logid,先设置状态为Q,加完明细改为F
- List<int> logids = new List<int>();
- DataTable dTable = new DataTable();
- //获取总单datacode
- DataView dv = new DataView(sapresultTable);
- dTable = dv.ToTable(true, "DATACODE");
- #region 注释原方式,启用新表,合并推送
- //for (int j = 0; j < dTable.Rows.Count; j++)
- //{
- // //sap日志总单(不同节点)
- // string sqlText = "SELECT SEQ_TSAP_DATALOG_BG.nextval FROM dual";
- // //判断有几个节点 20,30,40,50
- // #region 20节点
- // if (dTable.Rows[j]["DATACODE"].ToString() == "20")
- // {
- // int logid = int.Parse(oracleTrConn.GetSqlResultToStr(sqlText));
- // //记录logid
- // logids.Add(logid);
- // #region log总单
- // sqlText = "INSERT INTO TSAP_HEGII_DATALOG_BG\n" +
- // " (LOGID,\n" +
- // " LOGTYPE,\n" +
- // " BEGINTIME,\n" +
- // " YYYYMMDD,\n" +
- // " WORKCODE,\n" +
- // " DATACODE,\n" +
- // " DATASTUTS,\n" +
- // " DATAMSG,\n" +
- // " DATALOGID,\n" +
- // " EXECUTEDATEBEGIN,\n" +
- // " EXECUTEDATEEND,\n" +
- // " REMARKS,\n" +
- // " SAPGUID)\n" +
- // " VALUES\n" +
- // " (:LOGID,\n" +
- // " '4',\n" +
- // " SYSDATE,\n" +
- // " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- // " '5000',\n" +
- // " '20',\n" +
- // " 'Q',\n" +
- // " '',\n" +
- // " :LOGID,\n" +
- // " SYSDATE,\n" +
- // " SYSDATE,\n" +
- // " :REMARKS,\n" +
- // " SYS_GUID())";
- // paras = new OracleParameter[]
- // {
- // new OracleParameter(":LOGID",logid),
- // new OracleParameter(":REMARKS","注浆变更:新商标ID:"+logoid),
- // };
- // returnRows = oracleTrConn.ExecuteNonQuery(sqlText, paras);
- // #endregion
- // #region 明细
- // DataTable table20 = sapresultTable.Copy();
- // DataRow[] drRow20 = table20.Select("DATACODE = 20");
- // foreach (DataRow row in drRow20)
- // {
- // sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG\n" +
- // " (YYYYMMDD,\n" +
- // " WORKCODE,\n" +
- // " DATACODE,\n" +
- // " GOODSCODE,\n" +
- // " SAPCODE,\n" +
- // " USERCODE,\n" +
- // " OUTPUTNUM,\n" +
- // " SCRAPNUM,\n" +
- // " CLEANUPNUM,\n" +
- // " REPAIRNUM,\n" +
- // " WORKSHOP,\n" +
- // " LOGID,\n" +
- // " TESTMOULDFLAG,\n" +
- // " ZSCS,\n" +
- // " CHARG)\n" +
- // " VALUES\n" +
- // " (TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- // " '5000',\n" +
- // " '20',\n" +
- // " :GOODSCODE,\n" +
- // " :SAPCODE,\n" +
- // " :USERCODE,\n" +
- // " :OUTPUTNUM,\n" +
- // " :SCRAPNUM,\n" +
- // " :CLEANUPNUM,\n" +
- // " :REPAIRNUM,\n" +
- // " :WORKSHOP,\n" +
- // " :LOGID,\n" +
- // " :TESTMOULDFLAG,\n" +
- // " :ZSCS,\n" +
- // " :CHARG)";
- // paras = new OracleParameter[]
- // {
- // new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- // new OracleParameter(":SAPCODE",row["SAPCODE"].ToString()),
- // new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- // new OracleParameter(":OUTPUTNUM",row["OUTPUTNUM"].ToString()),
- // new OracleParameter(":SCRAPNUM",row["SCRAPNUM"].ToString()),
- // new OracleParameter(":CLEANUPNUM",row["CLEANUPNUM"].ToString()),
- // new OracleParameter(":REPAIRNUM",row["REPAIRNUM"].ToString()),
- // new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- // new OracleParameter(":LOGID",logid),
- // new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- // new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- // new OracleParameter(":CHARG",row["CHARG"].ToString()),
- // };
- // returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- // sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG\n" +
- // " (YYYYMMDD,\n" +
- // " WORKCODE,\n" +
- // " DATACODE,\n" +
- // " GOODSCODE,\n" +
- // " SAPCODE,\n" +
- // " USERCODE,\n" +
- // " OUTPUTNUM,\n" +
- // " SCRAPNUM,\n" +
- // " CLEANUPNUM,\n" +
- // " REPAIRNUM,\n" +
- // " WORKSHOP,\n" +
- // " LOGID,\n" +
- // " TESTMOULDFLAG,\n" +
- // " ZSCS,\n" +
- // " CHARG)\n" +
- // " VALUES\n" +
- // " (TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- // " '5000',\n" +
- // " '20',\n" +
- // " :GOODSCODE,\n" +
- // " :SAPCODE,\n" +
- // " :USERCODE,\n" +
- // " :OUTPUTNUM,\n" +
- // " :SCRAPNUM,\n" +
- // " :CLEANUPNUM,\n" +
- // " :REPAIRNUM,\n" +
- // " :WORKSHOP,\n" +
- // " :LOGID,\n" +
- // " :TESTMOULDFLAG,\n" +
- // " :ZSCS,\n" +
- // " :CHARG)";
- // paras = new OracleParameter[]
- // {
- // new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- // new OracleParameter(":SAPCODE",oldMatnr),
- // new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- // new OracleParameter(":OUTPUTNUM",Convert.ToInt32(row["OUTPUTNUM"])*(-1)),
- // new OracleParameter(":SCRAPNUM",Convert.ToInt32(row["SCRAPNUM"])*(-1)),
- // new OracleParameter(":CLEANUPNUM",Convert.ToInt32(row["CLEANUPNUM"])*(-1)),
- // new OracleParameter(":REPAIRNUM",Convert.ToInt32(row["REPAIRNUM"])*(-1)),
- // new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- // new OracleParameter(":LOGID",logid),
- // new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- // new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- // new OracleParameter(":CHARG",row["CHARG"].ToString()),
- // };
- // returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- // }
- // #endregion
- // }
- // #endregion
- // #region 30节点
- // else if (dTable.Rows[j]["DATACODE"].ToString() == "30")
- // {
- // int logid = int.Parse(oracleTrConn.GetSqlResultToStr(sqlText));
- // //记录logid
- // logids.Add(logid);
- // sqlText = "INSERT INTO TSAP_HEGII_DATALOG_BG\n" +
- // " (LOGID,\n" +
- // " LOGTYPE,\n" +
- // " BEGINTIME,\n" +
- // " YYYYMMDD,\n" +
- // " WORKCODE,\n" +
- // " DATACODE,\n" +
- // " DATASTUTS,\n" +
- // " DATAMSG,\n" +
- // " DATALOGID,\n" +
- // " EXECUTEDATEBEGIN,\n" +
- // " EXECUTEDATEEND,\n" +
- // " REMARKS,\n" +
- // " SAPGUID)\n" +
- // " VALUES\n" +
- // " (:LOGID,\n" +
- // " '4',\n" +
- // " SYSDATE,\n" +
- // " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- // " 5000,\n" +
- // " :DATACODE,\n" +
- // " 'Q',\n" +
- // " '',\n" +
- // " :LOGID,\n" +
- // " SYSDATE,\n" +
- // " SYSDATE,\n" +
- // " :REMARKS,\n" +
- // " SYS_GUID())";
- // paras = new OracleParameter[]
- // {
- // new OracleParameter(":LOGID",logid),
- // new OracleParameter(":DATACODE","30"),
- // new OracleParameter(":REMARKS","注浆变更:新商标ID:"+logoid),
- // };
- // returnRows = oracleTrConn.ExecuteNonQuery(sqlText, paras);
- // #region 明细
- // DataTable table30 = sapresultTable.Copy();
- // DataRow[] drRow30 = table30.Select("DATACODE = 30");
- // foreach (DataRow row in drRow30)
- // {
- // sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG\n" +
- // " (YYYYMMDD,\n" +
- // " WORKCODE,\n" +
- // " DATACODE,\n" +
- // " GOODSCODE,\n" +
- // " SAPCODE,\n" +
- // " USERCODE,\n" +
- // " OUTPUTNUM,\n" +
- // " SCRAPNUM,\n" +
- // " CLEANUPNUM,\n" +
- // " REPAIRNUM,\n" +
- // " WORKSHOP,\n" +
- // " LOGID,\n" +
- // " TESTMOULDFLAG,\n" +
- // " ZSCS,\n" +
- // " CHARG)\n" +
- // " VALUES\n" +
- // " (TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- // " '5000',\n" +
- // " '30',\n" +
- // " :GOODSCODE,\n" +
- // " :SAPCODE,\n" +
- // " :USERCODE,\n" +
- // " :OUTPUTNUM,\n" +
- // " :SCRAPNUM,\n" +
- // " :CLEANUPNUM,\n" +
- // " :REPAIRNUM,\n" +
- // " :WORKSHOP,\n" +
- // " :LOGID,\n" +
- // " :TESTMOULDFLAG,\n" +
- // " :ZSCS,\n" +
- // " :CHARG)";
- // paras = new OracleParameter[]
- // {
- // new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- // new OracleParameter(":SAPCODE",row["SAPCODE"].ToString()),
- // new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- // new OracleParameter(":OUTPUTNUM",row["OUTPUTNUM"].ToString()),
- // new OracleParameter(":SCRAPNUM",row["SCRAPNUM"].ToString()),
- // new OracleParameter(":CLEANUPNUM",row["CLEANUPNUM"].ToString()),
- // new OracleParameter(":REPAIRNUM",row["REPAIRNUM"].ToString()),
- // new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- // new OracleParameter(":LOGID",logid),
- // new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- // new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- // new OracleParameter(":CHARG",row["CHARG"].ToString()),
- // };
- // returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- // sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG\n" +
- // " (YYYYMMDD,\n" +
- // " WORKCODE,\n" +
- // " DATACODE,\n" +
- // " GOODSCODE,\n" +
- // " SAPCODE,\n" +
- // " USERCODE,\n" +
- // " OUTPUTNUM,\n" +
- // " SCRAPNUM,\n" +
- // " CLEANUPNUM,\n" +
- // " REPAIRNUM,\n" +
- // " WORKSHOP,\n" +
- // " LOGID,\n" +
- // " TESTMOULDFLAG,\n" +
- // " ZSCS,\n" +
- // " CHARG)\n" +
- // " VALUES\n" +
- // " (TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- // " '5000',\n" +
- // " '30',\n" +
- // " :GOODSCODE,\n" +
- // " :SAPCODE,\n" +
- // " :USERCODE,\n" +
- // " :OUTPUTNUM,\n" +
- // " :SCRAPNUM,\n" +
- // " :CLEANUPNUM,\n" +
- // " :REPAIRNUM,\n" +
- // " :WORKSHOP,\n" +
- // " :LOGID,\n" +
- // " :TESTMOULDFLAG,\n" +
- // " :ZSCS,\n" +
- // " :CHARG)";
- // paras = new OracleParameter[]
- // {
- // new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- // new OracleParameter(":SAPCODE",oldMatnr),
- // new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- // new OracleParameter(":OUTPUTNUM",Convert.ToInt32(row["OUTPUTNUM"])*(-1)),
- // new OracleParameter(":SCRAPNUM",Convert.ToInt32(row["SCRAPNUM"])*(-1)),
- // new OracleParameter(":CLEANUPNUM",Convert.ToInt32(row["CLEANUPNUM"])*(-1)),
- // new OracleParameter(":REPAIRNUM",Convert.ToInt32(row["REPAIRNUM"])*(-1)),
- // new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- // new OracleParameter(":LOGID",logid),
- // new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- // new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- // new OracleParameter(":CHARG",row["CHARG"].ToString()),
- // };
- // returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- // }
- // #endregion
- // }
- // #endregion
- // #region 40节点
- // else if (dTable.Rows[j]["DATACODE"].ToString() == "40")
- // {
- // int logid = int.Parse(oracleTrConn.GetSqlResultToStr(sqlText));
- // //记录logid
- // logids.Add(logid);
- // sqlText = "INSERT INTO TSAP_HEGII_DATALOG_BG\n" +
- // " (LOGID,\n" +
- // " LOGTYPE,\n" +
- // " BEGINTIME,\n" +
- // " YYYYMMDD,\n" +
- // " WORKCODE,\n" +
- // " DATACODE,\n" +
- // " DATASTUTS,\n" +
- // " DATAMSG,\n" +
- // " DATALOGID,\n" +
- // " EXECUTEDATEBEGIN,\n" +
- // " EXECUTEDATEEND,\n" +
- // " REMARKS,\n" +
- // " SAPGUID)\n" +
- // " VALUES\n" +
- // " (:LOGID,\n" +
- // " '4',\n" +
- // " SYSDATE,\n" +
- // " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- // " 5000,\n" +
- // " :DATACODE,\n" +
- // " 'Q',\n" +
- // " '',\n" +
- // " :LOGID,\n" +
- // " SYSDATE,\n" +
- // " SYSDATE,\n" +
- // " :REMARKS,\n" +
- // " SYS_GUID())";
- // paras = new OracleParameter[]
- // {
- // new OracleParameter(":LOGID",logid),
- // new OracleParameter(":DATACODE","40"),
- // new OracleParameter(":REMARKS","注浆变更:新商标ID:"+logoid),
- // };
- // returnRows = oracleTrConn.ExecuteNonQuery(sqlText, paras);
- // #region 明细
- // DataTable table40 = sapresultTable.Copy();
- // DataRow[] drRow40 = table40.Select("DATACODE = 40");
- // foreach (DataRow row in drRow40)
- // {
- // sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG\n" +
- // " (YYYYMMDD,\n" +
- // " WORKCODE,\n" +
- // " DATACODE,\n" +
- // " GOODSCODE,\n" +
- // " SAPCODE,\n" +
- // " USERCODE,\n" +
- // " OUTPUTNUM,\n" +
- // " SCRAPNUM,\n" +
- // " CLEANUPNUM,\n" +
- // " REPAIRNUM,\n" +
- // " WORKSHOP,\n" +
- // " LOGID,\n" +
- // " TESTMOULDFLAG,\n" +
- // " ZSCS,\n" +
- // " CHARG)\n" +
- // " VALUES\n" +
- // " (TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- // " '5000',\n" +
- // " '40',\n" +
- // " :GOODSCODE,\n" +
- // " :SAPCODE,\n" +
- // " :USERCODE,\n" +
- // " :OUTPUTNUM,\n" +
- // " :SCRAPNUM,\n" +
- // " :CLEANUPNUM,\n" +
- // " :REPAIRNUM,\n" +
- // " :WORKSHOP,\n" +
- // " :LOGID,\n" +
- // " :TESTMOULDFLAG,\n" +
- // " :ZSCS,\n" +
- // " :CHARG)";
- // paras = new OracleParameter[]
- // {
- // new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- // new OracleParameter(":SAPCODE",row["SAPCODE"].ToString()),
- // new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- // new OracleParameter(":OUTPUTNUM",row["OUTPUTNUM"].ToString()),
- // new OracleParameter(":SCRAPNUM",row["SCRAPNUM"].ToString()),
- // new OracleParameter(":CLEANUPNUM",row["CLEANUPNUM"].ToString()),
- // new OracleParameter(":REPAIRNUM",row["REPAIRNUM"].ToString()),
- // new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- // new OracleParameter(":LOGID",logid),
- // new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- // new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- // new OracleParameter(":CHARG",row["CHARG"].ToString()),
- // };
- // returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- // sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG\n" +
- // " (YYYYMMDD,\n" +
- // " WORKCODE,\n" +
- // " DATACODE,\n" +
- // " GOODSCODE,\n" +
- // " SAPCODE,\n" +
- // " USERCODE,\n" +
- // " OUTPUTNUM,\n" +
- // " SCRAPNUM,\n" +
- // " CLEANUPNUM,\n" +
- // " REPAIRNUM,\n" +
- // " WORKSHOP,\n" +
- // " LOGID,\n" +
- // " TESTMOULDFLAG,\n" +
- // " ZSCS,\n" +
- // " CHARG)\n" +
- // " VALUES\n" +
- // " (TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- // " '5000',\n" +
- // " '40',\n" +
- // " :GOODSCODE,\n" +
- // " :SAPCODE,\n" +
- // " :USERCODE,\n" +
- // " :OUTPUTNUM,\n" +
- // " :SCRAPNUM,\n" +
- // " :CLEANUPNUM,\n" +
- // " :REPAIRNUM,\n" +
- // " :WORKSHOP,\n" +
- // " :LOGID,\n" +
- // " :TESTMOULDFLAG,\n" +
- // " :ZSCS,\n" +
- // " :CHARG)";
- // paras = new OracleParameter[]
- // {
- // new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- // new OracleParameter(":SAPCODE",oldMatnr),
- // new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- // new OracleParameter(":OUTPUTNUM",Convert.ToInt32(row["OUTPUTNUM"])*(-1)),
- // new OracleParameter(":SCRAPNUM",Convert.ToInt32(row["SCRAPNUM"])*(-1)),
- // new OracleParameter(":CLEANUPNUM",Convert.ToInt32(row["CLEANUPNUM"])*(-1)),
- // new OracleParameter(":REPAIRNUM",Convert.ToInt32(row["REPAIRNUM"])*(-1)),
- // new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- // new OracleParameter(":LOGID",logid),
- // new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- // new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- // new OracleParameter(":CHARG",row["CHARG"].ToString()),
- // };
- // returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- // }
- // #endregion
- // }
- // #endregion
- // #region 50节点
- // else if (dTable.Rows[j]["DATACODE"].ToString() == "50")
- // {
- // int logid = int.Parse(oracleTrConn.GetSqlResultToStr(sqlText));
- // //记录logid
- // logids.Add(logid);
- // sqlText = "INSERT INTO TSAP_HEGII_DATALOG_BG\n" +
- // " (LOGID,\n" +
- // " LOGTYPE,\n" +
- // " BEGINTIME,\n" +
- // " YYYYMMDD,\n" +
- // " WORKCODE,\n" +
- // " DATACODE,\n" +
- // " DATASTUTS,\n" +
- // " DATAMSG,\n" +
- // " DATALOGID,\n" +
- // " EXECUTEDATEBEGIN,\n" +
- // " EXECUTEDATEEND,\n" +
- // " REMARKS,\n" +
- // " SAPGUID)\n" +
- // " VALUES\n" +
- // " (:LOGID,\n" +
- // " '4',\n" +
- // " SYSDATE,\n" +
- // " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- // " 5000,\n" +
- // " :DATACODE,\n" +
- // " 'Q',\n" +
- // " '',\n" +
- // " :LOGID,\n" +
- // " SYSDATE,\n" +
- // " SYSDATE,\n" +
- // " :REMARKS,\n" +
- // " SYS_GUID())";
- // paras = new OracleParameter[]
- // {
- // new OracleParameter(":LOGID",logid),
- // new OracleParameter(":DATACODE","50"),
- // new OracleParameter(":REMARKS","注浆变更:新商标ID:"+logoid),
- // };
- // returnRows = oracleTrConn.ExecuteNonQuery(sqlText, paras);
- // #region 明细
- // DataTable table50 = sapresultTable.Copy();
- // DataRow[] drRow50 = table50.Select("DATACODE = 50");
- // foreach (DataRow row in drRow50)
- // {
- // sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG\n" +
- // " (YYYYMMDD,\n" +
- // " WORKCODE,\n" +
- // " DATACODE,\n" +
- // " GOODSCODE,\n" +
- // " SAPCODE,\n" +
- // " USERCODE,\n" +
- // " OUTPUTNUM,\n" +
- // " SCRAPNUM,\n" +
- // " CLEANUPNUM,\n" +
- // " REPAIRNUM,\n" +
- // " WORKSHOP,\n" +
- // " LOGID,\n" +
- // " TESTMOULDFLAG,\n" +
- // " ZSCS,\n" +
- // " CHARG)\n" +
- // " VALUES\n" +
- // " (TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- // " '5000',\n" +
- // " '50',\n" +
- // " :GOODSCODE,\n" +
- // " :SAPCODE,\n" +
- // " :USERCODE,\n" +
- // " :OUTPUTNUM,\n" +
- // " :SCRAPNUM,\n" +
- // " :CLEANUPNUM,\n" +
- // " :REPAIRNUM,\n" +
- // " :WORKSHOP,\n" +
- // " :LOGID,\n" +
- // " :TESTMOULDFLAG,\n" +
- // " :ZSCS,\n" +
- // " :CHARG)";
- // paras = new OracleParameter[]
- // {
- // new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- // new OracleParameter(":SAPCODE",row["SAPCODE"].ToString()),
- // new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- // new OracleParameter(":OUTPUTNUM",row["OUTPUTNUM"].ToString()),
- // new OracleParameter(":SCRAPNUM",row["SCRAPNUM"].ToString()),
- // new OracleParameter(":CLEANUPNUM",row["CLEANUPNUM"].ToString()),
- // new OracleParameter(":REPAIRNUM",row["REPAIRNUM"].ToString()),
- // new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- // new OracleParameter(":LOGID",logid),
- // new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- // new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- // new OracleParameter(":CHARG",row["CHARG"].ToString()),
- // };
- // returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- // sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG\n" +
- // " (YYYYMMDD,\n" +
- // " WORKCODE,\n" +
- // " DATACODE,\n" +
- // " GOODSCODE,\n" +
- // " SAPCODE,\n" +
- // " USERCODE,\n" +
- // " OUTPUTNUM,\n" +
- // " SCRAPNUM,\n" +
- // " CLEANUPNUM,\n" +
- // " REPAIRNUM,\n" +
- // " WORKSHOP,\n" +
- // " LOGID,\n" +
- // " TESTMOULDFLAG,\n" +
- // " ZSCS,\n" +
- // " CHARG)\n" +
- // " VALUES\n" +
- // " (TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- // " '5000',\n" +
- // " '50',\n" +
- // " :GOODSCODE,\n" +
- // " :SAPCODE,\n" +
- // " :USERCODE,\n" +
- // " :OUTPUTNUM,\n" +
- // " :SCRAPNUM,\n" +
- // " :CLEANUPNUM,\n" +
- // " :REPAIRNUM,\n" +
- // " :WORKSHOP,\n" +
- // " :LOGID,\n" +
- // " :TESTMOULDFLAG,\n" +
- // " :ZSCS,\n" +
- // " :CHARG)";
- // paras = new OracleParameter[]
- // {
- // new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- // new OracleParameter(":SAPCODE",oldMatnr),
- // new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- // new OracleParameter(":OUTPUTNUM",Convert.ToInt32(row["OUTPUTNUM"])*(-1)),
- // new OracleParameter(":SCRAPNUM",Convert.ToInt32(row["SCRAPNUM"])*(-1)),
- // new OracleParameter(":CLEANUPNUM",Convert.ToInt32(row["CLEANUPNUM"])*(-1)),
- // new OracleParameter(":REPAIRNUM",Convert.ToInt32(row["REPAIRNUM"])*(-1)),
- // new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- // new OracleParameter(":LOGID",logid),
- // new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- // new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- // new OracleParameter(":CHARG",row["CHARG"].ToString()),
- // };
- // returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- // }
- // #endregion
- // }
- // #endregion
- //}
- #endregion
- for (int j = 0; j < dTable.Rows.Count; j++)
- {
- string sqlText = "";
- //判断有几个节点 20,30,40,50
- #region 20节点
- if (dTable.Rows[j]["DATACODE"].ToString() == "20")
- {
- #region 明细
- DataTable table20 = sapresultTable.Copy();
- DataRow[] drRow20 = table20.Select("DATACODE = 20");
- foreach (DataRow row in drRow20)
- {
- sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG_SBBG\n" +
- " ( BARCODE,\n" +
- " YYYYMMDD,\n" +
- " WORKCODE,\n" +
- " DATACODE,\n" +
- " GOODSCODE,\n" +
- " SAPCODE,\n" +
- " USERCODE,\n" +
- " OUTPUTNUM,\n" +
- " SCRAPNUM,\n" +
- " CLEANUPNUM,\n" +
- " REPAIRNUM,\n" +
- " WORKSHOP,\n" +
- " TESTMOULDFLAG,\n" +
- " ZSCS,\n" +
- " CHARG)\n" +
- " VALUES\n" +
- " (:BARCODE,\n" +
- " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- " '5000',\n" +
- " '20',\n" +
- " :GOODSCODE,\n" +
- " :SAPCODE,\n" +
- " :USERCODE,\n" +
- " :OUTPUTNUM,\n" +
- " :SCRAPNUM,\n" +
- " :CLEANUPNUM,\n" +
- " :REPAIRNUM,\n" +
- " :WORKSHOP,\n" +
- " :TESTMOULDFLAG,\n" +
- " :ZSCS,\n" +
- " :CHARG)";
- paras = new OracleParameter[]
- {
- new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- new OracleParameter(":SAPCODE",row["SAPCODE"].ToString()),
- new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- new OracleParameter(":OUTPUTNUM",row["OUTPUTNUM"].ToString()),
- new OracleParameter(":SCRAPNUM",row["SCRAPNUM"].ToString()),
- new OracleParameter(":CLEANUPNUM",row["CLEANUPNUM"].ToString()),
- new OracleParameter(":REPAIRNUM",row["REPAIRNUM"].ToString()),
- new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- new OracleParameter(":BARCODE",barcode),
- new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- new OracleParameter(":CHARG",row["CHARG"].ToString()),
- };
- returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG_SBBG\n" +
- " (BARCODE,\n" +
- " YYYYMMDD,\n" +
- " WORKCODE,\n" +
- " DATACODE,\n" +
- " GOODSCODE,\n" +
- " SAPCODE,\n" +
- " USERCODE,\n" +
- " OUTPUTNUM,\n" +
- " SCRAPNUM,\n" +
- " CLEANUPNUM,\n" +
- " REPAIRNUM,\n" +
- " WORKSHOP,\n" +
- " TESTMOULDFLAG,\n" +
- " ZSCS,\n" +
- " CHARG)\n" +
- " VALUES\n" +
- " (:BARCODE,\n" +
- " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- " '5000',\n" +
- " '20',\n" +
- " :GOODSCODE,\n" +
- " :SAPCODE,\n" +
- " :USERCODE,\n" +
- " :OUTPUTNUM,\n" +
- " :SCRAPNUM,\n" +
- " :CLEANUPNUM,\n" +
- " :REPAIRNUM,\n" +
- " :WORKSHOP,\n" +
- " :TESTMOULDFLAG,\n" +
- " :ZSCS,\n" +
- " :CHARG)";
- paras = new OracleParameter[]
- {
- new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- new OracleParameter(":SAPCODE",oldMatnr),
- new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- new OracleParameter(":OUTPUTNUM",Convert.ToInt32(row["OUTPUTNUM"])*(-1)),
- new OracleParameter(":SCRAPNUM",Convert.ToInt32(row["SCRAPNUM"])*(-1)),
- new OracleParameter(":CLEANUPNUM",Convert.ToInt32(row["CLEANUPNUM"])*(-1)),
- new OracleParameter(":REPAIRNUM",Convert.ToInt32(row["REPAIRNUM"])*(-1)),
- new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- new OracleParameter(":BARCODE",barcode),
- new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- new OracleParameter(":CHARG",row["CHARG"].ToString()),
- };
- returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- }
- #endregion
- }
- #endregion
- #region 30节点
- else if (dTable.Rows[j]["DATACODE"].ToString() == "30")
- {
- #region 明细
- DataTable table30 = sapresultTable.Copy();
- DataRow[] drRow30 = table30.Select("DATACODE = 30");
- foreach (DataRow row in drRow30)
- {
- sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG_SBBG\n" +
- " (BARCODE,\n" +
- " YYYYMMDD,\n" +
- " WORKCODE,\n" +
- " DATACODE,\n" +
- " GOODSCODE,\n" +
- " SAPCODE,\n" +
- " USERCODE,\n" +
- " OUTPUTNUM,\n" +
- " SCRAPNUM,\n" +
- " CLEANUPNUM,\n" +
- " REPAIRNUM,\n" +
- " WORKSHOP,\n" +
- " TESTMOULDFLAG,\n" +
- " ZSCS,\n" +
- " CHARG)\n" +
- " VALUES\n" +
- " (:BARCODE,\n" +
- " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- " '5000',\n" +
- " '30',\n" +
- " :GOODSCODE,\n" +
- " :SAPCODE,\n" +
- " :USERCODE,\n" +
- " :OUTPUTNUM,\n" +
- " :SCRAPNUM,\n" +
- " :CLEANUPNUM,\n" +
- " :REPAIRNUM,\n" +
- " :WORKSHOP,\n" +
- " :TESTMOULDFLAG,\n" +
- " :ZSCS,\n" +
- " :CHARG)";
- paras = new OracleParameter[]
- {
- new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- new OracleParameter(":SAPCODE",row["SAPCODE"].ToString()),
- new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- new OracleParameter(":OUTPUTNUM",row["OUTPUTNUM"].ToString()),
- new OracleParameter(":SCRAPNUM",row["SCRAPNUM"].ToString()),
- new OracleParameter(":CLEANUPNUM",row["CLEANUPNUM"].ToString()),
- new OracleParameter(":REPAIRNUM",row["REPAIRNUM"].ToString()),
- new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- new OracleParameter(":BARCODE",barcode),
- new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- new OracleParameter(":CHARG",row["CHARG"].ToString()),
- };
- returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG_SBBG\n" +
- " (BARCODE,\n" +
- " YYYYMMDD,\n" +
- " WORKCODE,\n" +
- " DATACODE,\n" +
- " GOODSCODE,\n" +
- " SAPCODE,\n" +
- " USERCODE,\n" +
- " OUTPUTNUM,\n" +
- " SCRAPNUM,\n" +
- " CLEANUPNUM,\n" +
- " REPAIRNUM,\n" +
- " WORKSHOP,\n" +
- " TESTMOULDFLAG,\n" +
- " ZSCS,\n" +
- " CHARG)\n" +
- " VALUES\n" +
- " (:BARCODE,\n" +
- " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- " '5000',\n" +
- " '30',\n" +
- " :GOODSCODE,\n" +
- " :SAPCODE,\n" +
- " :USERCODE,\n" +
- " :OUTPUTNUM,\n" +
- " :SCRAPNUM,\n" +
- " :CLEANUPNUM,\n" +
- " :REPAIRNUM,\n" +
- " :WORKSHOP,\n" +
- " :TESTMOULDFLAG,\n" +
- " :ZSCS,\n" +
- " :CHARG)";
- paras = new OracleParameter[]
- {
- new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- new OracleParameter(":SAPCODE",oldMatnr),
- new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- new OracleParameter(":OUTPUTNUM",Convert.ToInt32(row["OUTPUTNUM"])*(-1)),
- new OracleParameter(":SCRAPNUM",Convert.ToInt32(row["SCRAPNUM"])*(-1)),
- new OracleParameter(":CLEANUPNUM",Convert.ToInt32(row["CLEANUPNUM"])*(-1)),
- new OracleParameter(":REPAIRNUM",Convert.ToInt32(row["REPAIRNUM"])*(-1)),
- new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- new OracleParameter(":BARCODE",barcode),
- new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- new OracleParameter(":CHARG",row["CHARG"].ToString()),
- };
- returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- }
- #endregion
- }
- #endregion
- #region 40节点
- else if (dTable.Rows[j]["DATACODE"].ToString() == "40")
- {
- #region 明细
- DataTable table40 = sapresultTable.Copy();
- DataRow[] drRow40 = table40.Select("DATACODE = 40");
- foreach (DataRow row in drRow40)
- {
- sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG_SBBG\n" +
- " (BARCODE,\n" +
- " YYYYMMDD,\n" +
- " WORKCODE,\n" +
- " DATACODE,\n" +
- " GOODSCODE,\n" +
- " SAPCODE,\n" +
- " USERCODE,\n" +
- " OUTPUTNUM,\n" +
- " SCRAPNUM,\n" +
- " CLEANUPNUM,\n" +
- " REPAIRNUM,\n" +
- " WORKSHOP,\n" +
- " TESTMOULDFLAG,\n" +
- " ZSCS,\n" +
- " CHARG)\n" +
- " VALUES\n" +
- " (:BARCODE,\n" +
- " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- " '5000',\n" +
- " '40',\n" +
- " :GOODSCODE,\n" +
- " :SAPCODE,\n" +
- " :USERCODE,\n" +
- " :OUTPUTNUM,\n" +
- " :SCRAPNUM,\n" +
- " :CLEANUPNUM,\n" +
- " :REPAIRNUM,\n" +
- " :WORKSHOP,\n" +
- " :TESTMOULDFLAG,\n" +
- " :ZSCS,\n" +
- " :CHARG)";
- paras = new OracleParameter[]
- {
- new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- new OracleParameter(":SAPCODE",row["SAPCODE"].ToString()),
- new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- new OracleParameter(":OUTPUTNUM",row["OUTPUTNUM"].ToString()),
- new OracleParameter(":SCRAPNUM",row["SCRAPNUM"].ToString()),
- new OracleParameter(":CLEANUPNUM",row["CLEANUPNUM"].ToString()),
- new OracleParameter(":REPAIRNUM",row["REPAIRNUM"].ToString()),
- new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- new OracleParameter(":BARCODE",barcode),
- new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- new OracleParameter(":CHARG",row["CHARG"].ToString()),
- };
- returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG_SBBG\n" +
- " (BARCODE,\n" +
- " YYYYMMDD,\n" +
- " WORKCODE,\n" +
- " DATACODE,\n" +
- " GOODSCODE,\n" +
- " SAPCODE,\n" +
- " USERCODE,\n" +
- " OUTPUTNUM,\n" +
- " SCRAPNUM,\n" +
- " CLEANUPNUM,\n" +
- " REPAIRNUM,\n" +
- " WORKSHOP,\n" +
- " TESTMOULDFLAG,\n" +
- " ZSCS,\n" +
- " CHARG)\n" +
- " VALUES\n" +
- " (:BARCODE,\n" +
- " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- " '5000',\n" +
- " '40',\n" +
- " :GOODSCODE,\n" +
- " :SAPCODE,\n" +
- " :USERCODE,\n" +
- " :OUTPUTNUM,\n" +
- " :SCRAPNUM,\n" +
- " :CLEANUPNUM,\n" +
- " :REPAIRNUM,\n" +
- " :WORKSHOP,\n" +
- " :TESTMOULDFLAG,\n" +
- " :ZSCS,\n" +
- " :CHARG)";
- paras = new OracleParameter[]
- {
- new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- new OracleParameter(":SAPCODE",oldMatnr),
- new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- new OracleParameter(":OUTPUTNUM",Convert.ToInt32(row["OUTPUTNUM"])*(-1)),
- new OracleParameter(":SCRAPNUM",Convert.ToInt32(row["SCRAPNUM"])*(-1)),
- new OracleParameter(":CLEANUPNUM",Convert.ToInt32(row["CLEANUPNUM"])*(-1)),
- new OracleParameter(":REPAIRNUM",Convert.ToInt32(row["REPAIRNUM"])*(-1)),
- new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- new OracleParameter(":BARCODE",barcode),
- new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- new OracleParameter(":CHARG",row["CHARG"].ToString()),
- };
- returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- }
- #endregion
- }
- #endregion
- #region 50节点
- else if (dTable.Rows[j]["DATACODE"].ToString() == "50")
- {
- #region 明细
- DataTable table50 = sapresultTable.Copy();
- DataRow[] drRow50 = table50.Select("DATACODE = 50");
- foreach (DataRow row in drRow50)
- {
- sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG_SBBG\n" +
- " (BARCODE,\n" +
- " YYYYMMDD,\n" +
- " WORKCODE,\n" +
- " DATACODE,\n" +
- " GOODSCODE,\n" +
- " SAPCODE,\n" +
- " USERCODE,\n" +
- " OUTPUTNUM,\n" +
- " SCRAPNUM,\n" +
- " CLEANUPNUM,\n" +
- " REPAIRNUM,\n" +
- " WORKSHOP,\n" +
- " TESTMOULDFLAG,\n" +
- " ZSCS,\n" +
- " CHARG)\n" +
- " VALUES\n" +
- " (:BARCODE,\n" +
- " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- " '5000',\n" +
- " '50',\n" +
- " :GOODSCODE,\n" +
- " :SAPCODE,\n" +
- " :USERCODE,\n" +
- " :OUTPUTNUM,\n" +
- " :SCRAPNUM,\n" +
- " :CLEANUPNUM,\n" +
- " :REPAIRNUM,\n" +
- " :WORKSHOP,\n" +
- " :TESTMOULDFLAG,\n" +
- " :ZSCS,\n" +
- " :CHARG)";
- paras = new OracleParameter[]
- {
- new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- new OracleParameter(":SAPCODE",row["SAPCODE"].ToString()),
- new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- new OracleParameter(":OUTPUTNUM",row["OUTPUTNUM"].ToString()),
- new OracleParameter(":SCRAPNUM",row["SCRAPNUM"].ToString()),
- new OracleParameter(":CLEANUPNUM",row["CLEANUPNUM"].ToString()),
- new OracleParameter(":REPAIRNUM",row["REPAIRNUM"].ToString()),
- new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- new OracleParameter(":BARCODE",barcode),
- new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- new OracleParameter(":CHARG",row["CHARG"].ToString()),
- };
- returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- sqlText = "INSERT INTO TSAP_HEGII_WORKDATA_BG_SBBG\n" +
- " (BARCODE,\n" +
- " YYYYMMDD,\n" +
- " WORKCODE,\n" +
- " DATACODE,\n" +
- " GOODSCODE,\n" +
- " SAPCODE,\n" +
- " USERCODE,\n" +
- " OUTPUTNUM,\n" +
- " SCRAPNUM,\n" +
- " CLEANUPNUM,\n" +
- " REPAIRNUM,\n" +
- " WORKSHOP,\n" +
- " TESTMOULDFLAG,\n" +
- " ZSCS,\n" +
- " CHARG)\n" +
- " VALUES\n" +
- " (:BARCODE,\n" +
- " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- " '5000',\n" +
- " '50',\n" +
- " :GOODSCODE,\n" +
- " :SAPCODE,\n" +
- " :USERCODE,\n" +
- " :OUTPUTNUM,\n" +
- " :SCRAPNUM,\n" +
- " :CLEANUPNUM,\n" +
- " :REPAIRNUM,\n" +
- " :WORKSHOP,\n" +
- " :TESTMOULDFLAG,\n" +
- " :ZSCS,\n" +
- " :CHARG)";
- paras = new OracleParameter[]
- {
- new OracleParameter(":GOODSCODE",row["GOODSCODE"].ToString()),
- new OracleParameter(":SAPCODE",oldMatnr),
- new OracleParameter(":USERCODE",row["USERCODE"].ToString()),
- new OracleParameter(":OUTPUTNUM",Convert.ToInt32(row["OUTPUTNUM"])*(-1)),
- new OracleParameter(":SCRAPNUM",Convert.ToInt32(row["SCRAPNUM"])*(-1)),
- new OracleParameter(":CLEANUPNUM",Convert.ToInt32(row["CLEANUPNUM"])*(-1)),
- new OracleParameter(":REPAIRNUM",Convert.ToInt32(row["REPAIRNUM"])*(-1)),
- new OracleParameter(":WORKSHOP",row["WORKSHOP"].ToString()),
- new OracleParameter(":BARCODE",barcode),
- new OracleParameter(":TESTMOULDFLAG",row["TESTMOULDFLAG"].ToString()),
- new OracleParameter(":ZSCS",row["ZSCS"].ToString()),
- new OracleParameter(":CHARG",row["CHARG"].ToString()),
- };
- returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- }
- #endregion
- }
- #endregion
- }
- #region 更新总单状态为F
- //string ids = string.Join(",", logids);
- //if (!string.IsNullOrWhiteSpace(ids))
- if (returnRows > 0)
- {
- //string sql1 = "update TSAP_HEGII_DATALOG_BG set DATASTUTS='F' where DATASTUTS = 'Q' AND LOGID IN (" + ids + ") ";
- // returnRows += oracleTrConn.ExecuteNonQuery(sql1);
- //更新商标变更明细表
- //string sql1 = " update tp_pm_logochangedrecord set SAPFLAG='1',SAPLOGID = '" + ids + "' where barcode =" + barcode + " and createtime = to_date('" + cretetime + "','yyyy-mm-dd hh24:mi:ss')";
- string sql1 = " update tp_pm_logochangedrecord set SAPFLAG='1' where barcode =" + barcode + " and createtime = to_date('" + cretetime + "','yyyy-mm-dd hh24:mi:ss')";
- returnRows += oracleTrConn.ExecuteNonQuery(sql1);
- }
- #endregion
- }
- #endregion
- }
- }
- }
- oracleTrConn.Commit();
- oracleTrConn.Disconnect();
- }
- catch (Exception ex)
- {
- if (oracleTrConn.ConnState == System.Data.ConnectionState.Open)
- {
- oracleTrConn.Rollback();
- oracleTrConn.Disconnect();
- }
- throw ex;
- }
- finally
- {
- if (oracleTrConn != null)
- {
- oracleTrConn.Close();
- }
- }
- }
- /// <summary>
- /// 商标变更插入同步数据
- /// </summary>
- /// <param name="date">当前时间</param>
- /// <param name="ndate">本次要执行到的时间</param>
- public static void AutoWorkDataToSAP5000SBBGInsert(DateTime ndate)
- {
- IDBTransaction oracleTrConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- ServiceResultEntity sre = new ServiceResultEntity();
- try
- {
- string timeString = @" SELECT case when MAX(DL.EXECUTEDATEEND) is null then date'2024-06-17' else MAX(DL.EXECUTEDATEEND) end as EXECUTEDATEEND
- FROM TSAP_HEGII_DATALOG_BG DL
- WHERE DL.LOGTYPE = '4'
- AND DL.REMARKS ='商标变更新' ";
- DateTime createtimebegin = Convert.ToDateTime(oracleTrConn.GetSqlResultToStr(timeString));
- // 处理部分遗留数据+新表中保存的数据
- string sqlString = "\n" +
- "SELECT WB.WORKCODE\n" +
- " ,WB.DATACODE\n" +
- " ,WB.GOODSCODE\n" +
- " ,WB.SAPCODE\n" +
- " ,WB.USERCODE\n" +
- " ,sum(WB.OUTPUTNUM) OUTPUTNUM\n" +
- " ,sum(WB.SCRAPNUM) SCRAPNUM\n" +
- " ,sum(WB.CLEANUPNUM) CLEANUPNUM\n" +
- " ,sum(WB.REPAIRNUM) REPAIRNUM\n" +
- " ,WB.WORKSHOP\n" +
- " ,WB.TESTMOULDFLAG\n" +
- " ,WB.ZSCS\n" +
- " ,'24065000E' CHARG\n" +
- "FROM TSAP_HEGII_WORKDATA_BG WB\n" +
- "LEFT JOIN TSAP_HEGII_DATALOG_BG DL ON DL.LOGID=WB.LOGID\n" +
- "WHERE DL.Datastuts IN( 'Q') AND DL.REMARKS NOT IN( '商标变更新')\n" +
- "GROUP BY WB.WORKCODE\n" +
- " ,WB.DATACODE\n" +
- " ,WB.GOODSCODE\n" +
- " ,WB.SAPCODE\n" +
- " ,WB.USERCODE\n" +
- " ,WB.WORKSHOP\n" +
- " ,WB.TESTMOULDFLAG\n" +
- " ,WB.ZSCS\n" +
- " ,'24065000E'\n" +
- "UNION ALL\n" +
- "SELECT WB.WORKCODE\n" +
- " ,WB.DATACODE\n" +
- " ,WB.GOODSCODE\n" +
- " ,WB.SAPCODE\n" +
- " ,WB.USERCODE\n" +
- " ,sum(WB.OUTPUTNUM) OUTPUTNUM\n" +
- " ,sum(WB.SCRAPNUM) SCRAPNUM\n" +
- " ,sum(WB.CLEANUPNUM) CLEANUPNUM\n" +
- " ,sum(WB.REPAIRNUM) REPAIRNUM\n" +
- " ,WB.WORKSHOP\n" +
- " ,WB.TESTMOULDFLAG\n" +
- " ,WB.ZSCS\n" +
- " ,'24065000E' CHARG\n" +
- "FROM TSAP_HEGII_WORKDATA_BG_SBBG WB\n" +
- "WHERE WB.Createtime >= :BEGINDATE and WB.Createtime < :ENDDATE\n" +
- "GROUP BY WB.WORKCODE\n" +
- " ,WB.DATACODE\n" +
- " ,WB.GOODSCODE\n" +
- " ,WB.SAPCODE\n" +
- " ,WB.USERCODE\n" +
- " ,WB.WORKSHOP\n" +
- " ,WB.TESTMOULDFLAG\n" +
- " ,WB.ZSCS\n" +
- " ,'24065000E'";
- //同步结束时间 开始时间怎么取?暂定 取上次同步的结束时间
- OracleParameter[] paras = new OracleParameter[]
- {
- new OracleParameter(":BEGINDATE", createtimebegin),
- new OracleParameter(":ENDDATE", ndate),
- };
- DataTable detailTable = oracleTrConn.GetSqlResultToDt(sqlString, paras);
- int returnRows = 0;
- //所有需要汇总数据
- if (detailTable != null && detailTable.Rows.Count > 0)
- {
- #region sap报工
- DataTable sapresultTable = detailTable;
- //记录所有logid,先设置状态为Q,加完明细改为F
- List<int> logids = new List<int>();
- DataTable dTable = new DataTable();
- //获取总单datacode
- DataView dv = new DataView(sapresultTable);
- dTable = dv.ToTable(true, "DATACODE");
- #region 合并推送
- for (int j = 0; j < dTable.Rows.Count; j++)
- {
- //sap日志总单(不同节点)
- string sqlText = "SELECT SEQ_TSAP_DATALOG_BG.nextval FROM dual";
- //判断有几个节点 20,30,40,50
- #region 20节点
- if (dTable.Rows[j]["DATACODE"].ToString() == "20")
- {
- int logid = int.Parse(oracleTrConn.GetSqlResultToStr(sqlText));
- //记录logid
- logids.Add(logid);
- timeString = @" SELECT case when MAX(DL.EXECUTEDATEEND) is null then date'2024-06-17' else MAX(DL.EXECUTEDATEEND) end as EXECUTEDATEEND
- FROM TSAP_HEGII_DATALOG_BG DL
- WHERE DL.LOGTYPE = '4'
- AND DL.REMARKS ='商标变更新'
- AND DL.DATACODE = '20' ";
- createtimebegin = Convert.ToDateTime(oracleTrConn.GetSqlResultToStr(timeString));
- #region log总单
- sqlText = "INSERT INTO TSAP_HEGII_DATALOG_BG\n" +
- " (LOGID,\n" +
- " LOGTYPE,\n" +
- " BEGINTIME,\n" +
- " YYYYMMDD,\n" +
- " WORKCODE,\n" +
- " DATACODE,\n" +
- " DATASTUTS,\n" +
- " DATAMSG,\n" +
- " DATALOGID,\n" +
- " EXECUTEDATEBEGIN,\n" +
- " EXECUTEDATEEND,\n" +
- " REMARKS,\n" +
- " SAPGUID)\n" +
- " VALUES\n" +
- " (:LOGID,\n" +
- " '4',\n" +
- " SYSDATE,\n" +
- " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- " '5000',\n" +
- " '20',\n" +
- " 'Q',\n" +
- " '',\n" +
- " :LOGID,\n" +
- " :BEGINDATE,\n" +
- " :ENDDATE,\n" +
- " :REMARKS,\n" +
- " SYS_GUID())";
- paras = new OracleParameter[]
- {
- new OracleParameter(":LOGID",logid),
- new OracleParameter(":REMARKS","商标变更新"),
- new OracleParameter(":BEGINDATE", createtimebegin),
- new OracleParameter(":ENDDATE", ndate),
- };
- returnRows = oracleTrConn.ExecuteNonQuery(sqlText, paras);
- #endregion
- #region 明细
- sqlText = "INSERT INTO tsap_hegii_workdata_bg\n" +
- " (yyyymmdd\n" +
- " ,workcode\n" +
- " ,datacode\n" +
- " ,goodscode\n" +
- " ,sapcode\n" +
- " ,usercode\n" +
- " ,outputnum\n" +
- " ,scrapnum\n" +
- " ,cleanupnum\n" +
- " ,repairnum\n" +
- " ,workshop\n" +
- " ,logid\n" +
- " ,testmouldflag\n" +
- " ,zscs\n" +
- " ,charg)\n" +
- " SELECT yyyymmdd\n" +
- " ,workcode\n" +
- " ,datacode\n" +
- " ,goodscode\n" +
- " ,sapcode\n" +
- " ,usercode\n" +
- " ,SUM(outputnum) outputnum\n" +
- " ,SUM(scrapnum) scrapnum\n" +
- " ,SUM(cleanupnum) cleanupnum\n" +
- " ,SUM(repairnum) repairnum\n" +
- " ,workshop\n" +
- " ,logid\n" +
- " ,testmouldflag\n" +
- " ,zscs\n" +
- " ,CHARG from (\n" +
- " SELECT to_char(SYSDATE, 'YYYYMMDD') yyyymmdd\n" +
- " ,wb.workcode\n" +
- " ,wb.datacode\n" +
- " ,wb.goodscode\n" +
- " ,wb.sapcode\n" +
- " ,wb.usercode\n" +
- " ,SUM(wb.outputnum) outputnum\n" +
- " ,SUM(wb.scrapnum) scrapnum\n" +
- " ,SUM(wb.cleanupnum) cleanupnum\n" +
- " ,SUM(wb.repairnum) repairnum\n" +
- " ,wb.workshop\n" +
- " ,:LOGID logid\n" +
- " ,wb.testmouldflag\n" +
- " ,wb.zscs\n" +
- " ,'24065000E' CHARG\n" +
- " FROM tsap_hegii_workdata_bg wb\n" +
- " LEFT JOIN tsap_hegii_datalog_bg dl\n" +
- " ON dl.logid = wb.logid\n" +
- " WHERE dl.datastuts IN ('Q') AND dl.REMARKS NOT IN( '商标变更新')\n" +
- " AND wb.datacode = '20'\n" +
- " GROUP BY to_char(SYSDATE, 'YYYYMMDD'),wb.workcode,wb.datacode,wb.goodscode,wb.sapcode,wb.usercode,wb.workshop,wb.testmouldflag,wb.zscs,'24065000E'\n" +
- " UNION ALL\n" +
- " SELECT to_char(SYSDATE, 'YYYYMMDD') yyyymmdd\n" +
- " ,wb.workcode\n" +
- " ,wb.datacode\n" +
- " ,wb.goodscode\n" +
- " ,wb.sapcode\n" +
- " ,wb.usercode\n" +
- " ,SUM(wb.outputnum) outputnum\n" +
- " ,SUM(wb.scrapnum) scrapnum\n" +
- " ,SUM(wb.cleanupnum) cleanupnum\n" +
- " ,SUM(wb.repairnum) repairnum\n" +
- " ,wb.workshop\n" +
- " ,:LOGID logid\n" +
- " ,wb.testmouldflag\n" +
- " ,wb.zscs\n" +
- " ,'24065000E' CHARG\n" +
- " FROM tsap_hegii_workdata_bg_sbbg wb\n" +
- " WHERE wb.createtime >= :BEGINDATE\n" +
- " AND wb.createtime < :ENDDATE\n" +
- " AND wb.datacode = '20'\n" +
- " GROUP BY to_char(SYSDATE, 'YYYYMMDD'),wb.workcode,wb.datacode,wb.goodscode,wb.sapcode,wb.usercode,wb.workshop,wb.testmouldflag,wb.zscs,'24065000E' )\n" +
- " GROUP BY yyyymmdd,workcode,datacode,goodscode,sapcode,usercode,workshop,logid,testmouldflag,zscs,CHARG ";
- paras = new OracleParameter[]
- {
- new OracleParameter(":LOGID",logid),
- new OracleParameter(":ENDDATE", ndate),
- new OracleParameter(":BEGINDATE", createtimebegin),
- };
- returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- #endregion
- }
- #endregion
- #region 30节点
- else if (dTable.Rows[j]["DATACODE"].ToString() == "30")
- {
- int logid = int.Parse(oracleTrConn.GetSqlResultToStr(sqlText));
- //记录logid
- logids.Add(logid);
- timeString = @" SELECT case when MAX(DL.EXECUTEDATEEND) is null then date'2024-06-17' else MAX(DL.EXECUTEDATEEND) end as EXECUTEDATEEND
- FROM TSAP_HEGII_DATALOG_BG DL
- WHERE DL.LOGTYPE = '4'
- AND DL.REMARKS ='商标变更新'
- AND DL.DATACODE = '30' ";
- createtimebegin = Convert.ToDateTime(oracleTrConn.GetSqlResultToStr(timeString));
- sqlText = "INSERT INTO TSAP_HEGII_DATALOG_BG\n" +
- " (LOGID,\n" +
- " LOGTYPE,\n" +
- " BEGINTIME,\n" +
- " YYYYMMDD,\n" +
- " WORKCODE,\n" +
- " DATACODE,\n" +
- " DATASTUTS,\n" +
- " DATAMSG,\n" +
- " DATALOGID,\n" +
- " EXECUTEDATEBEGIN,\n" +
- " EXECUTEDATEEND,\n" +
- " REMARKS,\n" +
- " SAPGUID)\n" +
- " VALUES\n" +
- " (:LOGID,\n" +
- " '4',\n" +
- " SYSDATE,\n" +
- " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- " 5000,\n" +
- " :DATACODE,\n" +
- " 'Q',\n" +
- " '',\n" +
- " :LOGID,\n" +
- " :BEGINDATE,\n" +
- " :ENDDATE,\n" +
- " :REMARKS,\n" +
- " SYS_GUID())";
- paras = new OracleParameter[]
- {
- new OracleParameter(":LOGID",logid),
- new OracleParameter(":DATACODE","30"),
- new OracleParameter(":REMARKS","商标变更新"),
- new OracleParameter(":BEGINDATE", createtimebegin),
- new OracleParameter(":ENDDATE", ndate),
- };
- returnRows = oracleTrConn.ExecuteNonQuery(sqlText, paras);
- #region 明细
- sqlText = "INSERT INTO tsap_hegii_workdata_bg\n" +
- " (yyyymmdd\n" +
- " ,workcode\n" +
- " ,datacode\n" +
- " ,goodscode\n" +
- " ,sapcode\n" +
- " ,usercode\n" +
- " ,outputnum\n" +
- " ,scrapnum\n" +
- " ,cleanupnum\n" +
- " ,repairnum\n" +
- " ,workshop\n" +
- " ,logid\n" +
- " ,testmouldflag\n" +
- " ,zscs\n" +
- " ,charg)\n" +
- " SELECT yyyymmdd\n" +
- " ,workcode\n" +
- " ,datacode\n" +
- " ,goodscode\n" +
- " ,sapcode\n" +
- " ,usercode\n" +
- " ,SUM(outputnum) outputnum\n" +
- " ,SUM(scrapnum) scrapnum\n" +
- " ,SUM(cleanupnum) cleanupnum\n" +
- " ,SUM(repairnum) repairnum\n" +
- " ,workshop\n" +
- " ,logid\n" +
- " ,testmouldflag\n" +
- " ,zscs\n" +
- " ,CHARG from (\n" +
- " SELECT to_char(SYSDATE, 'YYYYMMDD') yyyymmdd\n" +
- " ,wb.workcode\n" +
- " ,wb.datacode\n" +
- " ,wb.goodscode\n" +
- " ,wb.sapcode\n" +
- " ,wb.usercode\n" +
- " ,SUM(wb.outputnum) outputnum\n" +
- " ,SUM(wb.scrapnum) scrapnum\n" +
- " ,SUM(wb.cleanupnum) cleanupnum\n" +
- " ,SUM(wb.repairnum) repairnum\n" +
- " ,wb.workshop\n" +
- " ,:LOGID logid\n" +
- " ,wb.testmouldflag\n" +
- " ,wb.zscs\n" +
- " ,'24065000E' CHARG\n" +
- " FROM tsap_hegii_workdata_bg wb\n" +
- " LEFT JOIN tsap_hegii_datalog_bg dl\n" +
- " ON dl.logid = wb.logid\n" +
- " WHERE dl.datastuts IN ('Q') AND dl.REMARKS NOT IN( '商标变更新')\n" +
- " AND wb.datacode = '30'\n" +
- " GROUP BY to_char(SYSDATE, 'YYYYMMDD'),wb.workcode,wb.datacode,wb.goodscode,wb.sapcode,wb.usercode,wb.workshop,wb.testmouldflag,wb.zscs,'24065000E'\n" +
- " UNION ALL\n" +
- " SELECT to_char(SYSDATE, 'YYYYMMDD') yyyymmdd\n" +
- " ,wb.workcode\n" +
- " ,wb.datacode\n" +
- " ,wb.goodscode\n" +
- " ,wb.sapcode\n" +
- " ,wb.usercode\n" +
- " ,SUM(wb.outputnum) outputnum\n" +
- " ,SUM(wb.scrapnum) scrapnum\n" +
- " ,SUM(wb.cleanupnum) cleanupnum\n" +
- " ,SUM(wb.repairnum) repairnum\n" +
- " ,wb.workshop\n" +
- " ,:LOGID logid\n" +
- " ,wb.testmouldflag\n" +
- " ,wb.zscs\n" +
- " ,'24065000E' CHARG\n" +
- " FROM tsap_hegii_workdata_bg_sbbg wb\n" +
- " WHERE wb.createtime >= :BEGINDATE\n" +
- " AND wb.createtime < :ENDDATE\n" +
- " AND wb.datacode = '30'\n" +
- " GROUP BY to_char(SYSDATE, 'YYYYMMDD'),wb.workcode,wb.datacode,wb.goodscode,wb.sapcode,wb.usercode,wb.workshop,wb.testmouldflag,wb.zscs,'24065000E' )\n" +
- " GROUP BY yyyymmdd,workcode,datacode,goodscode,sapcode,usercode,workshop,logid,testmouldflag,zscs,CHARG ";
- paras = new OracleParameter[]
- {
- new OracleParameter(":LOGID",logid),
- new OracleParameter(":ENDDATE", ndate),
- new OracleParameter(":BEGINDATE", createtimebegin),
- };
- returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- #endregion
- }
- #endregion
- #region 40节点
- else if (dTable.Rows[j]["DATACODE"].ToString() == "40")
- {
- int logid = int.Parse(oracleTrConn.GetSqlResultToStr(sqlText));
- //记录logid
- logids.Add(logid);
- timeString = @" SELECT case when MAX(DL.EXECUTEDATEEND) is null then date'2024-06-17' else MAX(DL.EXECUTEDATEEND) end as EXECUTEDATEEND
- FROM TSAP_HEGII_DATALOG_BG DL
- WHERE DL.LOGTYPE = '4'
- AND DL.REMARKS ='商标变更新'
- AND DL.DATACODE = '40' ";
- createtimebegin = Convert.ToDateTime(oracleTrConn.GetSqlResultToStr(timeString));
- sqlText = "INSERT INTO TSAP_HEGII_DATALOG_BG\n" +
- " (LOGID,\n" +
- " LOGTYPE,\n" +
- " BEGINTIME,\n" +
- " YYYYMMDD,\n" +
- " WORKCODE,\n" +
- " DATACODE,\n" +
- " DATASTUTS,\n" +
- " DATAMSG,\n" +
- " DATALOGID,\n" +
- " EXECUTEDATEBEGIN,\n" +
- " EXECUTEDATEEND,\n" +
- " REMARKS,\n" +
- " SAPGUID)\n" +
- " VALUES\n" +
- " (:LOGID,\n" +
- " '4',\n" +
- " SYSDATE,\n" +
- " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- " 5000,\n" +
- " :DATACODE,\n" +
- " 'Q',\n" +
- " '',\n" +
- " :LOGID,\n" +
- " :BEGINDATE,\n" +
- " :ENDDATE,\n" +
- " :REMARKS,\n" +
- " SYS_GUID())";
- paras = new OracleParameter[]
- {
- new OracleParameter(":LOGID",logid),
- new OracleParameter(":DATACODE","40"),
- new OracleParameter(":REMARKS","商标变更新"),
- new OracleParameter(":BEGINDATE", createtimebegin),
- new OracleParameter(":ENDDATE", ndate),
- };
- returnRows = oracleTrConn.ExecuteNonQuery(sqlText, paras);
- #region 明细
- sqlText = "INSERT INTO tsap_hegii_workdata_bg\n" +
- " (yyyymmdd\n" +
- " ,workcode\n" +
- " ,datacode\n" +
- " ,goodscode\n" +
- " ,sapcode\n" +
- " ,usercode\n" +
- " ,outputnum\n" +
- " ,scrapnum\n" +
- " ,cleanupnum\n" +
- " ,repairnum\n" +
- " ,workshop\n" +
- " ,logid\n" +
- " ,testmouldflag\n" +
- " ,zscs\n" +
- " ,charg)\n" +
- " SELECT yyyymmdd\n" +
- " ,workcode\n" +
- " ,datacode\n" +
- " ,goodscode\n" +
- " ,sapcode\n" +
- " ,usercode\n" +
- " ,SUM(outputnum) outputnum\n" +
- " ,SUM(scrapnum) scrapnum\n" +
- " ,SUM(cleanupnum) cleanupnum\n" +
- " ,SUM(repairnum) repairnum\n" +
- " ,workshop\n" +
- " ,logid\n" +
- " ,testmouldflag\n" +
- " ,zscs\n" +
- " ,CHARG from (\n" +
- " SELECT to_char(SYSDATE, 'YYYYMMDD') yyyymmdd\n" +
- " ,wb.workcode\n" +
- " ,wb.datacode\n" +
- " ,wb.goodscode\n" +
- " ,wb.sapcode\n" +
- " ,wb.usercode\n" +
- " ,SUM(wb.outputnum) outputnum\n" +
- " ,SUM(wb.scrapnum) scrapnum\n" +
- " ,SUM(wb.cleanupnum) cleanupnum\n" +
- " ,SUM(wb.repairnum) repairnum\n" +
- " ,wb.workshop\n" +
- " ,:LOGID logid\n" +
- " ,wb.testmouldflag\n" +
- " ,wb.zscs\n" +
- " ,'24065000E' CHARG\n" +
- " FROM tsap_hegii_workdata_bg wb\n" +
- " LEFT JOIN tsap_hegii_datalog_bg dl\n" +
- " ON dl.logid = wb.logid\n" +
- " WHERE dl.datastuts IN ('Q') AND dl.REMARKS NOT IN( '商标变更新')\n" +
- " AND wb.datacode = '40'\n" +
- " GROUP BY to_char(SYSDATE, 'YYYYMMDD'),wb.workcode,wb.datacode,wb.goodscode,wb.sapcode,wb.usercode,wb.workshop,wb.testmouldflag,wb.zscs,'24065000E' \n" +
- " UNION ALL\n" +
- " SELECT to_char(SYSDATE, 'YYYYMMDD') yyyymmdd\n" +
- " ,wb.workcode\n" +
- " ,wb.datacode\n" +
- " ,wb.goodscode\n" +
- " ,wb.sapcode\n" +
- " ,wb.usercode\n" +
- " ,SUM(wb.outputnum) outputnum\n" +
- " ,SUM(wb.scrapnum) scrapnum\n" +
- " ,SUM(wb.cleanupnum) cleanupnum\n" +
- " ,SUM(wb.repairnum) repairnum\n" +
- " ,wb.workshop\n" +
- " ,:LOGID logid\n" +
- " ,wb.testmouldflag\n" +
- " ,wb.zscs\n" +
- " ,'24065000E' CHARG\n" +
- " FROM tsap_hegii_workdata_bg_sbbg wb\n" +
- " WHERE wb.createtime >= :BEGINDATE\n" +
- " AND wb.createtime < :ENDDATE\n" +
- " AND wb.datacode = '40'\n" +
- " GROUP BY to_char(SYSDATE, 'YYYYMMDD'),wb.workcode,wb.datacode,wb.goodscode,wb.sapcode,wb.usercode,wb.workshop,wb.testmouldflag,wb.zscs,'24065000E' )\n" +
- " GROUP BY yyyymmdd,workcode,datacode,goodscode,sapcode,usercode,workshop,logid,testmouldflag,zscs,CHARG ";
- paras = new OracleParameter[]
- {
- new OracleParameter(":LOGID",logid),
- new OracleParameter(":ENDDATE", ndate),
- new OracleParameter(":BEGINDATE", createtimebegin),
- };
- returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- #endregion
- }
- #endregion
- #region 50节点
- else if (dTable.Rows[j]["DATACODE"].ToString() == "50")
- {
- int logid = int.Parse(oracleTrConn.GetSqlResultToStr(sqlText));
- //记录logid
- logids.Add(logid);
- timeString = @" SELECT case when MAX(DL.EXECUTEDATEEND) is null then date'2024-06-17' else MAX(DL.EXECUTEDATEEND) end as EXECUTEDATEEND
- FROM TSAP_HEGII_DATALOG_BG DL
- WHERE DL.LOGTYPE = '4'
- AND DL.REMARKS ='商标变更新'
- AND DL.DATACODE = '50' ";
- createtimebegin = Convert.ToDateTime(oracleTrConn.GetSqlResultToStr(timeString));
- sqlText = "INSERT INTO TSAP_HEGII_DATALOG_BG\n" +
- " (LOGID,\n" +
- " LOGTYPE,\n" +
- " BEGINTIME,\n" +
- " YYYYMMDD,\n" +
- " WORKCODE,\n" +
- " DATACODE,\n" +
- " DATASTUTS,\n" +
- " DATAMSG,\n" +
- " DATALOGID,\n" +
- " EXECUTEDATEBEGIN,\n" +
- " EXECUTEDATEEND,\n" +
- " REMARKS,\n" +
- " SAPGUID)\n" +
- " VALUES\n" +
- " (:LOGID,\n" +
- " '4',\n" +
- " SYSDATE,\n" +
- " TO_CHAR(SYSDATE, 'YYYYMMDD'),\n" +
- " 5000,\n" +
- " :DATACODE,\n" +
- " 'Q',\n" +
- " '',\n" +
- " :LOGID,\n" +
- " :BEGINDATE,\n" +
- " :ENDDATE,\n" +
- " :REMARKS,\n" +
- " SYS_GUID())";
- paras = new OracleParameter[]
- {
- new OracleParameter(":LOGID",logid),
- new OracleParameter(":DATACODE","50"),
- new OracleParameter(":REMARKS","商标变更新"),
- new OracleParameter(":BEGINDATE", createtimebegin),
- new OracleParameter(":ENDDATE", ndate),
- };
- returnRows = oracleTrConn.ExecuteNonQuery(sqlText, paras);
- #region 明细
- sqlText = "INSERT INTO tsap_hegii_workdata_bg\n" +
- " (yyyymmdd\n" +
- " ,workcode\n" +
- " ,datacode\n" +
- " ,goodscode\n" +
- " ,sapcode\n" +
- " ,usercode\n" +
- " ,outputnum\n" +
- " ,scrapnum\n" +
- " ,cleanupnum\n" +
- " ,repairnum\n" +
- " ,workshop\n" +
- " ,logid\n" +
- " ,testmouldflag\n" +
- " ,zscs\n" +
- " ,charg)\n" +
- " SELECT yyyymmdd\n" +
- " ,workcode\n" +
- " ,datacode\n" +
- " ,goodscode\n" +
- " ,sapcode\n" +
- " ,usercode\n" +
- " ,SUM(outputnum) outputnum\n" +
- " ,SUM(scrapnum) scrapnum\n" +
- " ,SUM(cleanupnum) cleanupnum\n" +
- " ,SUM(repairnum) repairnum\n" +
- " ,workshop\n" +
- " ,logid\n" +
- " ,testmouldflag\n" +
- " ,zscs\n" +
- " ,CHARG from (\n" +
- " SELECT to_char(SYSDATE, 'YYYYMMDD') yyyymmdd\n" +
- " ,wb.workcode\n" +
- " ,wb.datacode\n" +
- " ,wb.goodscode\n" +
- " ,wb.sapcode\n" +
- " ,wb.usercode\n" +
- " ,SUM(wb.outputnum) outputnum\n" +
- " ,SUM(wb.scrapnum) scrapnum\n" +
- " ,SUM(wb.cleanupnum) cleanupnum\n" +
- " ,SUM(wb.repairnum) repairnum\n" +
- " ,wb.workshop\n" +
- " ,:LOGID logid\n" +
- " ,wb.testmouldflag\n" +
- " ,wb.zscs\n" +
- " ,'24065000E' CHARG\n" +
- " FROM tsap_hegii_workdata_bg wb\n" +
- " LEFT JOIN tsap_hegii_datalog_bg dl\n" +
- " ON dl.logid = wb.logid\n" +
- " WHERE dl.datastuts IN ('Q') AND dl.REMARKS NOT IN( '商标变更新')\n" +
- " AND wb.datacode = '50'\n" +
- " GROUP BY to_char(SYSDATE, 'YYYYMMDD'),wb.workcode,wb.datacode,wb.goodscode,wb.sapcode,wb.usercode,wb.workshop,wb.testmouldflag,wb.zscs,'24065000E' \n" +
- " UNION ALL\n" +
- " SELECT to_char(SYSDATE, 'YYYYMMDD') yyyymmdd\n" +
- " ,wb.workcode\n" +
- " ,wb.datacode\n" +
- " ,wb.goodscode\n" +
- " ,wb.sapcode\n" +
- " ,wb.usercode\n" +
- " ,SUM(wb.outputnum) outputnum\n" +
- " ,SUM(wb.scrapnum) scrapnum\n" +
- " ,SUM(wb.cleanupnum) cleanupnum\n" +
- " ,SUM(wb.repairnum) repairnum\n" +
- " ,wb.workshop\n" +
- " ,:LOGID logid\n" +
- " ,wb.testmouldflag\n" +
- " ,wb.zscs\n" +
- " ,'24065000E' CHARG\n" +
- " FROM tsap_hegii_workdata_bg_sbbg wb\n" +
- " WHERE wb.createtime >= :BEGINDATE\n" +
- " AND wb.createtime < :ENDDATE\n" +
- " AND wb.datacode = '50'\n" +
- " GROUP BY to_char(SYSDATE, 'YYYYMMDD'),wb.workcode,wb.datacode,wb.goodscode,wb.sapcode,wb.usercode,wb.workshop,wb.testmouldflag,wb.zscs,'24065000E' )\n" +
- " GROUP BY yyyymmdd,workcode,datacode,goodscode,sapcode,usercode,workshop,logid,testmouldflag,zscs,CHARG ";
- paras = new OracleParameter[]
- {
- new OracleParameter(":LOGID",logid),
- new OracleParameter(":ENDDATE", ndate),
- new OracleParameter(":BEGINDATE", createtimebegin),
- };
- returnRows += oracleTrConn.ExecuteNonQuery(sqlText, paras);
- #endregion
- }
- #endregion
- }
- #endregion
- #region 更新总单状态为F
- string ids = string.Join(",", logids);
- if (!string.IsNullOrWhiteSpace(ids))
- {
- string sql1 = "update TSAP_HEGII_DATALOG_BG set DATASTUTS='F' where DATASTUTS = 'Q' AND REMARKS = '商标变更新' AND LOGID IN (" + ids + ") ";
- returnRows += oracleTrConn.ExecuteNonQuery(sql1);
- returnRows += oracleTrConn.ExecuteNonQuery(sql1);
- }
- #endregion
- #endregion
- }
- oracleTrConn.Commit();
- oracleTrConn.Disconnect();
- }
- catch (Exception ex)
- {
- if (oracleTrConn.ConnState == System.Data.ConnectionState.Open)
- {
- oracleTrConn.Rollback();
- oracleTrConn.Disconnect();
- }
- throw ex;
- }
- finally
- {
- if (oracleTrConn != null)
- {
- oracleTrConn.Close();
- }
- }
- }
- /// <summary>
- /// 执行与推送
- /// </summary>
- /// <param name="datacode"></param>
- /// <param name="ndate"></param>
- /// <returns></returns>
- public static ServiceResultEntity SetWorkData1001_5000(string datacode, DateTime ndate)
- {
- ServiceResultEntity sre = new ServiceResultEntity();
- IDBTransaction oracleConn = null;
- try
- {
- #region 事务1,执行存储过程
- OracleParameter[] paras = null;
- int logid = 0;
- string message = string.Empty;
- // 1001 模具生产
- if ("1001".Equals(datacode))
- {
- paras = new OracleParameter[]
- {
- new OracleParameter("in_dateend", OracleDbType.Date, ndate, ParameterDirection.Input),
- new OracleParameter("out_logid", OracleDbType.Int32, null, ParameterDirection.Output),
- new OracleParameter("out_msg", OracleDbType.NVarchar2, 500, null, ParameterDirection.Output)
- };
- oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- DataSet ds = oracleConn.ExecStoredProcedure("PRO_SAP_HEGII_WORKDATA_BG1001", paras);
- int.TryParse(paras[1].Value + "", out logid);
- message = paras[2].Value + "";
- oracleConn.Commit();
- }
- // 如果logid为0,则数据没有生成
- if (logid == 0)
- {
- sre.Status = Constant.ServiceResultStatus.Other;
- sre.Message = message;
- //return sre; // 推送之前失败的
- }
- #endregion
- // 事物2,同步SAP接口
- string sqlString = "select SAP_INI_BG from TP_SYS_SAPCONFIG";
- string SAP_ING_NEW = oracleConn.GetSqlResultToStr(sqlString);
- if (SAP_ING_NEW == "1")
- {
- sre = SyncSap1001_5000(ndate, datacode);
- }
- return sre;
- }
- catch (Exception ex)
- {
- throw ex;
- }
- finally
- {
- if (oracleConn != null &&
- oracleConn.ConnState == ConnectionState.Open)
- {
- oracleConn.Disconnect();
- }
- }
- }
- /// <summary>
- /// 同步SAP接口5000端口新
- /// </summary>
- /// <param name="date"></param>
- /// <param name="datacode"></param>
- /// <param name="userid"></param>
- /// <param name="logid"></param>
- /// <returns></returns>
- public static ServiceResultEntity SyncSap1001_5000(DateTime date, string datacode)
- {
- ServiceResultEntity sre = new ServiceResultEntity();
- IDBTransaction oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- try
- {
- OracleParameter[] paras = null;
- int r = 0;
- // 查询当前节点所有不为S的日志
- string sqlString = @"
- SELECT DL.LOGID
- FROM TSAP_HEGII_DATALOG_BG DL
- WHERE DL.DATASTUTS = 'F'
- AND DL.DATACODE = :DATACODE ";
- paras = new OracleParameter[]
- {
- new OracleParameter(":DATACODE", datacode),
- };
- DataTable dtLogID = oracleConn.GetSqlResultToDt(sqlString, paras);
- if (dtLogID == null || dtLogID.Rows.Count == 0)
- {
- return sre;
- }
- string logIDs = "," + string.Join(",", dtLogID.AsEnumerable().Select(d => d.Field<decimal>("LOGID")).ToArray()) + ",";
- sqlString = @"
- SELECT TO_CHAR(WD.ORDERCODE) AS ZID,
- TO_CHAR(WD.WORKCODE) AS WERKS,
- TO_CHAR(WD.SAPCODE) MATNR,
- TO_CHAR(WD.YYYYMMDD) BUDAT,
- TO_CHAR(WD.OUTPUTNUM) ZDKCL,
- TO_CHAR(WD.ORDERITEM) IDNRK
- FROM TSAP_HEGII_WORKDATA_BG WD
- INNER JOIN TSAP_HEGII_DATALOG_BG DL
- ON WD.LOGID = DL.LOGID
- WHERE INSTR(:LOGIDS, ',' || WD.LOGID || ',') > 0 ";
- paras = new OracleParameter[]
- {
- new OracleParameter(":DATACODE",datacode),
- new OracleParameter(":LOGIDS", OracleDbType.Varchar2, logIDs, ParameterDirection.Input),
- };
- DataTable workData = oracleConn.GetSqlResultToDt(sqlString, paras);
- int num = workData.Rows.Count;
- if (num > 0)
- {
- // 调用SAP接口
- //string postString = "{\"ZSUM\":" + num.ToString() + ",\"TABLE_IN\":{\"item\":" + JsonHelper.ToJson(ModelConvertHelper<BGToSAP>.ConvertToModel(workData)) + "}}";
- string postString = "{\"IT_TAB\":{\"item\":" + JsonHelper.ToJson(workData) + "}}";
- INIUtility ini = INIUtility.Instance(INIUtility.IniFile.SAP_HEGII);
- // 配置文件
- string url_BG1001_049 = ini.ReadIniData("SAP_NEW_INFO", "Url_BG1001_049");
- //string url_BG1001_049 = "http://hgs4podev.hegii.com:50200/RESTAdapter/DKMES/ZPPFM049";
- string result = PostData(url_BG1001_049, postString, "POST");
- sqlString = @"
- UPDATE TSAP_HEGII_DATALOG_BG T
- SET T.ENDTIME = SYSDATE,
- DATASTUTS = :DATASTUTS,
- DATAMSG = :MSG
- WHERE INSTR(:LOGIDS, ',' || LOGID || ',') > 0 ";
- paras = new OracleParameter[]
- {
- new OracleParameter(":DATASTUTS",OracleDbType.Varchar2, JObject.Parse(result)["ZTYPE"].ToString(), ParameterDirection.Input),
- new OracleParameter(":MSG",OracleDbType.Varchar2, JObject.Parse(result)["ZMSG"].ToString(), ParameterDirection.Input),
- new OracleParameter(":LOGIDS", OracleDbType.Varchar2, logIDs, ParameterDirection.Input),
- };
- r = oracleConn.ExecuteNonQuery(sqlString, paras);
- sre.Message = JObject.Parse(result)["ZMSG"].ToString();
- sre.Result = JObject.Parse(result)["ZTYPE"].ToString();
- }
- else
- {
- sqlString = @"
- UPDATE TSAP_HEGII_DATALOG_BG T
- SET T.ENDTIME = SYSDATE,
- DATASTUTS = :DATASTUTS,
- DATAMSG = :MSG
- WHERE INSTR(:LOGIDS, ',' || LOGID || ',') > 0 ";
- paras = new OracleParameter[]
- {
- new OracleParameter(":DATASTUTS",OracleDbType.Varchar2, "S", ParameterDirection.Input),
- new OracleParameter(":MSG",OracleDbType.Varchar2, "num:0", ParameterDirection.Input),
- new OracleParameter(":LOGIDS", OracleDbType.Varchar2, logIDs, ParameterDirection.Input),
- };
- r = oracleConn.ExecuteNonQuery(sqlString, paras);
- sre.Message = "num:0";
- sre.Result = "S";
- }
- oracleConn.Commit();
- return sre;
- }
- catch (Exception ex)
- {
- OutputLog.TraceLog(LogPriority.Error,
- "BG1001ToSAP",
- "报工" + date.ToString("yyyy-MM-dd HH:mm:ss"),
- ex.ToString(),
- LocalPath.LogExePath + "SAP_HEGII\\Error_");
- throw ex;
- }
- finally
- {
- if (oracleConn != null &&
- oracleConn.ConnState == ConnectionState.Open)
- {
- oracleConn.Disconnect();
- }
- }
- }
- /// <summary>
- /// 执行与推送
- /// </summary>
- /// <param name="datacode"></param>
- /// <param name="ndate"></param>
- /// <returns></returns>
- public static ServiceResultEntity SetWorkData10_50_5000(string datacode, DateTime ndate)
- {
- ServiceResultEntity sre = new ServiceResultEntity();
- IDBTransaction oracleConn = null;
- try
- {
- #region 事务1,执行存储过程
- OracleParameter[] paras = null;
- int logid = 0;
- string message = string.Empty;
- // 10 模具
- if ("10".Equals(datacode))
- {
- paras = new OracleParameter[]
- {
- new OracleParameter("in_dateend", OracleDbType.Date, ndate, ParameterDirection.Input),
- new OracleParameter("out_logid", OracleDbType.Int32, null, ParameterDirection.Output),
- new OracleParameter("out_msg", OracleDbType.NVarchar2, 500, null, ParameterDirection.Output)
- };
- oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- DataSet ds = oracleConn.ExecStoredProcedure("PRO_SAP_HEGII_WORKDATA_BG10", paras);
- int.TryParse(paras[1].Value + "", out logid);
- message = paras[2].Value + "";
- oracleConn.Commit();
- }
- // 20 湿坯
- else if ("20".Equals(datacode))
- {
- paras = new OracleParameter[]
- {
- new OracleParameter("in_dateend", OracleDbType.Date, ndate, ParameterDirection.Input),
- new OracleParameter("out_logid", OracleDbType.Int32, null, ParameterDirection.Output),
- new OracleParameter("out_msg", OracleDbType.NVarchar2, 500, null, ParameterDirection.Output)
- };
- oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- DataSet ds = oracleConn.ExecStoredProcedure("PRO_SAP_HEGII_WORKDATA_BG20", paras);
- int.TryParse(paras[1].Value + "", out logid);
- message = paras[2].Value + "";
- oracleConn.Commit();
- }
- // 30 精坯
- else if ("30".Equals(datacode))
- {
- paras = new OracleParameter[]
- {
- new OracleParameter("in_dateend", OracleDbType.Date, ndate, ParameterDirection.Input),
- new OracleParameter("in_datacode", OracleDbType.Varchar2, datacode, ParameterDirection.Input),
- new OracleParameter("out_logid", OracleDbType.Int32, null, ParameterDirection.Output),
- new OracleParameter("out_msg", OracleDbType.NVarchar2, 500, null, ParameterDirection.Output)
- };
- oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- DataSet ds = oracleConn.ExecStoredProcedure("PRO_SAP_HEGII_WORKDATA_BG30", paras);
- int.TryParse(paras[2].Value + "", out logid);
- message = paras[3].Value + "";
- oracleConn.Commit();
- }
- // 40 釉坯
- else if ("40".Equals(datacode))
- {
- paras = new OracleParameter[]
- {
- new OracleParameter("in_dateend", OracleDbType.Date, ndate, ParameterDirection.Input),
- new OracleParameter("in_datacode", OracleDbType.Varchar2, datacode, ParameterDirection.Input),
- new OracleParameter("out_logid", OracleDbType.Int32, null, ParameterDirection.Output),
- new OracleParameter("out_msg", OracleDbType.NVarchar2, 500, null, ParameterDirection.Output)
- };
- oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- DataSet ds = oracleConn.ExecStoredProcedure("PRO_SAP_HEGII_WORKDATA_BG40", paras);
- int.TryParse(paras[2].Value + "", out logid);
- message = paras[3].Value + "";
- oracleConn.Commit();
- }
- // 50 烧成
- else if ("50".Equals(datacode))
- {
- paras = new OracleParameter[]
- {
- new OracleParameter("in_dateend", OracleDbType.Date, ndate, ParameterDirection.Input),
- new OracleParameter("in_datacode", OracleDbType.Varchar2, datacode, ParameterDirection.Input),
- new OracleParameter("out_logid", OracleDbType.Int32, null, ParameterDirection.Output),
- new OracleParameter("out_msg", OracleDbType.NVarchar2, 500, null, ParameterDirection.Output)
- };
- oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- DataSet ds = oracleConn.ExecStoredProcedure("PRO_SAP_HEGII_WORKDATA_BG50", paras);
- int.TryParse(paras[2].Value + "", out logid);
- message = paras[3].Value + "";
- oracleConn.Commit();
- }
- // 55 裸瓷包装
- else if ("55".Equals(datacode))
- {
- paras = new OracleParameter[]
- {
- new OracleParameter("in_dateend", OracleDbType.Date, ndate, ParameterDirection.Input),
- new OracleParameter("out_logid", OracleDbType.Int32, null, ParameterDirection.Output),
- new OracleParameter("out_msg", OracleDbType.NVarchar2, 500, null, ParameterDirection.Output)
- };
- oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- DataSet ds = oracleConn.ExecStoredProcedure("PRO_SAP_HEGII_WORKDATA_BG55", paras);
- int.TryParse(paras[1].Value + "", out logid);
- message = paras[2].Value + "";
- oracleConn.Commit();
- }
- // 如果logid为0,则数据没有生成
- if (logid == 0)
- {
- sre.Status = Constant.ServiceResultStatus.Other;
- sre.Message = message;
- return sre;
- }
- #endregion
- // 事物2,同步SAP接口
- string sqlString = "select SAP_INI_BG from TP_SYS_SAPCONFIG";
- string SAP_ING_NEW = oracleConn.GetSqlResultToStr(sqlString);
- if (SAP_ING_NEW == "1")
- {
- sre = SyncSap5000(ndate, datacode);
- }
- return sre;
- }
- catch (Exception ex)
- {
- throw ex;
- }
- finally
- {
- if (oracleConn != null &&
- oracleConn.ConnState == ConnectionState.Open)
- {
- oracleConn.Disconnect();
- }
- }
- }
- /// <summary>
- /// 同步SAP接口5000端口新
- /// </summary>
- /// <param name="date"></param>
- /// <param name="datacode"></param>
- /// <param name="userid"></param>
- /// <param name="logid"></param>
- /// <returns></returns>
- public static ServiceResultEntity SyncSap5000(DateTime date, string datacode)
- {
- ServiceResultEntity sre = new ServiceResultEntity();
- IDBTransaction oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- try
- {
- OracleParameter[] paras = null;
- int r = 0;
- // 查询当前节点所有不为S的日志
- string sqlString = @"
- SELECT DL.LOGID
- FROM TSAP_HEGII_DATALOG_BG DL
- WHERE 1 = 1
- AND DL.DATASTUTS = 'F'
- AND DL.LOGID > 6
- AND DL.DATACODE = :DATACODE ";
- paras = new OracleParameter[]
- {
- new OracleParameter(":DATACODE", datacode),
- };
- DataTable dtLogID = oracleConn.GetSqlResultToDt(sqlString, paras);
- string logIDs = "," + string.Join(",", dtLogID.AsEnumerable().Select(d => d.Field<decimal>("LOGID")).ToArray()) + ",";
- sqlString = @"
- SELECT TO_CHAR(WD.YYYYMMDD) YYYYMMDD,
- WD.WORKCODE AS WERKS,
- TO_CHAR(WD.GOODSCODE) GROES,
- TO_CHAR(WD.SAPCODE) MATNR,
- TO_CHAR(WD.USERCODE) ZGHNU,
- TO_CHAR(WD.DATACODE) ZJDNU,
- TO_CHAR(WD.YYYYMMDD) ZSCNU,
- TO_CHAR(DL.EXECUTEDATEBEGIN, 'HH24MISS') ZKSSJ,
- TO_CHAR(DL.EXECUTEDATEEND, 'YYYYMMDDHH24MISS') ZJSRQ,
- TO_CHAR(WD.ORDERCODE) VBELN,
- TO_CHAR(WD.ORDERITEM) POSNR,
- TO_CHAR(WD.OUTPUTNUM) ZCLNG,
- TO_CHAR(WD.SCRAPNUM) ZSPNG,
- TO_CHAR(WD.CLEANUPNUM) ZQCNG,
- TO_CHAR(WD.RECOVERYNUM) ZHSNG,
- TO_CHAR(WD.REPAIRNUM) ZGBNG,
- TO_CHAR(WD.TESTMOULDFLAG) ZSCMS,
- DECODE(:DATACODE, 20, TO_CHAR(WD.ZSCS), 'T') AS ZSCS,
- TO_CHAR(WD.WORKSHOP) ZSCCJ,
- WD.CHARG,
- TO_CHAR(:DATACODE) DATACODE,
- WD.WORKCODE || WD.CHARG || LPAD(DL.LOGID, 10,'0') AS ZID
- FROM TSAP_HEGII_WORKDATA_BG WD
- INNER JOIN TSAP_HEGII_DATALOG_BG DL
- ON WD.LOGID = DL.LOGID
- WHERE INSTR(:LOGIDS, ',' || WD.LOGID || ',') > 0 ";
- paras = new OracleParameter[]
- {
- new OracleParameter(":DATACODE",datacode),
- new OracleParameter(":LOGIDS", OracleDbType.Varchar2, logIDs, ParameterDirection.Input),
- };
- DataTable workData = oracleConn.GetSqlResultToDt(sqlString, paras);
- int num = workData.Rows.Count;
- // 调用SAP接口
- string postString = "{\"ZSUM\":" + num.ToString() + ",\"TABLE_IN\":{\"item\":" + JsonHelper.ToJson(ModelConvertHelper<BGToSAP>.ConvertToModel(workData)) + "}}";
- INIUtility ini = INIUtility.Instance(INIUtility.IniFile.SAP_HEGII);
- // 配置文件
- string url030 = ini.ReadIniData("SAP_NEW_INFO", "Url030");
- // 测试
- // string url030 = "http://hgs4podev.hegii.com:50200/RESTAdapter/DKMES/ZPPFM030";
- // 正式
- //string url030 = "http://hgs4powd1.hegii.com:8000/RESTAdapter/DKMES/ZPPFM030";
- string result = PostData(url030, postString, "POST");
- sqlString = @"
- UPDATE TSAP_HEGII_DATALOG_BG T
- SET T.ENDTIME = SYSDATE,
- DATASTUTS = :DATASTUTS,
- DATAMSG = :MSG
- WHERE INSTR(:LOGIDS, ',' || LOGID || ',') > 0 ";
- paras = new OracleParameter[]
- {
- new OracleParameter(":DATASTUTS",OracleDbType.Varchar2, JObject.Parse(result)["ZTYPE"].ToString(), ParameterDirection.Input),
- new OracleParameter(":MSG",OracleDbType.Varchar2, JObject.Parse(result)["ZMSG"].ToString(), ParameterDirection.Input),
- new OracleParameter(":LOGIDS", OracleDbType.Varchar2, logIDs, ParameterDirection.Input),
- };
- r = oracleConn.ExecuteNonQuery(sqlString, paras);
- oracleConn.Commit();
- sre.Message = JObject.Parse(result)["ZMSG"].ToString();
- sre.Result = JObject.Parse(result)["ZTYPE"].ToString();
- return sre;
- }
- catch (Exception ex)
- {
- OutputLog.TraceLog(LogPriority.Error,
- "BGToSAP",
- "报工" + date.ToString("yyyy-MM-dd HH:mm:ss"),
- ex.ToString(),
- LocalPath.LogExePath + "SAP_HEGII\\Error_");
- throw ex;
- }
- finally
- {
- if (oracleConn != null &&
- oracleConn.ConnState == ConnectionState.Open)
- {
- oracleConn.Disconnect();
- }
- }
- }
- /// <summary>
- /// 查询同步日志
- /// </summary>
- /// <param name="cre"></param>
- /// <param name="userInfo"></param>
- /// <returns></returns>
- public static ServiceResultEntity GetDataLog_BG(ClientRequestEntity cre)
- {
- IDBConnection oracleConn = ClsDbFactory.CreateDBConnection(DataBaseType.ORACLE, DataManager.ConnectionString);
- ServiceResultEntity sre = new ServiceResultEntity();
- try
- {
- string sqlString =
- "select dl.logid\n" +
- " ,dl.logtype\n" +
- " ,dl.begintime\n" +
- " ,dl.endtime\n" +
- " ,dl.yyyymmdd\n" +
- " ,dl.workcode\n" +
- " ,dl.datacode\n" +
- " ,dc.datacodename\n" +
- " ,dl.datastuts\n" +
- " ,dl.datamsg\n" +
- " ,dl.datalogid\n" +
- " ,dl.executedatebegin\n" +
- " ,dl.executedateend\n" +
- " ,u.usercode synusercode\n" +
- " ,DECODE(dl.logtype, '4', dl.Remarks,'') AS Remarks\n" +
- " from TSAP_HEGII_DATALOG_BG dl\n" +
- " inner join tsap_hegii_datacode dc\n" +
- " on dc.datacode = dl.datacode\n" +
- " left join tp_mst_user u\n" +
- " on u.userid = dl.createuserid\n" +
- " where dl.logtype IN('2','3','4')\n" +
- " and dl.datastuts <> 'N'\n" +
- " and dl.executedatebegin >= :DATEBEGIN\n" +
- " and dl.executedateend < :DATEEND\n" +
- " and (-1= :DATACODE or dl.datacode=:DATACODE )";//add xiacm 2022-10-12
- OracleParameter[] oracleParameter = new OracleParameter[]
- {
- new OracleParameter(":DATEBEGIN",OracleDbType.Date, cre.Properties["datebegin"], ParameterDirection.Input),
- new OracleParameter(":DATEEND",OracleDbType.Date, cre.Properties["dateend"], ParameterDirection.Input),
- new OracleParameter(":DATACODE",OracleDbType.Varchar2, cre.Properties["datacode"], ParameterDirection.Input),
- };
- sqlString += "ORDER BY dl.logid DESC\n";
- sre.Data = oracleConn.GetSqlResultToDs(sqlString, oracleParameter);
- return sre;
- }
- catch (Exception ex)
- {
- throw ex;
- }
- finally
- {
- if (oracleConn != null)
- {
- oracleConn.Close();
- }
- }
- }
- /// <summary>
- /// 查询同步明细
- /// </summary>
- /// <param name="logid"></param>
- /// <param name="userInfo"></param>
- /// <returns></returns>
- public static ServiceResultEntity GetWorkData_BG(ClientRequestEntity cre)
- {
- IDBConnection oracleConn = ClsDbFactory.CreateDBConnection(DataBaseType.ORACLE, DataManager.ConnectionString);
- ServiceResultEntity sre = new ServiceResultEntity();
- try
- {
- int logid = Convert.ToInt32(cre.Request);
- string sqlString = "\n" +
- "select wd.yyyymmdd\n" +
- " ,wd.workcode\n" +
- " ,wd.datacode\n" +
- " ,dc.datacodename\n" +
- " ,wd.goodscode\n" +
- " ,wd.sapcode\n" +
- " ,wd.usercode\n" +
- " ,wd.ordercode\n" +
- " ,wd.orderitem\n" +
- " ,to_number(wd.outputnum) outputnum\n" +
- " ,to_number(wd.scrapnum) scrapnum\n" +
- " ,to_number(wd.cleanupnum) cleanupnum\n" +
- " ,to_number(wd.recoverynum) recoverynum\n" +
- " ,to_number(wd.repairnum) repairnum\n" +
- " ,wd.createtime\n" +
- " ,wd.ztype\n" +
- " ,wd.zmsg\n" +
- " ,wd.ztime\n" +
- " ,wd.testmouldflag\n" +
- " ,wd.zscs\n" +
- " ,wd.logid\n" +
- " from tsap_hegii_workdata_BG wd\n" +
- " inner join TSAP_HEGII_DATALOG_BG dl\n" +
- " on dl.logid = wd.logid\n" +
- " inner join tsap_hegii_datacode dc\n" +
- " on dc.datacode = wd.datacode\n";
- //update xiacm 2022-10-12
- if (logid > 0)
- {
- sqlString += " where wd.logid = :logid \n";
- }
- else
- {
- sqlString += " where dl.executedatebegin >= :DATEBEGIN and dl.executedateend <= :DATEEND";
- sqlString += " and (-1= :DATACODE OR wd.datacode = :DATACODE)";
- }
- sqlString += " order by wd.goodscode,wd.sapcode,wd.usercode,wd.ordercode,wd.outputnum \n";
- OracleParameter[] oracleParameter = new OracleParameter[]
- {
- new OracleParameter(":logid",OracleDbType.Int32, logid, ParameterDirection.Input),
- new OracleParameter(":DATEBEGIN",OracleDbType.Date, cre.Properties["datebegin"], ParameterDirection.Input),
- new OracleParameter(":DATEEND",OracleDbType.Date, cre.Properties["dateend"], ParameterDirection.Input),
- new OracleParameter(":DATACODE",OracleDbType.Varchar2, cre.Properties["datacode"], ParameterDirection.Input),
- };
- sre.Data = oracleConn.GetSqlResultToDs(sqlString, oracleParameter);
- return sre;
- }
- catch (Exception ex)
- {
- throw ex;
- }
- finally
- {
- if (oracleConn != null)
- {
- oracleConn.Close();
- }
- }
- }
- /// <summary>
- /// 报工汇总 add xiacm 2022-10-12
- /// </summary>
- /// <param name="cre"></param>
- /// <returns></returns>
- public static ServiceResultEntity GetDataLogTotal_BG(ClientRequestEntity cre)
- {
- IDBConnection oracleConn = ClsDbFactory.CreateDBConnection(DataBaseType.ORACLE, DataManager.ConnectionString);
- ServiceResultEntity sre = new ServiceResultEntity();
- try
- {
- string sqlString = @" SELECT T.DATACODE,
- T.ACTUALOUTPUT,
- T.WORKSHOP,
- T.OUTPUT,
- T.SCRAPNUM,
- T.CLEANNUPNUM,
- T.RECOVERYNUM,
- T.REPAIRNUM,
- T.DRCXFDRJJDCCP,
- T.DRJJBQTRCXDCCP,
- T.DIFFER FROM (
- SELECT T1.DATACODE,
- to_char(T1.ACTUALOUTPUT) ACTUALOUTPUT,
- '-' as WORKSHOP,
- T2.OUTPUT,
- T2.SCRAPNUM,
- T2.CLEANNUPNUM,
- T2.RECOVERYNUM,
- T2.REPAIRNUM,
- to_char(T3.DRCXFDRJJDCCP) DRCXFDRJJDCCP,
- to_char(T4.DRJJBQTRCXDCCP) DRJJBQTRCXDCCP,
- to_char(T1.ACTUALOUTPUT + NVL(T4.DRJJBQTRCXDCCP, 0) - NVL(T3.DRCXFDRJJDCCP, 0) -
- (T2.OUTPUT + T2.RECOVERYNUM)) AS DIFFER
- FROM (
- -- 业务数据汇总
- -- 10
- SELECT '10' AS DATACODE,
- SUM(DECODE(MHH.OPERATIONTYPE, 1, M.STANDARDGROUTINGSUM, 0)) AS ACTUALOUTPUT
- FROM (SELECT MH.GOODSID,
- MH.MOULDID,
- MH.OPERATIONTYPE,
- MH.GROUTINGNUM
- FROM TP_PC_MOULDCHANGEHISTORY MH
- WHERE MH.OPERATIONTYPE IN (1, 2, 3, 9, 11, -1)
- AND MH.CREATETIME >= :DATEBEGIN
- AND MH.CREATETIME < :DATEEND
- UNION ALL
- SELECT MH.GOODSIDAFTER,
- MH.MOULDID,
- 0,
- MH.GROUTINGNUM
- FROM TP_PC_MOULDCHANGEHISTORY MH
- WHERE MH.OPERATIONTYPE = -1
- AND MH.CREATETIME >= :DATEBEGIN
- AND MH.CREATETIME < :DATEEND) MHH
- INNER JOIN TP_PC_MOULD M
- ON M.MOULDID = MHH.MOULDID
- UNION ALL
- -- 20
- SELECT '20' AS DATACODE,
- SUM(DECODE(GH.DATATYPE, 1, 1, -1)) BUSINESSOUTPUT
- FROM TP_PM_GOODSCHANGEHISTORY GH
- INNER JOIN TP_MST_GOODS G
- ON G.GOODSID = GH.GOODSID
- WHERE GH.CREATETIME >= :DATEBEGIN
- AND GH.CREATETIME < :DATEEND
- AND GH.DATATYPE IN (1, 2)
- AND G.SCRAPSUMFLAG = '1'
- UNION ALL
- -- 30
- SELECT '30' AS DATACODE,
- SUM(T1.CC) AS BUSINESSOUTPUT
- FROM (SELECT 1 AS CC
- FROM TP_PM_PRODUCTIONDATA P
- WHERE P.PROCEDUREID IN (53, 97,161)
- AND P.CREATETIME >= :DATEBEGIN
- AND P.CREATETIME < :DATEEND
- UNION ALL
- SELECT -1 AS CC
- FROM TP_PM_PRODUCTIONDATA P
- WHERE P.PROCEDUREID IN (53, 97,161)
- AND P.VALUEFLAG = '0'
- AND P.BACKOUTTIME >= :DATEBEGIN
- AND P.BACKOUTTIME < :DATEEND) T1
- UNION ALL
- -- 40
- SELECT '40' AS DATACODE,
- SUM(T1.CC) AS BUSINESSOUTPUT
- FROM (SELECT 1 AS CC
- FROM TP_PM_PRODUCTIONDATA P
- WHERE P.PROCEDUREID IN (65, 99)
- AND P.CREATETIME >= :DATEBEGIN
- AND P.CREATETIME < :DATEEND
- UNION ALL
- SELECT -1 AS CC
- FROM TP_PM_PRODUCTIONDATA P
- WHERE P.PROCEDUREID IN (65, 99)
- AND P.VALUEFLAG = '0'
- AND P.BACKOUTTIME >= :DATEBEGIN
- AND P.BACKOUTTIME < :DATEEND) T1
- UNION ALL
- -- 50
- SELECT '50' AS DATACODE,
- SUM(T1.CC) AS BUSINESSOUTPUT
- FROM (SELECT COUNT(DISTINCT P.BARCODE) AS CC
- FROM TP_PM_PRODUCTIONDATA P
- WHERE P.PROCEDUREID IN (11, 104)
- AND P.ISREFIRE = '0'
- AND P.ISLENGBU = '0'
- AND ((P.PROCEDUREID = 11 AND (P.CHECKFLAG = '1' OR P.CHECKFLAG IS NULL))
- OR (P.PROCEDUREID = 104 AND P.CHECKFLAG = '1'))
- AND P.CREATETIME >= :DATEBEGIN
- AND P.CREATETIME < :DATEEND
- UNION ALL
- SELECT -1 AS CC
- FROM TP_PM_PRODUCTIONDATA P
- WHERE P.PROCEDUREID = 11
- AND P.VALUEFLAG = '0'
- AND P.ISREFIRE = '0'
- AND P.ISLENGBU = '0'
- AND P.BACKOUTTIME >= :DATEBEGIN
- AND P.BACKOUTTIME < :DATEEND) T1
- UNION ALL
- -- 55
- SELECT '55' AS DATACODE,
- COUNT(DISTINCT P.BARCODE ) AS BUSINESSOUTPUT
- FROM TP_PM_PRODUCTIONDATA P
- WHERE P.PROCEDUREID =159
- AND P.CREATETIME >= :DATEBEGIN
- AND P.CREATETIME < :DATEEND
- AND p.VALUEFLAG = 1
- UNION ALL
- -- 60
- SELECT '60' AS DATACODE,
- COUNT(1) AS BUSINESSOUTPUT
- FROM TP_PM_FINISHEDPRODUCT GH
- WHERE GH.FHTIME >= :DATEBEGIN
- AND GH.FHTIME < :DATEEND) T1
- LEFT JOIN (
- -- 当日推送日志数据汇总
- SELECT DATACODE AS DATACODETD,
- SUM(TO_NUMBER(OUTPUTNUM)) AS OUTPUT,
- SUM(TO_NUMBER(SCRAPNUM)) AS SCRAPNUM,
- SUM(TO_NUMBER(CLEANUPNUM)) AS CLEANNUPNUM,
- SUM(TO_NUMBER(RECOVERYNUM)) AS RECOVERYNUM,
- SUM(TO_NUMBER(REPAIRNUM)) AS REPAIRNUM
- FROM TSAP_HEGII_WORKDATA_BG
- WHERE LOGID IN (SELECT LOGID
- FROM TSAP_HEGII_DATALOG_BG T
- WHERE DATASTUTS = 'S'
- AND EXECUTEDATEBEGIN >= :DATEBEGIN
- AND EXECUTEDATEEND <= :DATEEND)
- GROUP BY DATACODE
- ORDER BY DATACODE) T2
- ON T2.DATACODETD = T1.DATACODE
- LEFT JOIN (
- -- 当日撤销非当日交接的产成品
- SELECT '60' AS DATACODE,
- COUNT(WL.CODEI) AS DRCXFDRJJDCCP
- FROM TP_WMS_LOG WL
- WHERE LOGTYPE = 2
- AND EXISTS (SELECT 1
- FROM TP_WMS_LOG WL1
- WHERE WL1.CODEI = WL.CODEI
- AND WL1.LOGTYPE = 1
- AND TRUNC(WL1.CREATETIME) < TRUNC(WL.CREATETIME))
- AND WL.CREATETIME >= :DATEBEGIN
- AND WL.CREATETIME < :DATEEND
- UNION ALL
- --55节点(裸瓷包装)
- SELECT '55' AS DATACODE,
- COUNT(DISTINCT P.BARCODE) AS DRCXFDRJJDCCP
- FROM TP_PM_PRODUCTIONDATA P
- WHERE P.PROCEDUREID =159
- AND P.BACKOUTTIME >= :DATEBEGIN
- AND P.BACKOUTTIME <:DATEEND
- AND P.CREATETIME < :DATEBEGIN
- AND p.VALUEFLAG = 0
- ) T3
- ON T3.DATACODE = T1.DATACODE
- LEFT JOIN (
- -- 当日交接被其他日撤销的产成品
- SELECT '60' AS DATACODE,
- COUNT(WL.CODEI) AS DRJJBQTRCXDCCP
- FROM TP_WMS_LOG WL
- WHERE LOGTYPE = 1
- AND EXISTS (SELECT 1
- FROM TP_WMS_LOG WL1
- WHERE WL1.CODEI = WL.CODEI
- AND WL1.LOGTYPE = 2
- AND TRUNC(WL1.CREATETIME) > TRUNC(WL.CREATETIME))
- AND WL.CREATETIME >= :DATEBEGIN
- AND WL.CREATETIME < :DATEEND
- UNION ALL
- --55节点(裸瓷包装)
- SELECT '55' AS DATACODE,
- COUNT(DISTINCT P.BARCODE) AS DRCXFDRJJDCCP
- FROM TP_PM_PRODUCTIONDATA P
- WHERE P.PROCEDUREID =159
- AND P.CREATETIME >= :DATEBEGIN
- AND P.CREATETIME < :DATEEND
- AND P.BACKOUTTIME >:DATEEND
- AND p.VALUEFLAG = 0
- ) T4
- ON T4.DATACODE = T1.DATACODE
- UNION ALL
- SELECT T2.DATACODE,
- '' ACTUALOUTPUT,
- TO_CHAR(T2.WORKSHOP) WORKSHOP,
- T2.OUTPUT,
- T2.SCRAPNUM,
- T2.CLEANNUPNUM,
- T2.RECOVERYNUM,
- T2.REPAIRNUM,
- '' AS DRCXFDRJJDCCP,
- '' AS DRJJBQTRCXDCCP,
- '' AS DIFFER
- FROM (
- -- 当日推送日志数据汇总
- SELECT DATACODE ,
- WORKSHOP,
- SUM(TO_NUMBER(OUTPUTNUM)) AS OUTPUT,
- SUM(TO_NUMBER(SCRAPNUM)) AS SCRAPNUM,
- SUM(TO_NUMBER(CLEANUPNUM)) AS CLEANNUPNUM,
- SUM(TO_NUMBER(RECOVERYNUM)) AS RECOVERYNUM,
- SUM(TO_NUMBER(REPAIRNUM)) AS REPAIRNUM
- FROM TSAP_HEGII_WORKDATA_BG
- WHERE LOGID IN (SELECT LOGID
- FROM TSAP_HEGII_DATALOG_BG T
- WHERE DATASTUTS = 'S'
- AND T.DATACODE IN ('20','30','40','50','55','60')
- AND EXECUTEDATEBEGIN >= :DATEBEGIN
- AND EXECUTEDATEEND <= :DATEEND )
- GROUP BY DATACODE ,WORKSHOP
- ORDER BY DATACODE ) T2
- ) T
- WHERE (-1 = :DATACODE OR T.DATACODE = :DATACODE)
- ORDER BY T.DATACODE,T.WORKSHOP";
- OracleParameter[] oracleParameter = new OracleParameter[]
- {
- new OracleParameter(":DATEBEGIN",OracleDbType.Date, cre.Properties["datebegin"], ParameterDirection.Input),
- new OracleParameter(":DATEEND",OracleDbType.Date, cre.Properties["dateend"], ParameterDirection.Input),
- new OracleParameter(":DATACODE",OracleDbType.Varchar2, cre.Properties["datacode"], ParameterDirection.Input),
- };
- sre.Data = oracleConn.GetSqlResultToDs(sqlString, oracleParameter);
- return sre;
- }
- catch (Exception ex)
- {
- throw ex;
- }
- finally
- {
- if (oracleConn != null)
- {
- oracleConn.Close();
- }
- }
- }
- /// <summary>
- /// 半成品库存 add xiacm 2022-11-09
- /// </summary>
- /// <param name="cre"></param>
- /// <returns></returns>
- public static ServiceResultEntity GetDataIVITotal_BC(ClientRequestEntity cre)
- {
- IDBConnection oracleConn = ClsDbFactory.CreateDBConnection(DataBaseType.ORACLE, DataManager.ConnectionString);
- ServiceResultEntity sre = new ServiceResultEntity();
- try
- {
- string sqlString = @"SELECT semi.DATACODE ,
- semi.WORKSHOP ,
- semi.MATERIALCODE ,
- semi.GOODSCODE ,
- semi.GOODSNAME ,
- COUNT(1) AS INVENTORYQUANTITY,
- SYSDATE AS CREATETIME
- FROM (
- --配置表里的所有工序
- SELECT DI.DATACODE,
- CASE
- WHEN DI.WORKSHOP = 0
- AND DI.ITEMTYPE = 1
- AND IP.KILNCODE = 'SK1' THEN
- 1
- WHEN DI.WORKSHOP = 0
- AND DI.ITEMTYPE = 1
- AND IP.KILNCODE = 'SK2' THEN
- 2
- WHEN DI.WORKSHOP = 0
- AND DI.ITEMTYPE = 1
- AND IP.KILNCODE = 'SK3' THEN
- 3
- WHEN DI.WORKSHOP = 2
- AND DI.ITEMTYPE = 1
- AND IP.KILNCODE = 'TK1' THEN
- 1
- WHEN DI.WORKSHOP = 2
- AND DI.ITEMTYPE = 1
- AND IP.KILNCODE = 'TK2' THEN
- 2
- WHEN DI.WORKSHOP = 2
- AND DI.ITEMTYPE = 2
- AND INSTR(GT.GOODSTYPECODE, '001001') = 1 THEN
- 2
- WHEN DI.WORKSHOP = 2
- AND DI.ITEMTYPE = 2
- AND INSTR(GT.GOODSTYPECODE, '001002') = 1 THEN
- 1
- WHEN DI.WORKSHOP = 3 THEN
- 3
- ELSE
- 0
- END WORKSHOP,
- GDD.MATERIALCODE,
- G.GOODSCODE,
- G.GOODSNAME
- FROM TP_PM_INPRODUCTION IP
- INNER JOIN TSAP_HEGII_DATAITEM_SSKC DI
- ON IP.PROCEDUREID = DI.ITEMID
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD
- ON IP.BARCODE = GDD.BARCODE
- INNER JOIN TP_MST_GOODS G
- ON G.GOODSID = GDD.GOODSID
- INNER JOIN TP_MST_GOODSTYPE GT
- ON GT.GOODSTYPEID = G.GOODSTYPEID
- UNION ALL
- --10-0干补
- SELECT DI.DATACODE,
- CASE
- WHEN DI.WORKSHOP = 0
- AND DI.ITEMTYPE = 1
- AND IP.KILNCODE = 'SK1' THEN
- 1
- WHEN DI.WORKSHOP = 0
- AND DI.ITEMTYPE = 1
- AND IP.KILNCODE = 'SK2' THEN
- 2
- WHEN DI.WORKSHOP = 0
- AND DI.ITEMTYPE = 1
- AND IP.KILNCODE = 'SK3' THEN
- 3
- WHEN DI.WORKSHOP = 2
- AND DI.ITEMTYPE = 1
- AND IP.KILNCODE = 'TK1' THEN
- 1
- WHEN DI.WORKSHOP = 2
- AND DI.ITEMTYPE = 1
- AND IP.KILNCODE = 'TK2' THEN
- 2
- WHEN DI.WORKSHOP = 2
- AND DI.ITEMTYPE = 2
- AND INSTR(GT.GOODSTYPECODE, '001001') = 1 THEN
- 2
- WHEN DI.WORKSHOP = 2
- AND DI.ITEMTYPE = 2
- AND INSTR(GT.GOODSTYPECODE, '001002') = 1 THEN
- 1
- WHEN DI.WORKSHOP = 3 THEN
- 3
- ELSE
- 0
- END WORKSHOP,
- GDD.MATERIALCODE,
- G.GOODSCODE,
- G.GOODSNAME
- FROM TP_PM_INPRODUCTION IP
- INNER JOIN TSAP_HEGII_DATAITEM_SSKC DI
- ON IP.FLOWPROCEDUREID = DI.ITEMID
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD
- ON IP.BARCODE = GDD.BARCODE
- INNER JOIN TP_MST_GOODS G
- ON G.GOODSID = GDD.GOODSID
- INNER JOIN TP_MST_GOODSTYPE GT
- ON GT.GOODSTYPEID = G.GOODSTYPEID
- WHERE PROCEDUREID = 18
- UNION ALL
- --未交坯
- SELECT '20' DATACODE,
- CASE
- WHEN INSTR(GT.GOODSTYPECODE, '001001') = 1
- AND
- (INSTR(GDD.GROUTINGLINECODE, 'B') = 1 OR INSTR(GDD.GROUTINGLINECODE, 'D') = 1) THEN
- 2
- WHEN INSTR(GT.GOODSTYPECODE, '001002') = 1
- AND
- (INSTR(GDD.GROUTINGLINECODE, 'A') = 1 OR INSTR(GDD.GROUTINGLINECODE, 'D') = 1) THEN
- 1
- WHEN INSTR(GDD.GROUTINGLINECODE, 'C') = 1 THEN
- 3
- ELSE
- 0
- END WORKSHOP,
- GDD.MATERIALCODE,
- G.GOODSCODE,
- G.GOODSNAME
- FROM TP_PM_GROUTINGDAILYDETAIL GDD
- INNER JOIN TP_MST_GOODS G
- ON GDD.GOODSID = G.GOODSID
- INNER JOIN TP_MST_GOODSTYPE GT
- ON GT.GOODSTYPEID = G.GOODSTYPEID
- WHERE GDD.VALUEFLAG = 1
- AND GDD.BARCODE IS NOT NULL
- AND GDD.BEGINNINGFLAG = 0
- AND GDD.DELIVERFLAG = 0
- AND GDD.SCRAPFLAG = 0) semi
- where (:DATACODE is null or :DATACODE ='' or :DATACODE ='-1' or instr(','||:DATACODE||',',','||semi.DATACODE||',')>0)
- and (:WORKSHOP is null or :WORKSHOP = '' or instr(','||:WORKSHOP||',',','||semi.WORKSHOP||',')>0)
- and (:MATERIALCODE is null or :MATERIALCODE = '' or instr(','||:MATERIALCODE||',',','||semi.MATERIALCODE||',')>0)
- GROUP BY DATACODE,
- WORKSHOP,
- MATERIALCODE,
- GOODSCODE,
- GOODSNAME
- ORDER BY DATACODE,
- WORKSHOP,
- MATERIALCODE,
- GOODSCODE,
- GOODSNAME";
- OracleParameter[] oracleParameter = new OracleParameter[]
- {
- new OracleParameter(":WORKSHOP",OracleDbType.Varchar2, cre.Properties["WORKSHOP"], ParameterDirection.Input),
- new OracleParameter(":MATERIALCODE",OracleDbType.Varchar2, cre.Properties["MATERIALCODE"], ParameterDirection.Input),
- new OracleParameter(":DATACODE",OracleDbType.Varchar2, cre.Properties["datacode"], ParameterDirection.Input),
- };
- sre.Data = oracleConn.GetSqlResultToDs(sqlString, oracleParameter);
- return sre;
- }
- catch (Exception ex)
- {
- throw ex;
- }
- finally
- {
- if (oracleConn != null)
- {
- oracleConn.Close();
- }
- }
- }
- /// <summary>
- /// 同步SAP接口5000端口_60节点
- /// </summary>
- /// <param name="date"></param>
- /// <param name="datacode"></param>
- /// <param name="userid"></param>
- /// <param name="logid"></param>
- /// <returns></returns>
- public static ServiceResultEntity SyncSap5000_60(DateTime date)
- {
- ServiceResultEntity sre = new ServiceResultEntity();
- IDBTransaction oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- try
- {
- OracleParameter[] paras = null;
- int r = 0;
- // 查询当前节点所有不为S的日志
- string sqlString = @"
- SELECT DL.LOGID
- FROM TSAP_HEGII_DATALOG_BG DL
- WHERE 1 = 1
- AND DL.DATASTUTS = 'F'
- AND DL.LOGID > 6
- AND DL.DATACODE = '60'
- ORDER BY DL.LOGID ";
- DataTable dtLogID = oracleConn.GetSqlResultToDt(sqlString);
- if (dtLogID.Rows.Count == 0)
- {
- sre.Result = "S";
- sre.Message = "没有要同步的数据";
- return sre;
- }
- string logIDs = "," + string.Join(",", dtLogID.AsEnumerable().Select(d => d.Field<decimal>("LOGID")).ToArray()) + ",";
- sqlString = @"
- SELECT TO_CHAR(WD.YYYYMMDD) YYYYMMDD,
- TO_CHAR(5000) WERKS,
- TO_CHAR(WD.GOODSCODE) GROES,
- TO_CHAR(WD.SAPCODE) MATNR,
- TO_CHAR(WD.USERCODE) ZGHNU,
- TO_CHAR(WD.DATACODE) ZJDNU,
- TO_CHAR(WD.CREATETIME, 'YYYYMMDD') ZSCNU,
- TO_CHAR(WD.CREATETIME, 'HH24MISS') ZKSSJ,
- TO_CHAR(WD.CREATETIME, 'YYYYMMDDHH24MISS') ZJSRQ,
- TO_CHAR(WD.ORDERCODE) VBELN,
- TO_CHAR(WD.ORDERITEM) POSNR,
- TO_CHAR(WD.OUTPUTNUM) ZCLNG,
- TO_CHAR(WD.SCRAPNUM) ZSPNG,
- TO_CHAR(WD.CLEANUPNUM) ZQCNG,
- TO_CHAR(WD.RECOVERYNUM) ZHSNG,
- TO_CHAR(WD.REPAIRNUM) ZGBNG,
- TO_CHAR(WD.TESTMOULDFLAG) ZSCMS,
- --'T' AS ZSCS,
- TO_CHAR(WD.ZSCS) ZSCS,
- TO_CHAR(WD.WORKSHOP) ZSCCJ,
- WD.CHARG,
- '60' DATACODE,
- '5000' || WD.CHARG || LPAD(DL.LOGID, 10, '0') AS ZID
- FROM TSAP_HEGII_WORKDATA_BG WD
- INNER JOIN TSAP_HEGII_DATALOG_BG DL
- ON WD.LOGID = DL.LOGID
- WHERE INSTR(:LOGIDS, ',' || WD.LOGID || ',') > 0
- ORDER BY WD.LOGID ";
- paras = new OracleParameter[]
- {
- new OracleParameter(":LOGIDS", OracleDbType.Varchar2, logIDs, ParameterDirection.Input),
- };
- DataTable workData = oracleConn.GetSqlResultToDt(sqlString, paras);
- int num = workData.Rows.Count;
- //sqlString = @"
- //SELECT ZID,
- // WERKS,
- // MATNR,
- // ZJDNU,
- // ZSCS,
- // ZSCCJ,
- // ZSCMS,
- // ZSCNU,
- // ZKSSJ,
- // ZGHNU,
- // GROES,
- // POSNR,
- // IDNRK,
- // MENGE,
- // MEINS,
- // CHARG,
- // LGORT
- // FROM TSAP_HEGII_WORKDATA_BG_ZB
- // WHERE INSTR(:LOGIDS, ',' || LOGID || ',') > 0
- // ORDER BY LOGID ";
- //paras = new OracleParameter[]
- //{
- // new OracleParameter(":LOGIDS", OracleDbType.Varchar2, logIDs, ParameterDirection.Input),
- //};
- //DataTable dtDetail = oracleConn.GetSqlResultToDt(sqlString, paras);
- // 调用SAP接口
- //string postString = "{\"ZSUM\":" + num.ToString() + ",\"TABLE_IN\":{\"item\":" + JsonHelper.ToJson(ModelConvertHelper<BGToSAP>.ConvertToModel(workData)) + "}"
- // + ",\"TABLE_IN1\":{\"item\":" + JsonHelper.ToJson(ModelConvertHelper<BGToSAPDetail>.ConvertToModel(dtDetail)) + "}}";
- string postString = "{\"ZSUM\":" + num.ToString() + ",\"TABLE_IN\":{\"item\":" + JsonHelper.ToJson(ModelConvertHelper<BGToSAP>.ConvertToModel(workData)) + "}}";
- // 配置文件
- INIUtility ini = INIUtility.Instance(INIUtility.IniFile.SAP_HEGII);
- string url030 = ini.ReadIniData("SAP_NEW_INFO", "Url030");
- // 测试
- //url030 = "http://hgs4podev.hegii.com:50200/RESTAdapter/DKMES/ZPPFM030";
- // 正式
- //url030 = "http://hgs4powd1.hegii.com:8000/RESTAdapter/DKMES/ZPPFM030";
- string result = string.Empty;
- try
- {
- result = PostData(url030, postString, "POST");
- }
- catch (Exception ex)
- {
- sre.Result = -2;
- sre.Message = "sap030接口同步失败," + ex.Message;
- return sre;
- }
- sqlString = @"
- UPDATE TSAP_HEGII_DATALOG_BG T
- SET T.ENDTIME = SYSDATE,
- DATASTUTS = :DATASTUTS,
- DATAMSG = :MSG
- WHERE INSTR(:LOGIDS, ',' || LOGID || ',') > 0 ";
- paras = new OracleParameter[]
- {
- new OracleParameter(":DATASTUTS",OracleDbType.Varchar2, JObject.Parse(result)["ZTYPE"].ToString(), ParameterDirection.Input),
- new OracleParameter(":MSG",OracleDbType.Varchar2, JObject.Parse(result)["ZMSG"].ToString(), ParameterDirection.Input),
- new OracleParameter(":LOGIDS", OracleDbType.Varchar2, logIDs, ParameterDirection.Input),
- };
- r = oracleConn.ExecuteNonQuery(sqlString, paras);
- #region 同步WMS系统
- DateTime now = DateTime.Now;
- string message = string.Empty;
- string sqlFpData = @"
- SELECT WL.SKU,
- WL.SERIALNO,
- WL.ADDDAY,
- WL.ADDTIME,
- WL.CODEI,
- WL.UDF1,
- WL.UDF2,
- WL.LPN,
- WL.CREATETIME,
- GDD.SECURITYCODE,
- WL.LOGTYPE
- FROM TP_WMS_LOG WL
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD
- ON GDD.BARCODE = WL.CODEI
- WHERE WL.VALUEFLAG = '1'
- AND WL.BGLOGID = :BGLOGID ";
- string sqlUpdate = @"
- UPDATE TP_WMS_LOG
- SET RETURNDESC = :RETURNDESC,
- UPDATETIME = :UPDATETIME
- WHERE BGLOGID = :BGLOGID ";
- foreach (DataRow row in dtLogID.Rows)
- {
- // 歇2s,调太快会给接口累着。
- Thread.Sleep(2000);
- paras = new OracleParameter[]
- {
- new OracleParameter(":BGLOGID", OracleDbType.Int32, row["LOGID"], ParameterDirection.Input),
- };
- DataTable fpData = oracleConn.GetSqlResultToDt(sqlFpData, paras);
- if (fpData.Rows.Count > 0)
- {
- if ("1".Equals(fpData.Rows[0]["LOGTYPE"] + ""))
- {
- message = WMSDataLogic.PushWMS2(fpData, now);
- }
- else
- {
- message = WMSDataLogic.BackPushWMS2(fpData, now);
- }
- }
- paras = new OracleParameter[]
- {
- new OracleParameter(":RETURNDESC", OracleDbType.NVarchar2, message, ParameterDirection.Input),
- new OracleParameter(":UPDATETIME", OracleDbType.Date, now, ParameterDirection.Input),
- new OracleParameter(":BGLOGID", OracleDbType.Int32, row["LOGID"], ParameterDirection.Input),
- };
- r = oracleConn.ExecuteNonQuery(sqlUpdate, paras);
- }
- #endregion
- oracleConn.Commit();
- sre.Message = JObject.Parse(result)["ZMSG"].ToString();
- sre.Result = JObject.Parse(result)["ZTYPE"].ToString();
- return sre;
- }
- catch (Exception ex)
- {
- OutputLog.TraceLog(LogPriority.Error,
- "BGToSAP",
- "报工" + date.ToString("yyyy-MM-dd HH:mm:ss"),
- ex.ToString(),
- LocalPath.LogExePath + "SAP_HEGII\\Error_");
- throw ex;
- }
- finally
- {
- if (oracleConn != null && oracleConn.ConnState == ConnectionState.Open)
- {
- oracleConn.Disconnect();
- }
- }
- }
- #endregion
- #region 报工移库
- /// <summary>
- /// 报工移库_同步SAP数据(自动)
- /// </summary>
- /// <param name="date"></param>
- public static void BGYKToSAP(DateTime date, DateTime ndate)
- {
- IDBTransaction oracleConn = null;
- ServiceResultEntity sre = new ServiceResultEntity();
- int logid = 0;
- string message = string.Empty;
- string sqlString = string.Empty;
- try
- {
- #region 生成日志
- OracleParameter[] paras = new OracleParameter[]
- {
- new OracleParameter("in_dateend", OracleDbType.Date, ndate, ParameterDirection.Input),
- new OracleParameter("out_logid", OracleDbType.Int32, null, ParameterDirection.Output),
- new OracleParameter("out_msg", OracleDbType.NVarchar2, 500, null, ParameterDirection.Output)
- };
- oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- DataSet ds = oracleConn.ExecStoredProcedure("PRO_SAP_HEGII_WORKDATA_BGYK", paras);
- int.TryParse(paras[1].Value + "", out logid);
- message = paras[2].Value + "";
- oracleConn.Commit();
- #endregion
- #region 同步SAP
- oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- //2022年9月8日11:38:51 更改 by fy
- //sqlString = @"
- //SELECT WERKS,
- // MATNR,
- // ZJDNU,
- // ZSCS,
- // ZSCCJ,
- // ZSCMS,
- // CHARG,
- // MENGE,
- // ZMLID
- // FROM TSAP_HEGII_WORKDATA_BGYK
- // WHERE LOGID = :LOGID ";
- sqlString = @"SELECT
- A.WERKS,
- A.MATNR,
- A.ZJDNU,
- -- A.ZSCS,
- 'T' AS ZSCS,
- A.ZSCCJ,
- A.ZSCMS,
- A.CHARG,
- A.MENGE,
- A.ZMLID,
- to_char(B.EXECUTEDATEBEGIN, 'yyyymmddhh24miss') AS ZYWKS,
- to_char(B.EXECUTEDATEEND, 'yyyymmddhh24miss' ) AS ZYWJS,
- to_char(SYSDATE, 'yyyymmdd' ) AS ZBUDAT,
- to_char(SYSDATE, 'yyyymmddhh24miss' ) AS ZMONT,
- '' AS ZTYPE1,
- '' AS ZMSG1
- FROM
- TSAP_HEGII_WORKDATA_BGYK A
- INNER JOIN TSAP_HEGII_DATALOG_BGYK B ON B.LOGID = A.LOGID
- WHERE
- A.LOGID = :LOGID";
- paras = new OracleParameter[]
- {
- new OracleParameter(":LOGID", OracleDbType.Int32, logid, ParameterDirection.Input),
- };
- DataTable workData = oracleConn.GetSqlResultToDt(sqlString, paras);
- //获取报工SAP接口是否开启
- sqlString = "select SAP_INI_BG from TP_SYS_SAPCONFIG";
- string SAP_ING_NEW = oracleConn.GetSqlResultToStr(sqlString);
- if (workData != null && workData.Rows.Count > 0 && SAP_ING_NEW == "1")
- {
- string postString = "{\"IT_INPUT\":{\"item\":" + JsonHelper.ToJson(ModelConvertHelper<BGYKToSAP>.ConvertToModel(workData)) + "}}";
- INIUtility ini = INIUtility.Instance(INIUtility.IniFile.SAP_HEGII);
- string url034 = ini.ReadIniData("SAP_NEW_INFO", "Url034");
- //url034 = "http://hgs4podev.hegii.com:50200/RESTAdapter/DKMES/ZPPFM034";
- string result = PostData(url034, postString, "POST");
- string ztype = JObject.Parse(result)["ZTYPE"].ToString();
- string zmsg = JObject.Parse(result)["ZMSG"].ToString();
- sqlString = "update TSAP_HEGII_DATALOG_BGYK t set t.EndTime = sysdate, ZTYPE = :ZTYPE, ZMSG =:ZMSG where logid = :logid";
- paras = new OracleParameter[]
- {
- new OracleParameter(":logid", OracleDbType.Varchar2, logid, ParameterDirection.Input),
- new OracleParameter(":ZTYPE", OracleDbType.Varchar2, ztype, ParameterDirection.Input),
- new OracleParameter(":ZMSG", OracleDbType.Varchar2, zmsg, ParameterDirection.Input),
- };
- oracleConn.ExecuteNonQuery(sqlString, paras);
- oracleConn.Commit();
- }
- #endregion
- }
- catch (Exception ex)
- {
- OutputLog.TraceLog(LogPriority.Error,
- "BGYKToSAP",
- "报工移库" + date.ToString("yyyy-MM-dd HH:mm:ss"),
- ex.ToString(),
- LocalPath.LogExePath + "SAP_HEGII\\Error_");
- }
- finally
- {
- if (oracleConn != null)
- {
- oracleConn.Close();
- }
- }
- }
- public static void BGYKToSAP_TEST(DateTime date, DateTime ndate)
- {
- IDBTransaction oracleConn = null;
- ServiceResultEntity sre = new ServiceResultEntity();
- int logid = 0;
- string message = string.Empty;
- string sqlString = string.Empty;
- try
- {
- #region 同步SAP
- oracleConn = ClsDbFactory.CreateDBTransaction(DataBaseType.ORACLE, DataManager.ConnectionString);
- //2022年9月8日11:38:51 更改 by fy
- //sqlString = @"
- //SELECT WERKS,
- // MATNR,
- // ZJDNU,
- // ZSCS,
- // ZSCCJ,
- // ZSCMS,
- // CHARG,
- // MENGE,
- // ZMLID
- // FROM TSAP_HEGII_WORKDATA_BGYK
- // WHERE LOGID = :LOGID ";
- sqlString = @"SELECT '5000' WERKS,MATNR,to_char(ZJDNU) ZJDNU,'T' AS ZSCS,to_char(ZSCCJ) ZSCCJ,to_char(ZSCMS) ZSCMS,to_char(CHARG)CHARG,
- to_char(MENGE) MENGE,to_char(ZMLID) ZMLID,
- to_char(:V_DATEBEGIN, 'yyyymmddhh24miss') AS ZYWKS,
- to_char(:IN_DATEEND, 'yyyymmddhh24miss' ) AS ZYWJS,
- to_char(SYSDATE, 'yyyymmdd' ) AS ZBUDAT,
- to_char(SYSDATE, 'yyyymmddhh24miss' ) AS ZMONT FROM (
- SELECT
- T.MATNR,
- '30' AS ZJDNU,
- G.GOODS_LINE_CODE AS ZSCS,
- '2' AS ZSCCJ,
- T.ZSCMS,
- TO_CHAR( SYSDATE, 'yyyymm' ) AS CHARG,
- SUM( T.MENGE ) AS MENGE,
- '3' AS ZMLID
- FROM
- (-- 3-3线上施釉(3)到3#刮登(99)
- SELECT
- GDD.GOODSID,
- GDD.MATERIALCODE AS MATNR,
- DECODE( GDD.TESTMOULDFLAG, '1', 'Y', 'C' ) AS ZSCMS,
- COUNT( 1 ) AS MENGE
- FROM
- TP_PM_PRODUCTIONDATA PD1
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD ON GDD.GROUTINGDAILYDETAILID = PD1.GROUTINGDAILYDETAILID
- WHERE
- PD1.CREATETIME >= :V_DATEBEGIN
- AND PD1.CREATETIME < :IN_DATEEND
- AND PD1.PROCEDUREID = 99
- AND PD1.VALUEFLAG = '1'
- AND EXISTS ( SELECT 1 FROM TP_PM_PRODUCTIONDATA PD2 WHERE PD2.BARCODE = PD1.BARCODE AND PD2.PROCEDUREID = 3 )
- GROUP BY
- GDD.GOODSID,
- GDD.MATERIALCODE,
- GDD.TESTMOULDFLAG UNION ALL-- 3-3线上施釉(3)到3#刮登(99)撤销了的
- SELECT
- GDD.GOODSID,
- GDD.MATERIALCODE AS MATNR,
- DECODE( GDD.TESTMOULDFLAG, '1', 'Y', 'C' ) AS ZSCMS,
- - COUNT( 1 ) AS MENGE
- FROM
- TP_PM_PRODUCTIONDATA PD1
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD ON GDD.GROUTINGDAILYDETAILID = PD1.GROUTINGDAILYDETAILID
- WHERE
- PD1.BACKOUTTIME >= :V_DATEBEGIN
- AND PD1.BACKOUTTIME < :IN_DATEEND
- AND PD1.PROCEDUREID = 99
- AND PD1.VALUEFLAG = '0'
- AND EXISTS ( SELECT 1 FROM TP_PM_PRODUCTIONDATA PD2 WHERE PD2.BARCODE = PD1.BARCODE AND PD2.PROCEDUREID = 3 )
- GROUP BY
- GDD.GOODSID,
- GDD.MATERIALCODE,
- GDD.TESTMOULDFLAG
- ) T
- LEFT JOIN TP_MST_GOODS G ON G.GOODSID = T.GOODSID
- GROUP BY
- T.MATNR,
- T.ZSCMS,
- G.GOODS_LINE_CODE UNION ALL
- SELECT
- T.MATNR,
- '40' AS ZJDNU,
- G.GOODS_LINE_CODE AS ZSCS,
- '2' AS ZSCCJ,
- T.ZSCMS,
- TO_CHAR( SYSDATE, 'yyyymm' ) AS CHARG,
- SUM( T.MENGE ) AS MENGE,
- '3' AS ZMLID
- FROM
- (-- 3#卸窑(103)到7-1成检出窑交接(11)
- SELECT
- GDD.GOODSID,
- GDD.MATERIALCODE AS MATNR,
- DECODE( GDD.TESTMOULDFLAG, '1', 'Y', 'C' ) AS ZSCMS,
- COUNT( 1 ) AS MENGE
- FROM
- TP_PM_PRODUCTIONDATA PD1
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD ON GDD.GROUTINGDAILYDETAILID = PD1.GROUTINGDAILYDETAILID
- WHERE
- PD1.CREATETIME >= :V_DATEBEGIN
- AND PD1.CREATETIME < :IN_DATEEND
- AND PD1.PROCEDUREID = 11
- AND PD1.VALUEFLAG = '1'
- AND EXISTS ( SELECT 1 FROM TP_PM_PRODUCTIONDATA PD2 WHERE PD2.BARCODE = PD1.BARCODE AND PD2.PROCEDUREID = 103 )
- GROUP BY
- GDD.GOODSID,
- GDD.MATERIALCODE,
- GDD.TESTMOULDFLAG UNION ALL-- 3-3线上施釉(3)到3#刮登(99)撤销了的
- SELECT
- GDD.GOODSID,
- GDD.MATERIALCODE AS MATNR,
- DECODE( GDD.TESTMOULDFLAG, '1', 'Y', 'C' ) AS ZSCMS,
- - COUNT( 1 ) AS MENGE
- FROM
- TP_PM_PRODUCTIONDATA PD1
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD ON GDD.GROUTINGDAILYDETAILID = PD1.GROUTINGDAILYDETAILID
- WHERE
- PD1.BACKOUTTIME >= :V_DATEBEGIN
- AND PD1.BACKOUTTIME < :IN_DATEEND
- AND PD1.PROCEDUREID = 11
- AND PD1.VALUEFLAG = '0'
- AND EXISTS ( SELECT 1 FROM TP_PM_PRODUCTIONDATA PD2 WHERE PD2.BARCODE = PD1.BARCODE AND PD2.PROCEDUREID = 103 )
- GROUP BY
- GDD.GOODSID,
- GDD.MATERIALCODE,
- GDD.TESTMOULDFLAG
- ) T
- LEFT JOIN TP_MST_GOODS G ON G.GOODSID = T.GOODSID
- GROUP BY
- T.MATNR,
- T.ZSCMS,
- G.GOODS_LINE_CODE UNION ALL
- SELECT
- T.MATNR,
- '40' AS ZJDNU,
- G.GOODS_LINE_CODE AS ZSCS,
- '3' AS ZSCCJ,
- T.ZSCMS,
- TO_CHAR( SYSDATE, 'yyyymm' ) AS CHARG,
- SUM( T.MENGE ) AS MENGE,
- '2' AS ZMLID
- FROM
- (-- 6-1卸窑(10)到3#成检交接(104)
- SELECT
- GDD.GOODSID,
- GDD.MATERIALCODE AS MATNR,
- DECODE( GDD.TESTMOULDFLAG, '1', 'Y', 'C' ) AS ZSCMS,
- COUNT( 1 ) AS MENGE
- FROM
- TP_PM_PRODUCTIONDATA PD1
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD ON GDD.GROUTINGDAILYDETAILID = PD1.GROUTINGDAILYDETAILID
- WHERE
- PD1.CREATETIME >= :V_DATEBEGIN
- AND PD1.CREATETIME < :IN_DATEEND
- AND PD1.PROCEDUREID = 104
- AND PD1.VALUEFLAG = '1'
- AND EXISTS ( SELECT 1 FROM TP_PM_PRODUCTIONDATA PD2 WHERE PD2.BARCODE = PD1.BARCODE AND PD2.PROCEDUREID = 10 )
- GROUP BY
- GDD.GOODSID,
- GDD.MATERIALCODE,
- GDD.TESTMOULDFLAG UNION ALL-- 6-1卸窑(10)到3#成检交接(104)撤销了的
- SELECT
- GDD.GOODSID,
- GDD.MATERIALCODE AS MATNR,
- DECODE( GDD.TESTMOULDFLAG, '1', 'Y', 'C' ) AS ZSCMS,
- - COUNT( 1 ) AS MENGE
- FROM
- TP_PM_PRODUCTIONDATA PD1
- INNER JOIN TP_PM_GROUTINGDAILYDETAIL GDD ON GDD.GROUTINGDAILYDETAILID = PD1.GROUTINGDAILYDETAILID
- WHERE
- PD1.BACKOUTTIME >= :V_DATEBEGIN
- AND PD1.BACKOUTTIME < :IN_DATEEND
- AND PD1.PROCEDUREID = 104
- AND PD1.VALUEFLAG = '0'
- AND EXISTS ( SELECT 1 FROM TP_PM_PRODUCTIONDATA PD2 WHERE PD2.BARCODE = PD1.BARCODE AND PD2.PROCEDUREID = 10 )
- GROUP BY
- GDD.GOODSID,
- GDD.MATERIALCODE,
- GDD.TESTMOULDFLAG
- ) T
- LEFT JOIN TP_MST_GOODS G ON G.GOODSID = T.GOODSID
- GROUP BY
- T.MATNR,
- T.ZSCMS,
- G.GOODS_LINE_CODE
- ) WHERE MENGE > 0";
- OracleParameter[] paras = new OracleParameter[]
- {
- new OracleParameter(":V_DATEBEGIN",OracleDbType.Date, date, ParameterDirection.Input),
- new OracleParameter(":IN_DATEEND",OracleDbType.Date, ndate, ParameterDirection.Input),
- };
- DataTable workData = oracleConn.GetSqlResultToDt(sqlString, paras);
- //获取报工SAP接口是否开启
- sqlString = "select SAP_INI_BG from TP_SYS_SAPCONFIG";
- string SAP_ING_NEW = oracleConn.GetSqlResultToStr(sqlString);
- if (workData != null && workData.Rows.Count > 0 && SAP_ING_NEW == "0")
- {
- string postString = "{\"IT_INPUT\":{\"item\":" + JsonHelper.ToJson(ModelConvertHelper<BGYKToSAP>.ConvertToModel(workData)) + "}}";
- //INIUtility ini = INIUtility.Instance(INIUtility.IniFile.SAP_HEGII);
- //string url034 = ini.ReadIniData("SAP_NEW_INFO", "Url034");
- string url034 = "http://hgs4podev.hegii.com:50200/RESTAdapter/DKMES/ZPPFM034";
- string result = PostData(url034, postString, "POST");
- string ztype = JObject.Parse(result)["ZTYPE"].ToString();
- string zmsg = JObject.Parse(result)["ZMSG"].ToString();
- //sqlString = "update TSAP_HEGII_DATALOG_BGYK t set t.EndTime = sysdate, ZTYPE = :ZTYPE, ZMSG =:ZMSG where logid = :logid";
- //paras = new OracleParameter[]
- //{
- // new OracleParameter(":logid", OracleDbType.Varchar2, logid, ParameterDirection.Input),
- // new OracleParameter(":ZTYPE", OracleDbType.Varchar2, ztype, ParameterDirection.Input),
- // new OracleParameter(":ZMSG", OracleDbType.Varchar2, zmsg, ParameterDirection.Input),
- //};
- //oracleConn.ExecuteNonQuery(sqlString, paras);
- oracleConn.Commit();
- }
- #endregion
- }
- catch (Exception ex)
- {
- OutputLog.TraceLog(LogPriority.Error,
- "BGYKToSAP",
- "报工移库" + date.ToString("yyyy-MM-dd HH:mm:ss"),
- ex.ToString(),
- LocalPath.LogExePath + "SAP_HEGII\\Error_");
- }
- finally
- {
- if (oracleConn != null)
- {
- oracleConn.Close();
- }
- }
- }
- /// <summary>
- /// 查询同步日志
- /// </summary>
- /// <param name="cre"></param>
- /// <param name="userInfo"></param>
- /// <returns></returns>
- public static ServiceResultEntity GetDataLog_BGYK(ClientRequestEntity cre)
- {
- IDBConnection oracleConn = ClsDbFactory.CreateDBConnection(DataBaseType.ORACLE, DataManager.ConnectionString);
- ServiceResultEntity sre = new ServiceResultEntity();
- try
- {
- string sqlString = @"
- SELECT DL.LOGID,
- DL.BEGINTIME,
- DL.ENDTIME,
- DL.YYYYMMDD,
- DL.ZTYPE,
- DL.ZMSG,
- U.USERCODE SYNUSERCODE
- FROM TSAP_HEGII_DATALOG_BGYK DL
- LEFT JOIN TP_MST_USER U
- ON U.USERID = DL.CREATEUSERID
- WHERE DL.EXECUTEDATEBEGIN >= :DATEBEGIN
- AND DL.EXECUTEDATEEND <= :DATEEND ";
- OracleParameter[] oracleParameter = new OracleParameter[]
- {
- new OracleParameter(":DATEBEGIN",OracleDbType.Date, cre.Properties["datebegin"], ParameterDirection.Input),
- new OracleParameter(":DATEEND",OracleDbType.Date, cre.Properties["dateend"], ParameterDirection.Input),
- };
- sqlString += "ORDER BY dl.logid DESC\n";
- sre.Data = oracleConn.GetSqlResultToDs(sqlString, oracleParameter);
- return sre;
- }
- catch (Exception ex)
- {
- throw ex;
- }
- finally
- {
- if (oracleConn != null)
- {
- oracleConn.Close();
- }
- }
- }
- /// <summary>
- /// 查询同步明细
- /// </summary>
- /// <param name="logid"></param>
- /// <param name="userInfo"></param>
- /// <returns></returns>
- public static ServiceResultEntity GetWorkData_BGYK(ClientRequestEntity cre)
- {
- IDBConnection oracleConn = ClsDbFactory.CreateDBConnection(DataBaseType.ORACLE, DataManager.ConnectionString);
- ServiceResultEntity sre = new ServiceResultEntity();
- try
- {
- //add xiacm 2022-10-21
- int logid = Convert.ToInt32(cre.Request);
- string sqlString = @"
- SELECT WERKS,
- MATNR,
- ZJDNU,
- ZSCS,
- ZSCCJ,
- ZSCMS,
- CHARG,
- MENGE,
- ZMLID
- FROM TSAP_HEGII_WORKDATA_BGYK WD ";
- if (logid > 0)
- {
- sqlString += "WHERE WD.LOGID = :LOGID ";
- }
- else
- {
- sqlString += @" INNER JOIN TSAP_HEGII_DATALOG_BGYK DL
- ON WD.LOGID = DL.LOGID
- WHERE DL.EXECUTEDATEBEGIN >= :DATEBEGIN
- AND DL.EXECUTEDATEEND <= :DATEEND ";
- }
- OracleParameter[] oracleParameter = new OracleParameter[]
- {
- new OracleParameter(":LOGID",OracleDbType.Int32, logid, ParameterDirection.Input),
- new OracleParameter(":DATEBEGIN",OracleDbType.Date, cre.Properties["datebegin"], ParameterDirection.Input),
- new OracleParameter(":DATEEND",OracleDbType.Date, cre.Properties["dateend"], ParameterDirection.Input),
- };
- sre.Data = oracleConn.GetSqlResultToDs(sqlString, oracleParameter);
- return sre;
- }
- catch (Exception ex)
- {
- throw ex;
- }
- finally
- {
- if (oracleConn != null)
- {
- oracleConn.Close();
- }
- }
- }
- #endregion
- #region PostData 请求
- public static string PostData(string url, string data, string method)
- {
- //将单引号转义成双引号
- data = data.Replace("'", "\"");
- //创建Web访问对象
- HttpWebRequest myRequest = (HttpWebRequest)WebRequest.Create(url);
- //把用户传过来的数据转成“UTF-8”的字节流
- byte[] buf = System.Text.Encoding.GetEncoding("UTF-8").GetBytes(data);
- myRequest.Method = method;
- myRequest.ContentLength = buf.Length;
- myRequest.ContentType = "application/json;charset=UTF-8";
- //myRequest.MaximumAutomaticRedirections = 1;
- myRequest.AllowAutoRedirect = true;
- //UTF8标准转码加密
- INIUtility ini = INIUtility.Instance(INIUtility.IniFile.SAP_HEGII);
- // 配置文件
- string userName = ini.ReadIniData("SAP_NEW_INFO", "userName");
- // 测试
- //userName = "hgsapdk:Sapdk#240";
- // 正式
- //string userName = "PODKMES:Sapdk#800";
- string base64Header = Convert.ToBase64String(Encoding.UTF8.GetBytes(userName));
- myRequest.Headers.Add("Authorization", "Basic " + base64Header);
- //发送请求
- Stream stream = myRequest.GetRequestStream();
- stream.Write(buf, 0, buf.Length);
- stream.Close();
- //获取接口返回值
- //通过Web访问对象获取响应内容
- HttpWebResponse myResponse = (HttpWebResponse)myRequest.GetResponse();
- //通过响应内容流创建StreamReader对象,因为StreamReader更高级更快
- StreamReader reader = new StreamReader(myResponse.GetResponseStream(), Encoding.UTF8);
- //string returnXml = HttpUtility.UrlDecode(reader.ReadToEnd());//如果有编码问题就用这个方法
- string returnXml = reader.ReadToEnd();//利用StreamReader就可以从响应内容从头读到尾
- reader.Close();
- myResponse.Close();
- // 结果
- OutputLog.TraceLog(LogPriority.Information,
- "报工030", method, data,
- LocalPath.LogExePath + "SAP_HEGII\\Info_030");
- return returnXml;
- }
- #endregion
- #region 转换
- public class ModelConvertHelper<T> where T : new()
- {
- public static List<T> ConvertToModel(DataTable dt)
- {
- // 定义集合
- List<T> ts = new List<T>();
- // 获得此模型的类型
- Type type = typeof(T);
- string tempName = "";
- foreach (DataRow dr in dt.Rows)
- {
- T t = new T();
- // 获得此模型的公共属性
- PropertyInfo[] propertys = t.GetType().GetProperties();
- foreach (PropertyInfo pi in propertys)
- {
- tempName = pi.Name;
- // 检查DataTable是否包含此列
- if (dt.Columns.Contains(tempName))
- {
- // 判断此属性是否有Setter
- if (!pi.CanWrite) continue;
- object value = dr[tempName];
- if (value != DBNull.Value)
- pi.SetValue(t, value, null);
- }
- }
- ts.Add(t);
- }
- return ts;
- }
- }
- #endregion
- }
- }
|