我正在開發一個醫院管理系統,就像你知道的是一個龐大的系統,要弄清楚事情,接待處會爲患者開一張新票票號不會是一個定製的表格,每月不會(112011000101 ),這意味着沒有票101上月月在2011年MySQL多用戶交易
在保存票,我的應用程序將讀取上次保存的票沒有&增加沒有一個,(從門票那裏Tick_No像「112011」%選擇Tick_No按Tick_No DESC限制1),這將返回最後一個保存的票(112011000101)增加一個==>新票將是(112011000102)。
因此,如果有兩名員工在同一個地方保存一張新票,是否有機會獲得重複票?
我正在使用mysql數據庫的事務處理,它將進行行級別鎖定,但仍然可用於任何查詢。
所以我需要一個明確的答案,如果有可能。
請注意在我的代碼中,如果出現問題時保存,將發出回滾併發出自動重試保存功能(在每個保存命令中,應用程序將執行檢查最後一個數字)。
我知道,但我需要關係數據庫,鎖定表將殺死使用事務的好處。 –
如何在最後一張票上執行「SELECT ... FOR UPDATE」,然後添加新行?通過這種方式,一次在線的一個用戶可以使用最後一個號碼來創建一個新號碼。 – Dragos
好吧,讓我們來簡化一下,我想知道在使用交易時,如果票號相同的票證插入到票據表中,mysql會回滾其中的一個,對吧?至少還會有一個人會被評論?答案是肯定的? –