日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

java - 復雜的字段條件判斷解析

瀏覽:235日期:2024-01-13 11:54:15

問題描述

應用場景簡化描述

現在有個用戶Person,包含int age, BigDecimal money,java.util.Date accessTime等字段,對應于用戶表person:

年齡(age : int)資產 (money : number)入網日期 (accessTime : date)20100.002017-03-2420150.002016-05-0721300.002015-04-0321240.002015-07-1522300.002014-12-2121300.002014-12-21

另外,有一張條件表,condition:

字段名(fieldName : varchar)運算符(oper : varchar)閾值 (threshold : varchar )age=21money>280.05accessTime>2015-05-31

條件表condition用來配置過濾用戶person的條件,表示要過濾出

年齡等于21歲

資產大于280.05

入網日期在 2015-06-01之后

的所有用戶。

其中,oper可取的值有 = , < , > , >= , <= , in , between

如果oper為in或between, 則閾值為多個,用逗號隔開。

問題

現在,對于不同的字段,在條件表condition里都是varchar類型,而在person表中,卻有不同的類型。

而且,條件表里的條件是從web系統頁面上,由用戶配置的;也就是說,條件的個數不確定,配置的字段,運算符,閾值也都是不確定的。

問: 如何才能使用java代碼,先將所有用戶以及條件查出來,然后遍歷每個用戶,對于每個用戶,遍歷每個條件,怎樣才能正確的判斷該用戶通過所有的條件檢查,得出通過條件篩選的用戶列表?(上邊的場景是實際場景簡化后的,請不要給出拼接sql,通過sql過濾的答案)

是不是可以把person的記錄生成xml文件,條件生成xsd文件,用xsd去校驗xml ??

問題解答

回答1:

如果不用sql的話,可以考慮使用責任鏈模式,將所有數據獲取出來放到linkedlist里面,然后寫個過濾器來過濾集合里面的內容,每一個條件可以相當于一個過濾器

回答2:

你用戶表有多大,還全部查出來。

正規做法都是拼sql查吧。。。

更高級的做法應該是自定義領域特定語言,然后轉sql吧,反正不可能是用xml過濾。

回答3:

感覺你這個condition表沒什么用???僅僅是存儲數據?如果臨時的直接用json傳過來就好了,如果你要持久存儲的話,起碼要個admin_id什么的,來標記下是誰的篩選條件。感覺效率不如直接扔到redis好點。

看你用的是Java,不過我習慣用PHP,就用PHP簡單描述下我的思路吧...

寫一個Filter類處理condition轉換為sql。

class Filter { public function doFilter() {//1. 獲取登錄的admin_id//2. 獲取篩選條件/** * 數據格式例子為: [ * ’field’ => ’age’;, * ’type’ => ’compare’, * ’ext’ => ’>’, * ’value’ => ’2’ * ] */foreach($conditions as $condition) { // 根據type獲取對應的$conditionHandle $conditionHandle::parse($condition);} }}// Condition接口interface Condition { // 解析數據,返回sql片段和需要填充的數據(此處使用PDO預處理,減少SQL注入) static function parse($data);}// ConditionHandlenamespace Condition;class Compare implements Condition { // 執行流程 public static function parse($data) {...return [ ’sql’ => ’age > ?’, ’params’ => [ 2 ]]; }}

手寫的,語法錯誤請忽略...

標簽: java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
视频一区视频二区中文| 99久久久国产精品美女| 影音国产精品| 午夜欧美精品久久久久久久| 一区在线免费| 久久亚洲美女| 男人操女人的视频在线观看欧美 | 免费中文字幕日韩欧美| 在线亚洲精品| 一区二区91| 日韩国产欧美视频| 欧美日一区二区三区在线观看国产免| 91麻豆精品| 国产精品传媒麻豆hd| 久久精品国产精品亚洲毛片| 国产成人黄色| 久久影视一区| 美女久久一区| 欧美中文一区| 国产999精品在线观看| 欧美成人一二区| 国产一区二区三区四区五区 | 国产免费av国片精品草莓男男 | 亚洲香蕉久久| 蜜桃视频免费观看一区| 免费人成精品欧美精品| 亚洲精品第一| 国产精品一页| 欧美aa在线观看| 亚洲成a人片| 国产亚洲永久域名| 日韩国产在线观看| 美女毛片一区二区三区四区最新中文字幕亚洲| 国产精品www994| 色婷婷色综合| 日韩网站在线| 青青草91视频| 福利精品一区| 亚洲综合不卡| 欧美成人一二区| 美女毛片一区二区三区四区| 四虎成人精品一区二区免费网站| 美女性感视频久久| 亚洲v在线看| 亚洲毛片视频| 久久久免费人体| 久久国产日本精品| 亚洲人成在线影院| 国产一区2区| 免播放器亚洲| 欧美极品中文字幕| 红桃视频国产一区| 国产精品多人| 日韩一级精品| 国产一区二区三区网| 99国产精品久久久久久久成人热| 国产人成精品一区二区三| 亚洲黄色免费av| 蜜臀精品一区二区三区在线观看 | 精品高清久久| 中文字幕中文字幕精品| 国产suv精品一区| 免费人成黄页网站在线一区二区| 国产精品扒开腿做爽爽爽软件| 99精品在线| 国产欧美日韩在线观看视频| 久久久久久免费视频| 欧美日本久久| 久久久久午夜电影| 国产精品一区二区三区av麻| 欧美日韩国产传媒| 欧美黄页在线免费观看| 久久都是精品| 亚洲免费福利| 国产精品视频一区视频二区| 亚洲一区二区免费看| 国产精品精品| 国产日韩欧美中文在线| 中文字幕乱码亚洲无线精品一区| 黄色精品视频| 米奇777超碰欧美日韩亚洲| 欧美亚洲国产日韩| 欧美日韩国产免费观看| 国产乱码精品一区二区三区四区 | 日韩精品dvd| 欧美日韩亚洲一区| 国产精品普通话对白| 正在播放日韩精品| 88久久精品| 丝袜美腿亚洲一区二区图片| 国产一区二区三区天码| 欧美日韩国产一区二区在线观看| 亚洲综合电影一区二区三区| 久久久久免费av| 国产不卡精品在线| 国产精品theporn| 日韩欧美三区| 视频一区二区三区中文字幕| 亚洲福利一区| 亚洲永久av| 精品视频在线观看网站| 91精品国产经典在线观看| 蜜桃视频第一区免费观看| 好吊日精品视频| 另类中文字幕国产精品| 国产精品日韩精品在线播放| 国产精品白丝久久av网站| 三级亚洲高清视频| 久久久久国产一区二区| 精品久久久中文字幕| 国产无遮挡裸体免费久久| 午夜亚洲福利| 亚洲色图综合| 只有精品亚洲| 老鸭窝亚洲一区二区三区| 亚洲国产不卡| 亚洲激情另类| 亚洲欧美日韩综合国产aⅴ| 伊人久久亚洲影院| 伊人久久成人| 午夜影院欧美| 激情久久中文字幕| 久久在线免费| 午夜国产精品视频| 免费久久99精品国产自在现线| 99xxxx成人网| 丝瓜av网站精品一区二区| 天堂成人国产精品一区| 中文字幕成人| 日本免费在线视频不卡一不卡二| 日韩一区二区三区高清在线观看| 亚洲日本免费电影| 日韩高清成人在线| 欧美啪啪一区| 久久女人天堂| 狠狠久久伊人中文字幕| 97精品视频在线看| 日韩高清成人| 九九久久电影| bbw在线视频| 久久精品国产www456c0m| 国产亚洲毛片| 亚洲一区二区日韩| 日韩**一区毛片| 欧美日韩一区二区三区四区在线观看| 国产精品一区二区av日韩在线| 美女视频一区在线观看| 国产理论在线| 国产韩日影视精品| 日韩精品一卡二卡三卡四卡无卡| 中文欧美日韩| 日韩一区二区三区免费视频| 国产精品.xx视频.xxtv| 日韩欧美在线中字| 国产午夜精品一区二区三区欧美| 蜜桃久久精品一区二区| 国产欧美一区二区色老头| 国产suv精品一区二区四区视频| 成人午夜国产| 蜜臀av一区二区在线免费观看| 国产亚洲欧美日韩精品一区二区三区 | 久久亚洲国产| 六月婷婷一区| 国产精品综合色区在线观看| av在线最新| 久久av一区| 久久a爱视频| 亚洲无线一线二线三线区别av| 亚洲区国产区| 国产aa精品| 久热re这里精品视频在线6| 国产精品久久| 亚洲午夜一级| 久久精品999| 欧美三级精品| 美国欧美日韩国产在线播放| 里番精品3d一二三区| 久久网站免费观看| 91成人在线精品视频| 91精品精品| 日韩av黄色在线| 久久久精品日韩| 国产亚洲高清在线观看| 欧美日一区二区| 国产欧美一区| 99国产精品久久久久久久| 里番精品3d一二三区| 视频在线观看91| 高清不卡亚洲| 欧美日本精品| 色婷婷久久久| 欧美日韩在线精品一区二区三区激情综合| 91亚洲国产高清| 日本久久二区| 色88888久久久久久影院| 欧美在线黄色| 亚洲一区久久| 91av亚洲| 国产日韩欧美在线播放不卡| 国产一区久久|