java 板


LINE

※ 引述《NullLife (929rock化)》之铭言: : 例如有某一张Table存放一家公司底下的处部等关系, : Aa ┬ Ba ┬ Ca ┬ Da : ├ Bb ├ Cb └ Db ┬ Ea ┬ Fa : │ └ Cc └ Eb ├ Fb : └ Bc ┬ Cd ┬ Dc └ Fc : │ └ Dd ┬ Ec : └ Ce ┬ De └ Ed : ├ Df : └ Dg : 目前table已经做出阶层式的关系, : class MyEntity { : @Id : @... : private Integer seq; : @ManyToOne : @JoinColumn(name="parent_seq") : private MyEntity parent; : @OneToMany : @JoinTable( : name="link" : ,joinColumns = @JoinColumn( : name = "parent_seq" : ,referencedColumnName = "seq" : ) : ,inverseJoinColumns = @JoinColumn( : name = "child_seq" : ,referencedColumnName = "seq" : ) : ) : private Set<MyEntity> children; : ... : } : 现在写入、跟一般查询都很正常, : 可以取到我要的资料,然後可以看到上下的关系 : 但如果处部有名字一样的时候,我想查到某个支线下的处部关系,要怎麽做? : 例如如下图的 Ea 跟 Df 同时都叫"总务部"好了 : Aa ┬ Ba ┬ Ca ┬ Da : ├ Bb ├ Cb └ Db ┬ Ea ┬ Fa : │ └ Cc └ Eb ├ Fb : └ Bc ┬ Cd ┬ Dc └ Fc : │ └ Dd ┬ Ec : └ Ce ┬ De └ Ed : ├ Df : └ Dg : 然後今天我想找Ea这个部,底下还有细分那些部, : 但我所拥有的条件,就只有 Aa Ba Ca Db Ea 的名字, : 要怎麽做才能找到我要 Ea ? : 因为如果直接条件下"总务部",我会得到两笔资料, : 然後两笔要往上查看是否为我要找的支线, : 要不然就变成是全查出来,然後递回去找到我要的 Ea... : 这两个方法都满笨的,而且要写不少code... : 小弟我这两天想破头了,也有想调整结构,或者多Table来处理, : 但都一样很麻烦,省不了工... : 所以上来请教一下各版大有没有其他比较方便方法能达到这个目的? : 感恩<(_ _)> 写 code 难免 我讲一下我的解决方案 首先,部门应该要有部门代号 (table的pk或是entity的@Id) 查询时可以把部门代号当条件 举个例来说,你去商店说你要HTC手机,店员会问你型号 不然谁晓得你要哪一只? 店员也可以把所有HTC手机拿出来给你选。 总之不可能心电感应就对了。 第二种是往上检查的 JPQL 假设 samsung 手机型号是这样悲惨的分类 Samsung ─ galaxy ┬ S ─ 3 └ Tab ─ 3 首先要查 "3",会查出两个 所以要把父节点当作查询条件 select x from x where x.name=(?1) and x.parent=(?2) ?1 就给 String ?2 就给 Entity 这两种方式虽然不能说是完美解,但在逻辑上说得通。 有清楚的逻辑,就算要写code,应该也不会太笨吧? 如果真的觉得写code很麻烦,改scheme很麻烦的话 有 framework 是可以到这种程度的 @Query("select x from x where x.name=(?1) and x.parent=(?2)") public MyEntity myAutoQuery(String name, MyEntity parent); 就写好了。 另外,程式这东西一定要有规则绑住,不然会很麻烦 例如:"万一我部门代号也重覆怎麽办" 就不要让他重复阿,重复就代表资料有问题,要去找到为什麽会重复 而不是去想 "代码重复後我要怎样做才能只输入代码就只查到一笔资料" 就像如果有人问说 "我的电脑只要拔掉电源线就会关机,你能让我的电脑拔掉电源线不关机吗?" 我们要解的是不要让 user 脚贱一直踢到电源线, 而不是真的让电脑可以在无电底下运作 --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 61.218.64.133
※ 文章网址: http://webptt.com/cn.aspx?n=bbs/java/M.1405573550.A.554.html
1F:推 gmoz:推电源线这段XDDD 07/19 13:38
2F:推 dream1124:推 07/20 01:17







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:BuyTogether站内搜寻

TOP