顯示廣告
隱藏 ✕
※ 本文為 terievv 轉寄自 ptt.cc 更新時間: 2019-05-11 20:56:20
看板 Soft_Job
作者 a88241050 (再回頭已是百殘身)
標題 [請益] 這是個很低級的錯誤嗎?
時間 Tue May  7 20:42:01 2019


是這樣的

最近工作上需要寫一支程式寫資料進資料庫

並產生流水號當key值寫進欄位中

我的想法很單純

就是直接抓資料庫資料筆數

然後拿筆數+1當新增的流水號

寫完後交給SA測試

結果他一測馬上就出問題了

後來我才知道 原來流水號是要抓最大值+1

而不是一直照順序編下去

因為這個我被SA噹的體無完膚

請問這個是很基本的觀念嗎?



--
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 49.214.145.27
※ 文章代碼(AID): #1SqNqRbb (Soft_Job)
※ 文章網址: https://www.ptt.cc/bbs/Soft_Job/M.1557232923.A.965.html
g2581856: 我覺得是啦1F 05/07 20:47
g2581856: 不過以後別再犯就OK了吧,用不著噹
diabloevagto: 你自己測試測不出來嗎???3F 05/07 20:48
我沒想到他會手動刪除資料啊
※ 編輯: a88241050 (49.214.145.27), 05/07/2019 20:50:06
abccbaandy: SA需求不明確還敢噹人喔...4F 05/07 20:50
abccbaandy: 產生流水號規則有說/寫清楚嗎?
meowyih: ... 呃, 這也太新手了6F 05/07 20:51
abccbaandy: 另外第二種作法有考慮multi thread嗎?7F 05/07 20:52
meowyih: 還有這不是auto incremental自動會幫你寫嗎,為啥要自己手8F 05/07 20:53
meowyih: 動寫?
wayne12345: 是10F 05/07 20:53
sourbait: 資料庫一般來說要考慮到刪除的可能11F 05/07 20:54
weinine32: 有考慮lock問題嗎? 流水號會重複喔!12F 05/07 20:55
MOONY135: 要看需求吧13F 05/07 20:56
alihue: 我就算第一次學也不會犯這種錯14F 05/07 20:58
yyc1217: 是 不過刪除也有分直接刪除或是註記刪除15F 05/07 20:59
yyc1217: 如果能用資料庫本身的流水號更好 除非流水號有要求格式
yyc1217: 一般來說要刪除也要保留資料比較好 畢竟記憶體不貴
yyc1217: 查到了 叫soft delete
alan3100: 流水號由DB產生是基本, 除非你有其他特殊需求19F 05/07 21:07
supernow: 是的,這很基本,不抓最大的就會有重複的問題20F 05/07 21:11
t64141: 滿基本的,不過多了一個機會去研究流水號的問題也是好事21F 05/07 21:12
請問DB產生的意思是? SA是跟我說抓最大的號碼加1,比如說現在有0000,0001,0002,0003,
0004五筆,這五筆都是由程式產生出來的,所以照理來說程式產生的下一筆就是0005,但
現在問題是SA可能在資料庫直接手動新增資料,比如說現在他手動新增了一筆1234,這時
再跑程式的話就應該要產生1235,而不是0006,他的意思是這樣
※ 編輯: a88241050 (49.214.145.27), 05/07/2019 21:19:45
alan3100: 抓最大+1也是錯的 除非你一次只insert一筆22F 05/07 21:14
是一次一筆沒錯,不會有多筆的情況
meowyih: google 'sql auto_increment'23F 05/07 21:21
benjamin99: 比較好奇 SA 為啥會有 max+1 就正確的概念?24F 05/07 21:23
※ 編輯: a88241050 (49.214.145.27), 05/07/2019 21:26:17
Chris926926: 好奇不用auto increment的原因是?有特殊需求?26F 05/07 21:28
googoo1102: 保險起見把流水號欄位設成unique27F 05/07 21:29
godddddd: 看你資歷 沒事請用sql內建流水號28F 05/07 21:30
x000032001: 同時插兩筆抓max也是爆炸29F 05/07 21:50
q26766: 一樣錯啊哈哈 ,別理有些酸推文,誰沒新手過30F 05/07 21:54
mackliu: 你們的流水號會不會是設計成文字格式,而且還沒設主鍵?XD31F 05/07 21:56
GoodFriday: 抓最大值+1不就超容易抓到重複 只有第一筆塞得進去32F 05/07 21:59
ripple0129: 你新手就算了,SA也新手,拜託找個資深的來帶一下吧33F 05/07 22:00
LinuxKernel: 慘34F 05/07 22:06
jyunwei: 那你以後就會想到了,如果你資歷一年內的話啦35F 05/07 22:07
crossdunk: 很基本阿,可是為什麼是SA測試呀36F 05/07 22:13
ChungLi5566: 非本科? 實務上流水號都給db自己編啊37F 05/07 22:14
crossdunk: 他的流水號應該是前面還需要加其他東西38F 05/07 22:15
abraxas: 他那做法,直接新增一筆溢位筆數減一的資料不就炸掉了39F 05/07 22:15
Label: 他還沒測transation呢40F 05/07 22:16
kurtsgm: 441F 05/07 22:19
[圖]
 
bill0205: 通常db 的 key都是auto increment吧=  =43F 05/07 22:23
abccbaandy: 好奇到底什麼使用情境可以想出這種神奇作法...44F 05/07 22:24
bill0205: 我自己是會做兩種序號 一種是db 一種是顯示的SN45F 05/07 22:24
可是我的序號前面還要加其他字串欸,等於說我在寫入資料庫前就要取得db產生的key值
組成我要的流水號後再寫入db,這有辦法嗎?
※ 編輯: a88241050 (49.214.145.27), 05/07/2019 22:33:10
rahit: 這東西一般資料庫都能自動給…46F 05/07 22:31
cloudgoogle: 單純抓max一樣也是有問題 多人同時操作的執行順序...47F 05/07 22:35
drajan: 蠻嚴重的錯誤 不過如果入行不到半年可以容忍48F 05/07 22:38
ChungLi5566: 要加字串還是補左邊零的寫在程式就好 幹嘛放在table49F 05/07 22:42
ChungLi5566: 佔DB磁碟空間
bill0205: 有序的就照C大方法 或是把字串丟到另外欄位 撈出來時後51F 05/07 22:43
bill0205: 再組起來 無序比較麻煩
ashlikewing: 流水號自己做太扯了啦53F 05/07 22:44
cloudgoogle: 如果可以撈出來另外處理當然是最好 不過有的Table54F 05/07 22:46
cloudgoogle: 是要給別人存取的,可能就沒辦法控制在自己這邊
cloudgoogle: 即便如此,還是可以像bill大說的存兩欄可能好一點
onlyeric23: 菜到不行57F 05/07 22:49
you878787: 如果我看到這種code應該會把這個人幹到火星去吧= =58F 05/07 22:51
ChungLi5566: 通常別系統來存取 是走API而不會直連DB59F 05/07 22:51
bill0205: 題外話 大家是怎麼做無序的流水序號60F 05/07 22:52
you878787: 開始寫前請先訂好test case, 另外有基礎知識應該根本61F 05/07 22:55
you878787: 不能這樣抓....
lukelove: 比較大的問題是 開發前沒有先查怎麼設計就土砲做63F 05/07 22:56
jinmin88: 菜到不行的問題64F 05/07 23:10
blackie1019: 兩個都會笑到翻過去65F 05/07 23:39
crossdunk: 無序怎麼叫做流水XD66F 05/07 23:57
Darkword1987: 資料筆數減少不就GG了67F 05/07 23:58
CloudyWing: 總筆數+1在跳號的情況下有可能序號重複,有經驗的設計68F 05/08 00:01
CloudyWing: 應該就要注意這件事...
CloudyWing: 今天就算是Soft delete,也有可能因為一些意外因素導
jlhc: 還是不懂為什麼不是auto increment71F 05/08 00:06
CloudyWing: 致資料跳號,不過我好奇設計上有介面可以輸入序號72F 05/08 00:07
CloudyWing: 還是SA直接加資料庫?
bibo9901: uuid..74F 05/08 00:09
molopo: 流水號一直上去就好75F 05/08 00:12
gpctv: 這個也要刁,改就好了啊,在我們公司SA地位像狗一樣76F 05/08 00:27
sachung28: serial primary key就會自己產生序號+避免重複了77F 05/08 00:28
viper9709: 流水號不用也不能自己做吧...78F 05/08 00:28
sachung28: 可以在SQL寫入DB時順便用return回傳+改格式 前提是DB79F 05/08 00:33
sachung28: 有支援...另外 刪除並重塞資料測序號產生邏輯ok 但我
sachung28: 第一次看到QA自己塞數字當流水號
sachung28: 如果是UI呈現美觀 流水號要補字串 這可以API hard code
sachung28: 處理 或是另外開個流水號前綴字的定義表儲存 查詢時將
sachung28: 前綴和序號串起來
sachung28: 建議你去惡補一下DB觀念 學會用DB能省很多寫程式的時
sachung28: 間
mathrew: 4  這種問題就代表  你根本寫的時候  很多狀況都沒想過88F 05/08 06:23
mathrew: 但是為什麼流水號不給DB自動去編
brianhsu: 流水號不要自己生,問題很多的。交給 DB,例如 auto Inc90F 05/08 07:26
brianhsu:  之類的功能處理。
deray: 流水號幹嘛最大值+1 auto increment92F 05/08 08:36
qpowjohn: 抓最大值+1想了一下應該有可能,可是要開transaction保93F 05/08 08:44
qpowjohn: 證不會有人寫表...有錯請指教
xdraculax: 總數加一很瞎,最大加一也只是50步笑百步95F 05/08 08:51
y3k: 這就是菜而已吧96F 05/08 08:57
luluking: 你不覺得這樣寫反而麻煩97F 05/08 09:03
lion0208: 為何不用 auto increment?另外取最大+1,同時間確定只98F 05/08 09:10
lion0208: 會有一個 process/thread 在寫?
mago: 如果有大量同時寫入問題,兩個都不行100F 05/08 09:14
CodingMan: 換個想法你就知道答案了 難不成這是高級問題嗎?101F 05/08 09:19
lazarus1121: auto increment如果需要跨table當key不就不能用了102F 05/08 09:20
silent5566: 直接用DB的sequence去滾不就好了103F 05/08 09:34
silent5566: 你這兩種作法未來table在應用上會很差
silent5566: 多人使用的時候沒咬住key值很容易有重複的問題
hakama99: 我一開始寫也不知道有自動產生的功能  也是跟你一樣XD106F 05/08 10:18
testPtt: 設預設值不要用sql寫就好啦107F 05/08 10:45
johnny9144: 4108F 05/08 11:23
f124: 叫資料庫自己跑流水號就好 還自己編幹嘛...109F 05/08 11:25
iamshiao: 是,而且拿 max 也可能會有問題,用資料庫本身提供的自110F 05/08 11:34
iamshiao: 動增加機制比較好
seedli: 除非系統只有一個人用,不然抓max+1可能有race condition112F 05/08 12:13
worf: ...113F 05/08 14:08
amyt: 是114F 05/08 14:25
laker780304: 不嫌麻煩可以建立Sequence,新增時取Sequence用即可115F 05/08 15:20
zg0608x: 好有創意的方法116F 05/08 17:17
indexcome: 其實就算沒講清楚需求。這種可能發生的情況寫code的人117F 05/08 17:24
indexcome: 應該都會注意到的.
BignoZe: 照常理不太會這樣寫119F 05/08 17:59
rocwild: 基本120F 05/08 18:30
GinginDenSha: 兩個都4121F 05/08 19:00
xo1100: 抓最大+1的話 你之後碰用到多人使用的系統還會再被噹一次122F 05/08 22:15
stupid0319: 是SA太淺了123F 05/09 00:09
hooll111: 這個還蠻基本的耶 取筆數超抖...124F 05/09 01:32
deanh: 你們兩個都錯了啊,搞笑125F 05/09 04:44
gettheworld: 覺得是想展現優越感126F 05/09 12:53
zerrofighter: 這種事情就是炸過一次就知道了127F 05/09 14:13
mdkn35: 我都用uuid128F 05/09 14:23
DerLuna: 這兩個方法都不好吧129F 05/09 15:54
cholux: 是有一點,不過看問題可能會有更好的作法130F 05/09 18:04
panpan: 笑死 看到兩個菜雞戶啄131F 05/09 20:32
Frecci: 妳太菜是真的 但是不代表他能夠直接進入db刪資料132F 05/09 22:45
Frecci: 假設是用ui刪除的話 那完全就妳問題了
paulshain04: 這怎麼會是自己新增 DB不是有自動流水號 column不用134F 05/10 09:09
paulshain04: 填啊

--
※ 看板: terievv 文章推薦值: 0 目前人氣: 0 累積人氣: 149 
作者 a88241050 的最新發文:
點此顯示更多發文記錄
分享網址: 複製 已複製
r)回覆 e)編輯 d)刪除 M)收藏 ^x)轉錄 同主題: =)首篇 [)上篇 ])下篇