spillage.go 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904
  1. package api
  2. import (
  3. "fmt"
  4. "io/ioutil"
  5. "log"
  6. "net/http"
  7. "strconv"
  8. "strings"
  9. "sync"
  10. "time"
  11. "../../pkg/app"
  12. "../../pkg/e"
  13. "../../pkg/logging"
  14. "../../pkg/setting"
  15. "../../routers/restful"
  16. "github.com/Anderson-Lu/gofasion/gofasion"
  17. "github.com/gin-gonic/gin"
  18. "github.com/xormplus/xorm"
  19. )
  20. type feedtemplet struct {
  21. Id int64 `xorm:"id"`
  22. Ccname string `xorm:"ccname"`
  23. Cname string `xorm:"tname"`
  24. }
  25. type tmrStruct struct {
  26. Id int64 `xorm:"id"`
  27. Tname string `xorm:"tname"`
  28. Maxstirfeed float64 `xorm:"maxstirfeed"`
  29. }
  30. type lpplanStruct struct {
  31. Id int64 `xorm:"id"`
  32. Tmrname string `xorm:"tmrname"`
  33. Tmrid int64 `xorm:"tmrid"`
  34. Sort int64 `xorm:"sort"`
  35. Sel int64 `xorm:"sel"`
  36. Times int64 `xorm:"times"`
  37. Ftname string `xorm:"ftname"`
  38. Ftid int64 `xorm:"ftid"`
  39. Maxweight float64 `xorm:"maxweight"`
  40. Sumweight float64 `xorm:"sumweight"`
  41. Sumcowcount int64 `xorm:"sumcowcount"`
  42. Pastureid string `xorm:"pastureid"`
  43. Display string `xorm:"display"`
  44. }
  45. type sysopt struct {
  46. Inforvalue int `xorm:"inforvalue"`
  47. }
  48. type lpplanQueryInfo struct {
  49. Pastureid int64 `xorm:"pastureid"`
  50. Lppid int64 `xorm:"id"`
  51. Maxweight float64 `xorm:"maxweight"`
  52. Lweight float64 `xorm:"lweight"`
  53. Lweighthis float64 `xorm:"lweighthis"`
  54. Barid int64 `xorm:"barid"`
  55. Barname string `xorm:"barname"`
  56. Sort int64 `xorm:"sort"`
  57. Tmrid int64 `xorm:"tmrid"`
  58. Tmrname string `xorm:"tmrname"`
  59. Cowcount int64 `xorm:"cowcount"`
  60. Ccountradio float64 `xorm:"ccountradio"`
  61. Background string `xorm:"background"`
  62. Times int64 `xorm:"times"`
  63. Ftid int64 `xorm:"ftid"`
  64. }
  65. type fpdetailQueryInfo struct {
  66. Fpdid int64 `xorm:"fpdid"`
  67. Ptsrate float64 `xorm:"ptsrate"`
  68. Ptsuse float64 `xorm:"ptsuse"`
  69. Ptuse float64 `xorm:"ptuse"`
  70. Weight float64 `xorm:"weight"`
  71. Barid int64 `xorm:"barid"`
  72. Barname string `xorm:"barname"`
  73. Cowcount int64 `xorm:"cowcount"`
  74. Ccountradio float64 `xorm:"ccountradio"`
  75. Fttypeid int64 `xorm:"fttypeid"`
  76. Times int64 `xorm:"times"`
  77. Ptid int64 `xorm:"ptid"`
  78. Background string `xorm:"background"`
  79. }
  80. type lpplandtl1 struct {
  81. Pastureid int64 `xorm:"pastureid"`
  82. Lppid int64 `xorm:"lppid"`
  83. Barid int64 `xorm:"barid"`
  84. Barname string `xorm:"barname"`
  85. Fpdid int64 `xorm:"fpdid"`
  86. Fttype int64 `xorm:"fttype"`
  87. Lweight float64 `xorm:"lweight"`
  88. Sort int64 `xorm:"sort"`
  89. Tmrid int64 `xorm:"tmrid"`
  90. Tmrname string `xorm:"tmrname"`
  91. Cowcount int64 `xorm:"cowcount"`
  92. Ccountradio float64 `xorm:"ccountradio"`
  93. Background string `xorm:"background"`
  94. Lweighthis float64 `xorm:"lweighthis"`
  95. }
  96. //撒料计划 自动生成
  97. func Autogeneration(c *gin.Context) {
  98. appG := app.Gin{C: c}
  99. dataByte, _ := ioutil.ReadAll(c.Request.Body)
  100. fsion := gofasion.NewFasion(string(dataByte))
  101. pastureid := fsion.Get("pastureid").ValueStr()
  102. typeIN := fsion.Get("type").ValueInt64()
  103. log.Println(time.Now())
  104. tx := restful.Engine.NewSession()
  105. // defer tx.Close()
  106. var times int
  107. var wg sync.WaitGroup
  108. var tmrlist *[]*tmrStruct
  109. var feedtempletlist *[]*feedtemplet
  110. var err error
  111. var lpplanlist *[]*lpplanList
  112. var fpdetailWeightList *[]*fpdetailWeight
  113. wg.Add(1)
  114. go func() {
  115. defer wg.Done()
  116. feedtempletlist, err = getfeedtemplet(pastureid, tx)
  117. if err != nil {
  118. appG.Response(http.StatusOK, e.ERROR, false)
  119. return
  120. }
  121. }()
  122. wg.Wait()
  123. wg.Add(1)
  124. go func() {
  125. defer wg.Done()
  126. tmrlist, err = gettmr(pastureid, tx)
  127. if err != nil {
  128. appG.Response(http.StatusOK, e.ERROR, false)
  129. return
  130. }
  131. }()
  132. wg.Wait()
  133. wg.Add(1)
  134. go func() {
  135. defer wg.Done()
  136. times, err = gettimes(pastureid, tx)
  137. if err != nil {
  138. appG.Response(http.StatusOK, e.ERROR, false)
  139. return
  140. }
  141. }()
  142. wg.Wait()
  143. wg.Add(1)
  144. go func() {
  145. defer wg.Done()
  146. lpplanlist, err = getLpplanlist(pastureid, tx)
  147. if err != nil {
  148. appG.Response(http.StatusOK, e.ERROR, false)
  149. return
  150. }
  151. }()
  152. wg.Wait()
  153. wg.Add(1)
  154. go func() {
  155. defer wg.Done()
  156. fpdetailWeightList, err = getFpdetail(pastureid, tx)
  157. if err != nil {
  158. appG.Response(http.StatusOK, e.ERROR, false)
  159. return
  160. }
  161. for _, fpd := range *fpdetailWeightList {
  162. for _, lpp := range *lpplanlist {
  163. if (lpp.Ftid == fpd.Ptid || lpp.Ftid == fpd.Ptsid) && lpp.Times == fpd.Times {
  164. fpd.Weight = fpd.Weight - (lpp.Maxweight - lpp.Lweight)
  165. }
  166. }
  167. }
  168. }()
  169. wg.Wait()
  170. // 避免车次数量为0造成死循环
  171. max := false
  172. for _, tmr := range *tmrlist {
  173. if tmr.Maxstirfeed > 0 {
  174. max = true
  175. break
  176. }
  177. }
  178. count, err := getLpplanCount(tx)
  179. if err != nil {
  180. appG.Response(http.StatusOK, e.ERROR, false)
  181. return
  182. }
  183. for i := 1; i <= times; i++ {
  184. for _, tem := range *feedtempletlist {
  185. for _, fpd := range *fpdetailWeightList {
  186. if tem.Id == fpd.Temid && i == int(fpd.Times) {
  187. var ftid int64
  188. if fpd.Ptid != 0 {
  189. ftid = fpd.Ptid
  190. } else {
  191. ftid = fpd.Ptsid
  192. }
  193. for fpd.Weight > 0 && max {
  194. for _, tmr := range *tmrlist {
  195. if tmr.Maxstirfeed > 0 {
  196. count++
  197. ids, err := setting.SnowIds.NextId()
  198. if err != nil {
  199. ids = time.Now().UnixNano()
  200. logging.Info("create SnowIds err", err)
  201. }
  202. display := tem.Cname
  203. if i == 1 {
  204. display += "第一班"
  205. } else if i == 2 {
  206. display += "第二班"
  207. } else if i == 3 {
  208. display += "第三班"
  209. } else if i == 4 {
  210. display += "第四班"
  211. }
  212. lpplan := &lpplanStruct{
  213. Id: ids,
  214. Tmrname: tmr.Tname,
  215. Tmrid: tmr.Id,
  216. Sort: count,
  217. Sel: 1,
  218. Times: int64(i),
  219. Ftname: tem.Cname,
  220. Ftid: ftid,
  221. Maxweight: tmr.Maxstirfeed,
  222. Sumweight: 0,
  223. Sumcowcount: 0,
  224. Pastureid: pastureid,
  225. Display: display,
  226. }
  227. err = addLpplan(lpplan, tx)
  228. if err != nil {
  229. appG.Response(http.StatusOK, e.ERROR, false)
  230. return
  231. }
  232. fpd.Weight = fpd.Weight - tmr.Maxstirfeed
  233. }
  234. if fpd.Weight < 0 {
  235. break
  236. }
  237. }
  238. }
  239. }
  240. }
  241. }
  242. }
  243. // wg.Wait()
  244. err = autogeneration(typeIN, pastureid, tx)
  245. if err != nil {
  246. appG.Response(http.StatusOK, e.ERROR, false)
  247. return
  248. }
  249. appG.Response(http.StatusOK, e.SUCCESS, true)
  250. }
  251. //查看配方模板
  252. func getfeedtemplet(pastureid string, tx *xorm.Session) (*[]*feedtemplet, error) {
  253. data := make([]*feedtemplet, 0)
  254. err := tx.Table("feedtemplet").Select("id,ccname,tname").Where("pastureid = ? ", pastureid).Find(&data)
  255. if err != nil {
  256. log.Println("getfeedtemplet-error", err)
  257. return nil, err
  258. }
  259. return &data, nil
  260. }
  261. //查看tmr设备
  262. func gettmr(pastureid string, tx *xorm.Session) (*[]*tmrStruct, error) {
  263. data := make([]*tmrStruct, 0)
  264. session := tx.Table("tmr")
  265. session.Select("TRIM(id) id,tname,maxstirfeed")
  266. session.Where("pastureid = ? ", pastureid)
  267. session.Where("enable = 1")
  268. session.In("tclassid", "1,2,3")
  269. err := session.Find(&data)
  270. if err != nil {
  271. log.Println("gettmr-error", err)
  272. return nil, err
  273. }
  274. return &data, nil
  275. }
  276. //判断计划种是否有该车次
  277. func getLpplanExist(tmrid, ftid int64, times int, pastureid string, tx *xorm.Session) (bool, error) {
  278. session := tx.Table("lpplan")
  279. session.Where("pastureid = ? ", pastureid)
  280. session.Where("times = ? ", times)
  281. session.Where("tmrid = ? ", tmrid)
  282. session.Where("ftid = ? ", ftid)
  283. exist, err := session.Exist()
  284. if err != nil {
  285. log.Println("getLpplanExist-error", err)
  286. return false, err
  287. }
  288. return exist, nil
  289. }
  290. type fpdetailWeight struct {
  291. Times int64 `xorm:"times"`
  292. Weight float64 `xorm:"weight"`
  293. Pastureid int64 `xorm:"pastureid"`
  294. Ptid int64 `xorm:"ptid"`
  295. Ptsid int64 `xorm:"ptsid"`
  296. Cowcount int64 `xorm:"cowcount"`
  297. Temid int64 `xorm:"Temid"`
  298. }
  299. //获取料数量
  300. func getFpdetail(pastureid string, tx *xorm.Session) (*[]*fpdetailWeight, error) {
  301. fpdetaillist := make([]*fpdetailWeight, 0)
  302. err := tx.SQL(` select t1.temid,t1.times,ifnull(t2.weight,0)+sum(t1.weight) as weight ,TRIM(t1.pastureid) pastureid,TRIM(t1.ptid) ptid,TRIM(t1.ptsid ) ptsid ,t1.cowcount from (SELECT fpd.id,ft.id as temid,fpd.times, ROUND((1-fpd.ptsrate)*fpd.weight,2)-fpd.ptuse weight,TRIM(fpd.pastureid) pastureid,TRIM(fpd.ptid) ptid,TRIM(fpd.ptsid ) ptsid ,fpd.cowcount FROM fpdetail fpd
  303. join feedp fp on fp.ftid = fpd.ptid and fp.pastureid = fpd.pastureid
  304. inner join feedtemplet ft on ft.id = fp.ftid and ft.pastureid = fpd.pastureid
  305. WHERE fpd.pastureid = ? AND fpd.ptuse<ROUND((1-fpd.ptsrate)*fpd.weight,2) and fpd.ptid > 0
  306. group by fpd.id,fpd.times) t1
  307. left join ( select t1.id,t1.temid as temid, t1.times,sum(t1.weight) weight,TRIM(t1.pastureid) pastureid,TRIM(t1.ptid) ptid,TRIM(t1.ptsid ) ptsid ,
  308. t1.cowcount from (SELECT fpd.id,ft.id as temid, fpd.times,ROUND(fpd.ptsrate*fpd.weight,2)-fpd.ptsuse weight,TRIM(fpd.pastureid) pastureid,TRIM(fpd.ptid) ptid,TRIM(fpd.ptsid ) ptsid ,
  309. cowcount FROM fpdetail fpd
  310. join feedp fp on fp.ptsfid = fpd.ptsid and fp.pastureid = fpd.pastureid
  311. inner join feedtemplet ft on ft.id = fp.ftid and ft.pastureid = fpd.pastureid
  312. WHERE fpd.pastureid = ? AND fpd.ptsuse< ROUND(fpd.ptsrate*fpd.weight,2) and fpd.ptsid > 0
  313. group by fpd.id,fpd.times) t1
  314. group by t1.temid,t1.times) t2 on t2.temid = t1.temid and t2.times = t1.times
  315. group by t1.temid,t1.times
  316. `, pastureid, pastureid).Find(&fpdetaillist)
  317. if err != nil {
  318. log.Println("getFpdetail-error", err)
  319. tx.Rollback()
  320. return nil, err
  321. }
  322. return &fpdetaillist, nil
  323. }
  324. type lpplanList struct {
  325. Tmrid int64 `xorm:"tmrid"`
  326. Times int64 `xorm:"times"`
  327. Ftid int64 `xorm:"ftid"`
  328. Maxweight float64 `xorm:"maxweight"`
  329. Lweight float64 `xorm:"lweight"`
  330. }
  331. func getLpplanlist(patsureid string, tx *xorm.Session) (*[]*lpplanList, error) {
  332. session := tx.SQL(` select t1.times,t1.tmrid,t1.ftid,t1.maxweight ,ifnull(t2.lweight,0)as lweight from lpplan t1
  333. left join ( select ifnull(sum(lweight),0) as lweight,lppid from lpplandtl1 where pastureid =? GROUP BY lppid) t2 on t1.id = t2.lppid
  334. where t1.pastureid = ? `, patsureid, patsureid)
  335. data := make([]*lpplanList, 0)
  336. err := session.Find(&data)
  337. if err != nil {
  338. log.Println("getLpplanlist-error", err)
  339. return nil, err
  340. }
  341. return &data, nil
  342. }
  343. // 添加车次计划
  344. func addLpplan(lpplan *lpplanStruct, tx *xorm.Session) error {
  345. _, err := tx.Table("lpplan").Insert(lpplan)
  346. if err != nil {
  347. log.Println("addLpplan-error", err)
  348. return err
  349. }
  350. return nil
  351. }
  352. //获取车次数量
  353. func getLpplanCount(tx *xorm.Session) (int64, error) {
  354. count, err := tx.Table("lpplan").Count()
  355. if err != nil {
  356. log.Println("getLpplanCount-error", err)
  357. return 0, err
  358. }
  359. return count, err
  360. }
  361. //获取班次信息
  362. func gettimes(pastureid string, tx *xorm.Session) (int, error) {
  363. session := tx.Table("sysopt")
  364. session.Where("pastureid = ? ", pastureid)
  365. session.Where("inforname = 'times' ")
  366. data := new(sysopt)
  367. _, err := session.Get(data)
  368. if err != nil {
  369. log.Println("gettimes-error", err)
  370. return 0, err
  371. }
  372. return data.Inforvalue, nil
  373. }
  374. type upfpdetail struct {
  375. insertlweight float64
  376. fttypeid int64
  377. fpdid int64
  378. }
  379. func autogeneration(typeIN int64, pastureid string, tx *xorm.Session) error {
  380. tx.Begin()
  381. if typeIN == 1 {
  382. _, err := tx.SQL(`DELETE FROM lpplandtl1 WHERE pastureid = ?`, pastureid).Execute()
  383. if err != nil {
  384. log.Println("autogeneration-error-1", err)
  385. tx.Rollback()
  386. return err
  387. }
  388. _, err = tx.SQL(`update fpdetail
  389. set ptuse = 0,ptsuse=0
  390. WHERE pastureid = ?`, pastureid).Execute()
  391. if err != nil {
  392. log.Println("autogeneration-error-2", err)
  393. tx.Rollback()
  394. return err
  395. }
  396. }
  397. lpplansession := tx.SQL(`select
  398. t1.sort,t1.tmrid,t1.tmrname,t1.ftid,
  399. t1.pastureid,t1.id ,t1.maxweight,ifnull(t2.lweight,0) as lweight,t1.times from lpplan t1
  400. left join ( select ifnull(sum(lweight),0) as lweight,lppid from lpplandtl1 where pastureid =? GROUP BY lppid) t2 on t1.id = t2.lppid
  401. where t1.pastureid = ? and t1.maxweight > ifnull(t2.lweight,0) `, pastureid, pastureid)
  402. lpplanlist := make([]*lpplanQueryInfo, 0)
  403. err := lpplansession.Find(&lpplanlist)
  404. if err != nil {
  405. log.Println("autogeneration-error-3", err)
  406. tx.Rollback()
  407. return err
  408. }
  409. fpdetaillist := make([]*fpdetailQueryInfo, 0)
  410. err = tx.SQL(`SELECT ft.tcolor background,fpd.ptid,ft.fttypeid,fpd.cowcount,fpd.ccountradio,fpd.id as fpdid,times,tratio,ROUND((1-fpd.ptsrate)*fpd.weight,2)-fpd.ptuse weight,TRIM(fpd.barid) barid,TRIM(fpd.pastureid) pastureid,TRIM(fpd.ptid) ptid,TRIM(fpd.ptsid ) ptsid ,
  411. (select bname from bar where pastureid =fpd.pastureid and id = fpd.barid ) barname,cowcount,ccountradio,0 isfill FROM fpdetail fpd
  412. join feedp fp on fp.ftid = fpd.ptid and fp.pastureid = fpd.pastureid
  413. inner join feedtemplet ft on ft.id = fp.ftid and ft.pastureid = fpd.pastureid
  414. WHERE fpd.pastureid = ? AND ptuse<ROUND((1-fpd.ptsrate)*fpd.weight,2)
  415. group by fpd.id , fpd.times `, pastureid).Find(&fpdetaillist)
  416. if err != nil {
  417. log.Println("autogeneration-error-4", err)
  418. tx.Rollback()
  419. return err
  420. }
  421. log.Println(time.Now(), "333333333333")
  422. var wg sync.WaitGroup
  423. for _, lpplan := range lpplanlist {
  424. lpplandtl1List := make([]*lpplandtl1, 0)
  425. upfpdetailList := make([]*upfpdetail, 0)
  426. for _, fpdetail := range fpdetaillist {
  427. if fpdetail.Ptid == lpplan.Ftid && fpdetail.Times == lpplan.Times {
  428. var weight float64
  429. weight = fpdetail.Weight
  430. if lpplan.Maxweight <= lpplan.Lweight || weight <= 0 {
  431. continue
  432. }
  433. var insertlweight float64
  434. if lpplan.Maxweight-lpplan.Lweight > weight {
  435. insertlweight = weight
  436. } else {
  437. insertlweight = lpplan.Maxweight - lpplan.Lweight
  438. }
  439. lpplan.Lweight += insertlweight
  440. lpplan.Lweighthis = insertlweight
  441. exist := false
  442. for _, up := range upfpdetailList {
  443. if up.fpdid == fpdetail.Fpdid {
  444. up.insertlweight += insertlweight
  445. exist = true
  446. break
  447. }
  448. }
  449. if !exist {
  450. upfpdetailList = append(upfpdetailList, &upfpdetail{
  451. fpdid: fpdetail.Fpdid,
  452. insertlweight: insertlweight,
  453. fttypeid: fpdetail.Fttypeid,
  454. })
  455. }
  456. fpdetail.Weight = fpdetail.Weight - insertlweight
  457. exist = false
  458. for _, lpplandtl1 := range lpplandtl1List {
  459. if lpplandtl1.Lppid == lpplan.Lppid && lpplan.Pastureid == lpplandtl1.Pastureid && lpplandtl1.Fttype == fpdetail.Fttypeid && lpplandtl1.Fpdid == fpdetail.Fpdid {
  460. lpplandtl1.Lweight += insertlweight
  461. lpplandtl1.Lweighthis = insertlweight
  462. exist = true
  463. break
  464. }
  465. }
  466. if !exist {
  467. lpplandtl1List = append(lpplandtl1List, &lpplandtl1{
  468. Pastureid: lpplan.Pastureid,
  469. Lppid: lpplan.Lppid,
  470. Barid: fpdetail.Barid,
  471. Barname: fpdetail.Barname,
  472. Fpdid: fpdetail.Fpdid,
  473. Fttype: fpdetail.Fttypeid,
  474. Lweight: insertlweight,
  475. Sort: lpplan.Sort,
  476. Tmrid: lpplan.Tmrid,
  477. Tmrname: lpplan.Tmrname,
  478. Cowcount: lpplan.Cowcount,
  479. Ccountradio: lpplan.Ccountradio,
  480. Background: fpdetail.Background,
  481. Lweighthis: insertlweight,
  482. })
  483. }
  484. }
  485. }
  486. for _, lpplpplandtl1 := range lpplandtl1List {
  487. wg.Add(1)
  488. go func(lpplpplandtl1 *lpplandtl1) {
  489. defer wg.Done()
  490. _, err = tx.SQL(`insert into lpplandtl1(pastureid,lppid,barid,barname,fpdid,fttype,lweight,sort,tmrid,tmrname,
  491. cowcount,ccountradio,background,lweighthis)
  492. value(?,?,?,?,?,?,?,?,?,?,?,?,?,?)
  493. ON DUPLICATE KEY UPDATE lweight = lweight + lweight, lweighthis=lweighthis`, lpplpplandtl1.Pastureid,
  494. lpplpplandtl1.Lppid,
  495. lpplpplandtl1.Barid,
  496. lpplpplandtl1.Barname,
  497. lpplpplandtl1.Fpdid,
  498. lpplpplandtl1.Fttype,
  499. lpplpplandtl1.Lweight,
  500. lpplpplandtl1.Sort,
  501. lpplpplandtl1.Tmrid,
  502. lpplpplandtl1.Tmrname,
  503. lpplpplandtl1.Cowcount,
  504. lpplpplandtl1.Ccountradio,
  505. lpplpplandtl1.Background,
  506. lpplpplandtl1.Lweighthis).Execute()
  507. if err != nil {
  508. log.Println("autogeneration-error-6", err)
  509. tx.Rollback()
  510. return
  511. }
  512. }(lpplpplandtl1)
  513. }
  514. wg.Wait()
  515. for _, up := range upfpdetailList {
  516. wg.Add(1)
  517. go func(up *upfpdetail) {
  518. defer wg.Done()
  519. _, err = tx.SQL(` UPDATE fpdetail SET ptuse=IF(?=1,IF(ptuse+? <0,0,ptuse+?),ptuse),ptsuse=IF(?=0,IF(ptsuse+?<0,0,ptsuse+?),ptsuse)
  520. WHERE pastureid=? AND id=? `, up.fttypeid, up.insertlweight, up.insertlweight, up.fttypeid, up.insertlweight, up.insertlweight, pastureid, up.fpdid).Execute()
  521. if err != nil {
  522. log.Println("autogeneration-error-5", err)
  523. tx.Rollback()
  524. return
  525. }
  526. }(up)
  527. }
  528. wg.Wait()
  529. }
  530. if typeIN == 1 {
  531. _, err = tx.SQL("update lpplan set sel = 1 where pastureid = ?", pastureid).Execute()
  532. if err != nil {
  533. log.Println("autogeneration-error-10", err)
  534. return err
  535. }
  536. }
  537. supplement := tx.Table("fpdetail").Alias("fpd")
  538. supplement.Select("ft.tcolor background,fpd.id as fpdid,fpd.barid,ft.id as temid, fpd.times,ROUND(fpd.ptsrate*fpd.weight,2)-fpd.ptsuse weight,TRIM(fpd.pastureid) pastureid,TRIM(fpd.ptid) ptid,TRIM(fpd.ptsid ) ptsid ,cowcount")
  539. supplement.Join("inner", []string{"feedp", "fp"}, "fp.ptsfid = fpd.ptsid").And("fp.pastureid = fpd.pastureid")
  540. supplement.Join("inner", []string{"feedtemplet", "ft"}, "ft.id = fp.ftid").And("ft.pastureid = fpd.pastureid")
  541. supplement.Where("fpd.pastureid = ?", pastureid).And("fpd.ptsuse< ROUND(fpd.ptsrate*fpd.weight,2)").And("fpd.ptsid > 0")
  542. supplement.GroupBy("fpd.id,fpd.times")
  543. supplementList := make([]*fpdetailQueryInfo, 0)
  544. err = supplement.Find(&supplementList)
  545. if err != nil {
  546. log.Println("autogeneration-error-11", err)
  547. return err
  548. }
  549. if len(supplementList) > 0 {
  550. for _, lpplan := range lpplanlist {
  551. if lpplan.Maxweight <= lpplan.Lweight {
  552. continue
  553. }
  554. lppids := []string{strconv.FormatInt(lpplan.Lppid, 10)}
  555. for _, lpp := range lpplanlist {
  556. if lpp.Ftid == lpplan.Ftid && lpp.Times == lpplan.Times {
  557. lppids = append(lppids, strconv.FormatInt(lpp.Lppid, 10))
  558. }
  559. }
  560. lpplandtl1List := make([]*lpplandtl1, 0)
  561. upfpdetailList := make([]*upfpdetail, 0)
  562. lpplandtllist := make([]*lpplandtl1, 0)
  563. err = tx.Table("lpplandtl1").Select("barid").Where(fmt.Sprintf("lppid in (%s)", strings.Join(lppids, ","))).And("").Find(&lpplandtllist)
  564. if err != nil {
  565. log.Println("autogeneration-error-11", err)
  566. return err
  567. }
  568. for _, fpdetail := range supplementList {
  569. if lpplan.Times != fpdetail.Times {
  570. continue
  571. }
  572. exist := false
  573. for _, bar := range lpplandtllist {
  574. if bar.Barid == fpdetail.Barid {
  575. exist = true
  576. break
  577. }
  578. }
  579. if !exist {
  580. continue
  581. }
  582. var weight float64
  583. weight = fpdetail.Weight
  584. if weight <= 0 {
  585. continue
  586. }
  587. var insertlweight float64
  588. if lpplan.Maxweight-lpplan.Lweight > weight {
  589. insertlweight = weight
  590. } else {
  591. insertlweight = lpplan.Maxweight - lpplan.Lweight
  592. }
  593. lpplan.Lweight += insertlweight
  594. lpplan.Lweighthis = insertlweight
  595. exist = false
  596. for _, up := range upfpdetailList {
  597. if up.fpdid == fpdetail.Fpdid {
  598. up.insertlweight += insertlweight
  599. exist = true
  600. break
  601. }
  602. }
  603. if !exist {
  604. upfpdetailList = append(upfpdetailList, &upfpdetail{
  605. fpdid: fpdetail.Fpdid,
  606. insertlweight: insertlweight,
  607. fttypeid: 0,
  608. })
  609. }
  610. fpdetail.Weight = fpdetail.Weight - insertlweight
  611. exist = false
  612. for _, lpplandtl1 := range lpplandtl1List {
  613. if lpplandtl1.Lppid == lpplan.Lppid && lpplan.Pastureid == lpplandtl1.Pastureid && lpplandtl1.Fttype == fpdetail.Fttypeid && lpplandtl1.Fpdid == fpdetail.Fpdid {
  614. lpplandtl1.Lweight += insertlweight
  615. lpplandtl1.Lweighthis = insertlweight
  616. exist = true
  617. break
  618. }
  619. }
  620. if !exist {
  621. lpplandtl1List = append(lpplandtl1List, &lpplandtl1{
  622. Pastureid: lpplan.Pastureid,
  623. Lppid: lpplan.Lppid,
  624. Barid: fpdetail.Barid,
  625. Barname: fpdetail.Barname,
  626. Fpdid: fpdetail.Fpdid,
  627. Fttype: 0,
  628. Lweight: insertlweight,
  629. Sort: lpplan.Sort,
  630. Tmrid: lpplan.Tmrid,
  631. Tmrname: lpplan.Tmrname,
  632. Cowcount: lpplan.Cowcount,
  633. Ccountradio: lpplan.Ccountradio,
  634. Background: fpdetail.Background,
  635. Lweighthis: insertlweight,
  636. })
  637. }
  638. }
  639. for _, lpplpplandtl1 := range lpplandtl1List {
  640. wg.Add(1)
  641. go func(lpplpplandtl1 *lpplandtl1) {
  642. defer wg.Done()
  643. _, err = tx.SQL(`insert into lpplandtl1(pastureid,lppid,barid,barname,fpdid,fttype,lweight,sort,tmrid,tmrname,
  644. cowcount,ccountradio,background,lweighthis)
  645. value(?,?,?,?,?,?,?,?,?,?,?,?,?,?)
  646. ON DUPLICATE KEY UPDATE lweight = lweight + lweight, lweighthis=lweighthis`, lpplpplandtl1.Pastureid,
  647. lpplpplandtl1.Lppid,
  648. lpplpplandtl1.Barid,
  649. lpplpplandtl1.Barname,
  650. lpplpplandtl1.Fpdid,
  651. lpplpplandtl1.Fttype,
  652. lpplpplandtl1.Lweight,
  653. lpplpplandtl1.Sort,
  654. lpplpplandtl1.Tmrid,
  655. lpplpplandtl1.Tmrname,
  656. lpplpplandtl1.Cowcount,
  657. lpplpplandtl1.Ccountradio,
  658. lpplpplandtl1.Background,
  659. lpplpplandtl1.Lweighthis).Execute()
  660. if err != nil {
  661. log.Println("autogeneration-error-6", err)
  662. tx.Rollback()
  663. return
  664. }
  665. }(lpplpplandtl1)
  666. }
  667. wg.Wait()
  668. for _, up := range upfpdetailList {
  669. wg.Add(1)
  670. go func(up *upfpdetail) {
  671. defer wg.Done()
  672. _, err = tx.SQL(` UPDATE fpdetail SET ptuse=IF(?=1,IF(ptuse+? <0,0,ptuse+?),ptuse),ptsuse=IF(?=0,IF(ptsuse+?<0,0,ptsuse+?),ptsuse)
  673. WHERE pastureid=? AND id=? `, up.fttypeid, up.insertlweight, up.insertlweight, up.fttypeid, up.insertlweight, up.insertlweight, pastureid, up.fpdid).Execute()
  674. if err != nil {
  675. log.Println("autogeneration-error-5", err)
  676. tx.Rollback()
  677. // return err
  678. return
  679. }
  680. }(up)
  681. }
  682. wg.Wait()
  683. }
  684. }
  685. err = tx.Commit()
  686. if err != nil {
  687. log.Println("autogeneration-error-11", err)
  688. return err
  689. }
  690. return nil
  691. }
  692. func GetSpillage(c *gin.Context) {
  693. appG := app.Gin{C: c}
  694. dataByte, _ := ioutil.ReadAll(c.Request.Body)
  695. fsion := gofasion.NewFasion(string(dataByte))
  696. parammaps := fsion.Get("parammaps")
  697. pastureid := parammaps.Get("pastureid").ValueInt64()
  698. times := parammaps.Get("times").ValueInt64()
  699. // refresh 0 全部 , 1 车次信息, 2 班次
  700. refresh := parammaps.Get("refresh").ValueInt64()
  701. tx := restful.Engine.NewSession()
  702. defer tx.Close()
  703. data := make(map[string]interface{})
  704. if refresh == 0 || refresh == 2 {
  705. ftList, err := tx.SQL(`SELECT trim(feedp.pastureid) pastureid,barname,trim(barid) barid,trim(ftid) arrid,1 as type,? as times,ft.tname ftname,ft.tcolor background,0 isfill FROM feedp
  706. inner join feedtemplet ft
  707. on ft.id = feedp.ftid and ft.pastureid=?
  708. WHERE feedp.pastureid = ?
  709. GROUP BY feedp.ftid
  710. UNION
  711. SELECT trim(feedp.pastureid) pastureid,barname,barid,trim(ptsfid) arrid,0 as type,? as times,ft.tname ptsfname ,ft.tcolor background,1 isfill FROM feedp
  712. inner join feedtemplet ft
  713. on ft.id = feedp.ptsfid and ft.pastureid=?
  714. WHERE feedp.pastureid = ? and (SELECT inforvalue FROM sysopt WHERE sysopt.pastureid=feedp.pastureid AND sysopt.inforname= 'isEnableSupplyFeed') = 1
  715. GROUP BY feedp.ptsfid`, times, pastureid, pastureid, times, pastureid, pastureid).Query().List()
  716. if err != nil {
  717. log.Println("GetSpillage-error-1: ", err)
  718. appG.Response(http.StatusOK, e.ERROR, nil)
  719. return
  720. }
  721. ftDetailList, err := tx.SQL(`SELECT TRIM(id) id,times,tratio,ROUND(ptsrate*weight,2)-ptsuse weight,TRIM(barid) barid,TRIM(pastureid) pastureid,TRIM(ptid) ptid,TRIM(ptsid ) ptsid ,
  722. (select bname from bar where pastureid =fpdetail.pastureid and id = fpdetail.barid ) barname,0 AS fttype,cowcount,ccountradio,1 isfill FROM fpdetail
  723. WHERE fpdetail.pastureid = ? AND times=? AND ptsuse< ROUND(ptsrate*weight,2)
  724. UNION
  725. SELECT TRIM(id) id,times,tratio,ROUND((1-ptsrate)*weight,2)-ptuse weight,TRIM(barid) barid,TRIM(pastureid) pastureid,TRIM(ptid) ptid,TRIM(ptsid ) ptsid ,
  726. (select bname from bar where pastureid =fpdetail.pastureid and id = fpdetail.barid ) barname,1 AS fttype,cowcount,ccountradio,0 isfill FROM fpdetail
  727. WHERE fpdetail.pastureid = ? AND times=? AND ptuse<ROUND((1-ptsrate)*weight,2)
  728. ORDER BY barid`, pastureid, times, pastureid, times).Query().List()
  729. if err != nil {
  730. log.Println("GetSpillage-error-2: ", err)
  731. appG.Response(http.StatusOK, e.ERROR, nil)
  732. return
  733. }
  734. for _, ft := range ftList {
  735. arrList := make([]map[string]interface{}, 0)
  736. arrid := ft["arrid"].(string)
  737. for _, detail := range ftDetailList {
  738. if _, ok := detail["ptid"]; ok {
  739. if arrid == detail["ptid"].(string) && ft["isfill"].(int64) == detail["isfill"].(int64) {
  740. detail["background"] = ft["background"]
  741. arrList = append(arrList, detail)
  742. }
  743. } else if _, ok := detail["ptsid"]; ok {
  744. if arrid == detail["ptsid"].(string) && ft["isfill"].(int64) == detail["isfill"].(int64) {
  745. detail["background"] = ft["background"]
  746. arrList = append(arrList, detail)
  747. }
  748. }
  749. }
  750. if len(arrList) > 0 {
  751. ft["arrList"] = arrList
  752. }
  753. }
  754. data["ftlist"] = ftList
  755. }
  756. if refresh == 0 || refresh == 1 {
  757. sqlstr := `SELECT
  758. ifnull((select eqcode from tmr where pastureid =lpplan.pastureid and id = lpplan.tmrid ),lpplan.tmrname) tmrname,trim(tmrid) tmrid,sort,sel,
  759. CASE times
  760. WHEN 1 THEN
  761. '第一班'
  762. WHEN 2 THEN
  763. '第二班'
  764. WHEN 3 THEN
  765. '第三班'
  766. WHEN 4 THEN
  767. '第四班'
  768. END timesstr,issplit,
  769. times,display,begintime,
  770. (select tname from feedtemplet where pastureid =lpplan.pastureid and id = lpplan.ftid ) ftname,sumcowcount,
  771. IFNULL(round((SELECT SUM(lpplandtl1.lweight) FROM lpplandtl1 WHERE lpplandtl1.lppid=lpplan.id),2),0) sumweight ,
  772. ifnull((select maxstirfeed from tmr where pastureid =lpplan.pastureid and id = lpplan.tmrid ),100000) maxweight,
  773. TRIM(ftid) ftid,
  774. TRIM(id) id,
  775. TRIM(id) lppid,
  776. TRIM(pastureid) pastureid
  777. FROM
  778. lpplan
  779. WHERE pastureid = ? and times <= (SELECT sysopt.inforvalue FROM sysopt
  780. WHERE sysopt.pastureid= lpplan.pastureid AND sysopt.inforname='times')
  781. ORDER BY times,lpplan.sort`
  782. session := tx.SQL(sqlstr, pastureid)
  783. lppList, err := session.Query().List()
  784. if err != nil {
  785. log.Println("GetSpillage-error-3: ", err)
  786. appG.Response(http.StatusOK, e.ERROR, nil)
  787. return
  788. }
  789. arrList, err := tx.SQL(`SELECT
  790. trim(lpplandtl1.lppid) lppid,lweight,
  791. lpplandtl1.lweight weight,lpplandtl1.sort,
  792. (select bname from bar where pastureid =lpplandtl1.pastureid and id = lpplandtl1.barid ) barname,
  793. TRIM(lpplandtl1.fpdid) fpdid,
  794. TRIM(lpplandtl1.barid) barid,
  795. TRIM(lpplandtl1.id) id,
  796. TRIM(lpplandtl1.pastureid) pastureid,
  797. (SELECT tcolor FROM feedtemplet WHERE pastureid =lpplandtl1.pastureid AND id = IF(lpplandtl1.fttype=1,fpdetail.ptid,fpdetail.ptsid) ) background,
  798. lpplandtl1.fttype,
  799. trim(lpplandtl1.tmrid) tmrid,
  800. ifnull((select eqcode from tmr where pastureid =lpplandtl1.pastureid and id = lpplandtl1.tmrid ),lpplandtl1.tmrname) tmrname,
  801. ifnull((select tcolor from tmr where pastureid =lpplandtl1.pastureid and id = lpplandtl1.tmrid ),'#ccc') tbackground,
  802. fpdetail.ptid,
  803. fpdetail.ptsid,
  804. fpdetail.times,
  805. fpdetail.cowcount,
  806. fpdetail.ccountradio
  807. FROM
  808. lpplandtl1
  809. inner join fpdetail
  810. on lpplandtl1.fpdid= fpdetail.id and lpplandtl1.pastureid = fpdetail.pastureid
  811. WHERE lpplandtl1.pastureid = ? and lpplandtl1.lweight>0
  812. ORDER BY lpplandtl1.sort`, pastureid).QueryString() //获取
  813. if err != nil {
  814. log.Println("GetSpillage-error-2: ", err)
  815. appG.Response(http.StatusOK, e.ERROR, nil)
  816. return
  817. }
  818. for _, query := range lppList {
  819. list := make([]map[string]string, 0)
  820. for _, arr := range arrList {
  821. if query["lppid"].(string) == arr["lppid"] {
  822. list = append(list, arr)
  823. }
  824. }
  825. query["arrList"] = list
  826. }
  827. data["list"] = lppList
  828. data["total"] = len(lppList)
  829. }
  830. appG.Response(http.StatusOK, e.SUCCESS, data)
  831. }