Mem_PurchaseHistoryController.cs 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.SqlClient;
  4. using System.Linq;
  5. using System.Threading.Tasks;
  6. using CoreEntity.Entity;
  7. using CoreEntity.ESEntity;
  8. using JCSoft.WX.Framework.Api;
  9. using Microsoft.AspNetCore.Mvc;
  10. using Microsoft.Extensions.Caching.Memory;
  11. using Newtonsoft.Json;
  12. using PublicLibrary.Model;
  13. using SupplierWeb.Commonss;
  14. namespace SupplierWeb.Controllers
  15. {
  16. [Route("web/Mem_PurchaseHistory")]
  17. public class mem_PurchaseHistoryController : BaseController
  18. {
  19. public mem_PurchaseHistoryController(IMemoryCache cache, IApiClient client) : base(cache, client)
  20. {
  21. }
  22. public IActionResult Index()
  23. {
  24. return View();
  25. }
  26. /// <summary>
  27. /// 订单列表
  28. /// </summary>
  29. /// <param name="data"></param>
  30. /// <param name="filters"></param>
  31. /// <returns></returns>
  32. [HttpPost]
  33. [Route("OrderList")]
  34. public ActionResult OrderList([FromBody]dynamic data, QueryFilter[] filters)
  35. {
  36. int start = 0;
  37. string filter = "";
  38. Object query = null;
  39. string MemberPhone = "";
  40. if (data != null)
  41. {
  42. filters = data.filters.ToObject<QueryFilter[]>();
  43. filter = QueryFilter.getFilterString(filters);
  44. MemberPhone = filters[0].value;
  45. if (data.pageIndex == 1)
  46. {
  47. start = 0;
  48. }
  49. else
  50. {
  51. start = ((data.pageIndex - 1) * data.pageSize) + 1;
  52. }
  53. query = new { query = "select * from mem_order where 1=1 "+
  54. filter+
  55. " order by CreationDate " +
  56. "limit " + data.pageSize
  57. };
  58. }
  59. //将参数转换成JSON数据
  60. var json = JsonConvert.SerializeObject(query);
  61. //通过传来的SQL语句,转换成DSL语句
  62. string sql = Util.ElasticQuery("_sql/translate?format=json", "POST", json);
  63. string from = "\"from\":" + start + ",";
  64. sql = sql.Insert(1, from);
  65. //通过转换的DSL语句,获取数据
  66. var str = Util.ElasticQuery("mem_order/_search?format=json", "POST", sql);
  67. //JSON转Root对象
  68. Root<Orders> stobj = EsCommon.FromJSON<Root<Orders>>(str);
  69. //总数
  70. List<Orders> _source = new List<Orders>();
  71. long totalcount = 0;
  72. if (stobj.hits.hits.Count > 0) {
  73. //给filed额外的属性赋值
  74. stobj.hits.hits.ForEach(x =>
  75. {
  76. x._source._id = x._id;
  77. //x._source.OriginType = x.fields.OriginType[0].ToString();
  78. //x._source.Sum = x.fields.Sum[0].ToString();
  79. //x.fields.Manufacturer = x._source.Manufacturer;
  80. x.fields.Sum[0] = x.fields.Sum[0] > 0 ?
  81. x.fields.Sum[0] / 100 : 0;
  82. });
  83. //将Root对象中的子对象取出来
  84. _source = stobj.hits.hits.Select(x => x.entity()).ToList();
  85. var countdata = new { query = "select count(1) from mem_order where 1=1 "+
  86. filter };
  87. var jsons = JsonConvert.SerializeObject(countdata);
  88. //ES获取SQL执行结果
  89. string obj = Util.ElasticQuery("_sql?format=json", "POST", jsons);
  90. Num num = EsCommon.FromJSON<Num>(obj);
  91. totalcount = num.rows[0][0];
  92. }
  93. var jsonData = JsonConvert.SerializeObject(_source);
  94. return Json(
  95. new
  96. {
  97. items = JsonConvert.DeserializeObject(jsonData),
  98. totalCount = totalcount
  99. });
  100. }
  101. ///// <summary>
  102. ///// JSON转对象
  103. ///// </summary>
  104. ///// <typeparam name="T"></typeparam>
  105. ///// <param name="input"></param>
  106. ///// <returns></returns>
  107. //public static T FromJSON<T>(string input)
  108. //{
  109. // try
  110. // {
  111. // return JsonConvert.DeserializeObject<T>(input);
  112. // }
  113. // catch (Exception ex)
  114. // {
  115. // string a = ex.Message;
  116. // return default(T);
  117. // }
  118. //}
  119. //#region
  120. //public class _shards
  121. //{
  122. // /// <summary>
  123. // ///
  124. // /// </summary>
  125. // public int total { get; set; }
  126. // /// <summary>
  127. // ///
  128. // /// </summary>
  129. // public int successful { get; set; }
  130. // /// <summary>
  131. // ///
  132. // /// </summary>
  133. // public int skipped { get; set; }
  134. // /// <summary>
  135. // ///
  136. // /// </summary>
  137. // public int failed { get; set; }
  138. //}
  139. //public class Total
  140. //{
  141. // /// <summary>
  142. // ///
  143. // /// </summary>
  144. // public int value { get; set; }
  145. // /// <summary>
  146. // ///
  147. // /// </summary>
  148. // public string relation { get; set; }
  149. //}
  150. //public class _source
  151. //{
  152. // /// <summary>
  153. // ///
  154. // /// </summary>
  155. // public string Sum { get; set; }
  156. // /// <summary>
  157. // ///
  158. // /// </summary>
  159. // public string OriginType { get; set; }
  160. // /// <summary>
  161. // ///
  162. // /// </summary>
  163. // public string _id { get; set; }
  164. // /// <summary>
  165. // ///
  166. // /// </summary>
  167. // public string OrderTime { get; set; }
  168. // /// <summary>
  169. // ///
  170. // /// </summary>
  171. // public string InventoryAuditDate { get; set; }
  172. // /// <summary>
  173. // ///
  174. // /// </summary>
  175. // public string CreationDate { get; set; }
  176. // /// <summary>
  177. // ///
  178. // /// </summary>
  179. // public string AccountId { get; set; }
  180. // /// <summary>
  181. // ///
  182. // /// </summary>
  183. // public string Invoice { get; set; }
  184. // /// <summary>
  185. // ///
  186. // /// </summary>
  187. // public string VerificationCode { get; set; }
  188. // /// <summary>
  189. // ///
  190. // /// </summary>
  191. // public string RegionCode { get; set; }
  192. // /// <summary>
  193. // ///
  194. // /// </summary>
  195. // public string OrderNotes { get; set; }
  196. // /// <summary>
  197. // ///
  198. // /// </summary>
  199. // public string Sex { get; set; }
  200. // /// <summary>
  201. // ///
  202. // /// </summary>
  203. // public string CustomerDataId { get; set; }
  204. // /// <summary>
  205. // ///
  206. // /// </summary>
  207. // public string IsToERP { get; set; }
  208. // /// <summary>
  209. // ///
  210. // /// </summary>
  211. // public string SubProductLine { get; set; }
  212. // /// <summary>
  213. // /// 吉林省吉林市磐石市河南街牛心综合楼一单元601室
  214. // /// </summary>
  215. // public string ADeliveryAddress { get; set; }
  216. // /// <summary>
  217. // ///
  218. // /// </summary>
  219. // public string LastModified { get; set; }
  220. // /// <summary>
  221. // ///
  222. // /// </summary>
  223. // public string MemPhone { get; set; }
  224. // /// <summary>
  225. // /// 赵海霞
  226. // /// </summary>
  227. // public string Consignee { get; set; }
  228. // /// <summary>
  229. // ///
  230. // /// </summary>
  231. // public string ReceiverPhone { get; set; }
  232. // /// <summary>
  233. // ///
  234. // /// </summary>
  235. // public string LeverNumber { get; set; }
  236. // /// <summary>
  237. // ///
  238. // /// </summary>
  239. // public string AConsigneePhone1 { get; set; }
  240. // /// <summary>
  241. // ///
  242. // /// </summary>
  243. // public string DeliveryZipCode { get; set; }
  244. // /// <summary>
  245. // ///
  246. // /// </summary>
  247. // public string Height { get; set; }
  248. // /// <summary>
  249. // ///
  250. // /// </summary>
  251. // public string AConsigneePhone2 { get; set; }
  252. // /// <summary>
  253. // ///
  254. // /// </summary>
  255. // public string CustomerName { get; set; }
  256. // /// <summary>
  257. // ///
  258. // /// </summary>
  259. // public string ProductLine { get; set; }
  260. // /// <summary>
  261. // ///
  262. // /// </summary>
  263. // public string BusinessId { get; set; }
  264. // /// <summary>
  265. // ///
  266. // /// </summary>
  267. // public string InvoiceContent { get; set; }
  268. // /// <summary>
  269. // ///
  270. // /// </summary>
  271. // public string ConfirmId { get; set; }
  272. // /// <summary>
  273. // ///
  274. // /// </summary>
  275. // public string CashCouponCode { get; set; }
  276. // /// <summary>
  277. // ///
  278. // /// </summary>
  279. // public string ShippingNo { get; set; }
  280. // /// <summary>
  281. // ///
  282. // /// </summary>
  283. // public string DiseaseClassCode { get; set; }
  284. // /// <summary>
  285. // ///
  286. // /// </summary>
  287. // public string AuditorId { get; set; }
  288. // /// <summary>
  289. // ///
  290. // /// </summary>
  291. // public string ReceivingTime { get; set; }
  292. // /// <summary>
  293. // ///
  294. // /// </summary>
  295. // public string CustomerCode { get; set; }
  296. // /// <summary>
  297. // ///
  298. // /// </summary>
  299. // public string SyncStatus { get; set; }
  300. // /// <summary>
  301. // ///
  302. // /// </summary>
  303. // public string InvoiceNo { get; set; }
  304. // /// <summary>
  305. // ///
  306. // /// </summary>
  307. // public string DeptId { get; set; }
  308. // /// <summary>
  309. // ///
  310. // /// </summary>
  311. // public string Weight { get; set; }
  312. // /// <summary>
  313. // ///
  314. // /// </summary>
  315. // public string ShippingTime { get; set; }
  316. // /// <summary>
  317. // ///
  318. // /// </summary>
  319. // public string AllocationTime { get; set; }
  320. // /// <summary>
  321. // ///
  322. // /// </summary>
  323. // public string OtherNote { get; set; }
  324. // /// <summary>
  325. // ///
  326. // /// </summary>
  327. // public string OrderProcessDate { get; set; }
  328. // /// <summary>
  329. // ///
  330. // /// </summary>
  331. // public string MerchantNote { get; set; }
  332. // /// <summary>
  333. // ///
  334. // /// </summary>
  335. // public string OperateID { get; set; }
  336. // /// <summary>
  337. // ///
  338. // /// </summary>
  339. // public string DeptCode { get; set; }
  340. // /// <summary>
  341. // ///
  342. // /// </summary>
  343. // public string OrdersCode { get; set; }
  344. // /// <summary>
  345. // ///
  346. // /// </summary>
  347. // public string BuyUserId { get; set; }
  348. // /// <summary>
  349. // ///
  350. // /// </summary>
  351. // public string AccountName { get; set; }
  352. //}
  353. //public class Fields
  354. //{
  355. // /// <summary>
  356. // ///
  357. // /// </summary>
  358. // public List<string> IsPayByCard { get; set; }
  359. // /// <summary>
  360. // ///
  361. // /// </summary>
  362. // public List<int> IntegralValue { get; set; }
  363. // /// <summary>
  364. // ///
  365. // /// </summary>
  366. // public List<string> IsDrug { get; set; }
  367. // /// <summary>
  368. // ///
  369. // /// </summary>
  370. // public List<int> HealthPrice { get; set; }
  371. // /// <summary>
  372. // ///
  373. // /// </summary>
  374. // public List<int> WarehouseCode { get; set; }
  375. // /// <summary>
  376. // ///
  377. // /// </summary>
  378. // public List<string> IsNeedReceipt { get; set; }
  379. // /// <summary>
  380. // ///
  381. // /// </summary>
  382. // public List<string> AllocationFlag { get; set; }
  383. // /// <summary>
  384. // ///
  385. // /// </summary>
  386. // public List<int> TransportCosts { get; set; }
  387. // /// <summary>
  388. // ///
  389. // /// </summary>
  390. // public List<string> BonusDate { get; set; }
  391. // /// <summary>
  392. // ///
  393. // /// </summary>
  394. // public List<int> DeliveryType { get; set; }
  395. // /// <summary>
  396. // ///
  397. // /// </summary>
  398. // public List<int> InitSum { get; set; }
  399. // /// <summary>
  400. // ///
  401. // /// </summary>
  402. // public List<int> OriginType { get; set; }
  403. // /// <summary>
  404. // ///
  405. // /// </summary>
  406. // public List<int> CouponValue { get; set; }
  407. // /// <summary>
  408. // ///
  409. // /// </summary>
  410. // public List<int> Discountprice { get; set; }
  411. // /// <summary>
  412. // ///
  413. // /// </summary>
  414. // public List<string> IsEmailmark { get; set; }
  415. // /// <summary>
  416. // ///
  417. // /// </summary>
  418. // public List<int> Sum { get; set; }
  419. // /// <summary>
  420. // ///
  421. // /// </summary>
  422. // public List<int> OrdersType { get; set; }
  423. // /// <summary>
  424. // ///
  425. // /// </summary>
  426. // public List<int> DeviceType { get; set; }
  427. // /// <summary>
  428. // ///
  429. // /// </summary>
  430. // public List<int> AdvanceSum { get; set; }
  431. // /// <summary>
  432. // ///
  433. // /// </summary>
  434. // public List<int> InvoiceSum { get; set; }
  435. // /// <summary>
  436. // ///
  437. // /// </summary>
  438. // public List<string> IsRxDrug { get; set; }
  439. // /// <summary>
  440. // ///
  441. // /// </summary>
  442. // public List<string> Ispayment { get; set; }
  443. // /// <summary>
  444. // ///
  445. // /// </summary>
  446. // public List<int> ProductCost { get; set; }
  447. // /// <summary>
  448. // ///
  449. // /// </summary>
  450. // public List<string> IsNewOrder { get; set; }
  451. // /// <summary>
  452. // ///
  453. // /// </summary>
  454. // public List<string> IsDealWith { get; set; }
  455. // /// <summary>
  456. // ///
  457. // /// </summary>
  458. // public List<int> ErrorCount { get; set; }
  459. // /// <summary>
  460. // ///
  461. // /// </summary>
  462. // public List<int> MemKey { get; set; }
  463. // /// <summary>
  464. // ///
  465. // /// </summary>
  466. // public List<string> IsReturn { get; set; }
  467. // /// <summary>
  468. // ///
  469. // /// </summary>
  470. // public List<string> IsReward { get; set; }
  471. // /// <summary>
  472. // ///
  473. // /// </summary>
  474. // public List<int> HuaWuOriginType { get; set; }
  475. // /// <summary>
  476. // ///
  477. // /// </summary>
  478. // public List<int> OrderStatus { get; set; }
  479. // /// <summary>
  480. // ///
  481. // /// </summary>
  482. // public List<int> AgainOrderCount { get; set; }
  483. // /// <summary>
  484. // ///
  485. // /// </summary>
  486. // public List<string> IsO2O { get; set; }
  487. // /// <summary>
  488. // ///
  489. // /// </summary>
  490. // public List<string> IsAutomaticSigned { get; set; }
  491. // /// <summary>
  492. // ///
  493. // /// </summary>
  494. // public List<int> PaymentType { get; set; }
  495. // /// <summary>
  496. // ///
  497. // /// </summary>
  498. // public List<string> PreferentialRate { get; set; }
  499. // /// <summary>
  500. // ///
  501. // /// </summary>
  502. // public List<string> Age { get; set; }
  503. // /// <summary>
  504. // ///
  505. // /// </summary>
  506. // public List<int> InvoiceContentType { get; set; }
  507. // /// <summary>
  508. // ///
  509. // /// </summary>
  510. // public List<int> OrdersIntegral { get; set; }
  511. // /// <summary>
  512. // ///
  513. // /// </summary>
  514. // public List<int> ConfimLevel { get; set; }
  515. // /// <summary>
  516. // ///
  517. // /// </summary>
  518. // public List<int> ConsigneeType { get; set; }
  519. // /// <summary>
  520. // ///
  521. // /// </summary>
  522. // public List<int> AdvancePayType { get; set; }
  523. // /// <summary>
  524. // ///
  525. // /// </summary>
  526. // public List<int> CouponCode { get; set; }
  527. // /// <summary>
  528. // ///
  529. // /// </summary>
  530. // public List<int> CashCouponValue { get; set; }
  531. // /// <summary>
  532. // ///
  533. // /// </summary>
  534. // public List<int> Reducing { get; set; }
  535. // /// <summary>
  536. // ///
  537. // /// </summary>
  538. // public List<string> IsVisible { get; set; }
  539. // /// <summary>
  540. // ///
  541. // /// </summary>
  542. // public List<int> SourcePlatforms { get; set; }
  543. //}
  544. //public class HitsItem
  545. //{
  546. // /// <summary>
  547. // ///
  548. // /// </summary>
  549. // public string _index { get; set; }
  550. // /// <summary>
  551. // ///
  552. // /// </summary>
  553. // public string _type { get; set; }
  554. // /// <summary>
  555. // ///
  556. // /// </summary>
  557. // public string _id { get; set; }
  558. // /// <summary>
  559. // ///
  560. // /// </summary>
  561. // public string _score { get; set; }
  562. // /// <summary>
  563. // ///
  564. // /// </summary>
  565. // public string _routing { get; set; }
  566. // /// <summary>
  567. // ///
  568. // /// </summary>
  569. // public _source _source { get; set; }
  570. // /// <summary>
  571. // ///
  572. // /// </summary>
  573. // public Fields fields { get; set; }
  574. // /// <summary>
  575. // ///
  576. // /// </summary>
  577. // public List<int> sort { get; set; }
  578. //}
  579. //public class Hits
  580. //{
  581. // /// <summary>
  582. // ///
  583. // /// </summary>
  584. // public Total total { get; set; }
  585. // /// <summary>
  586. // ///
  587. // /// </summary>
  588. // public string max_score { get; set; }
  589. // /// <summary>
  590. // ///
  591. // /// </summary>
  592. // public List<HitsItem> hits { get; set; }
  593. //}
  594. //public class Root
  595. //{
  596. // /// <summary>
  597. // ///
  598. // /// </summary>
  599. // public int took { get; set; }
  600. // /// <summary>
  601. // ///
  602. // /// </summary>
  603. // public string timed_out { get; set; }
  604. // /// <summary>
  605. // ///
  606. // /// </summary>
  607. // public _shards _shards { get; set; }
  608. // /// <summary>
  609. // ///
  610. // /// </summary>
  611. // public Hits hits { get; set; }
  612. //}
  613. //#endregion
  614. //#region 总数实体类
  615. //public class ColumnsItem
  616. //{
  617. // /// <summary>
  618. // ///
  619. // /// </summary>
  620. // public string name { get; set; }
  621. // /// <summary>
  622. // ///
  623. // /// </summary>
  624. // public string type { get; set; }
  625. //}
  626. //public class Num
  627. //{
  628. // /// <summary>
  629. // ///
  630. // /// </summary>
  631. // public List<ColumnsItem> columns { get; set; }
  632. // /// <summary>
  633. // ///
  634. // /// </summary>
  635. // public List<List<int>> rows { get; set; }
  636. //}
  637. //#endregion
  638. }
  639. }