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