比如我们网站有很多订单 , 但是 管理权限的客服有很多人 .
如何防止多人同时编辑呢
回复内容:
比如我们网站有很多订单 , 但是 管理权限的客服有很多人 .
如何防止多人同时编辑呢
多状态嘛,编辑的时候,把状态改成编辑中,其他人不可以操作,完成了再把它状态修改下,这个是比较容易操作的。
比较科学的做法
1.提交方式是ajax
2.订单增加last_update_dateline字段存时间戳,每次修改更新该字段
3.提交订单时对比时间戳,如果晚于last_update_dateline,提示ajax弹框提示用户已经被修改过,是刷新加载新的订单内容,还是继续提交。
get√ ~
这种场景,多人同时编辑避免不了的,
决解办法可以参考SVN的做法,用户正式提交前告诉用户,他提交的版本和此时在服务器的版本之间的差异,让他来确认提交,或者继续修改
提交的时候做最近时间的确认,看是否与你提取数据的时候一直,并且用最新数据提示用户是否需要覆盖
两个比较容易实现的方法:
1.把订单编辑操作设置权限。可以按订单的类型、时间、区域等划分;
2.修改订单的显示条件。如果一个订单正在编辑中,可以有一个唯一状态,此时订单列表不显示该订单;
补充楼上。
编辑时记录进入时刻。
如果有人在进入时刻之后提交了数据,则提示刚刚有人提交过。
- ETag 判断修改的资源是否是最新的
- DB 也要加入防止并发修改的逻辑(简单一点使用行锁就可以)
就像上厕所, 每次只能一个人用; 厕所里有人就把门关上; 其他人要用的话就要在后面排着; 有的人着急就插队?
这个比较容易实现吧.
在订单列表里查询订单状态,如果是正在处理 就把订单灰掉; 客服点击订单之后就把订单状态改过正在处理状态,客服完成后或者取消修改,订单状态依次修改为 已处理/ 未处理. 然后就是细节的逻辑判断了;
是不允许多人同时编辑呢,还是解决多人同时编辑的冲突。如果是不允许那就给订单设置一个编辑中的状态,定好时间戳不久应该行吧。如果是解决多人编辑冲突,那就可以仿照github的分支,已有的就是主分支,每一个编辑的人都会创建一个分支,编辑完成之后合并到主分支。这样也应该行吧。
使用加锁机制
这个问题楼主问的比较粗糙,解决核心是数据库是一定要加锁的,否则根本做不到并发造成的多个客服读到同一个订单而导致多人编辑该订单的情况。
假设数据库是mysql,innodb引擎,订单表为orders,id为主键。所有的客服首先看到一个订单列表,然后客服点击某个订单进入订单修改页面,进入订单修改页面的php逻辑如下:
1,update orders set status="编辑中" where id=xx and status != "编辑中";
检查update语句执行后返回值,如果返回值为1(1表示更新了一行数据),表示更新成功,否则提示该订单正在编辑中。
上面的方法有两个要点:
1,update操作默认会锁住行,update执行完成后释放行锁;
2,status != "编辑中" 很重要,假设a,b两个客服并发访问,a先执行update操作,那么b会等待a操作完成才能执行自己的update操作,等待完后发现status= "编辑中",所以b什么都不做,虽然update操作成功,但是更新的行数为0;
另外一种情况是有很多需要修改的订单系统随机分配给客服,就是说客服一进入某个页面会看到一个需要修改的订单,并且要求客服们看到的订单不能重复,逻辑可以是这样:
1,begin;(开始一个事务)
2,select * from orders where status != "编辑中" limit 1 for update;
3,将得到这个订单update操作设置 status = "编辑中"
4,commit;
要点是第2步会锁定所有status != "编辑中"的订单记录,其他人需要等待事务提交后才能读到数据。如果事务等待超时时间比较短,可以设置长一点,同时如果操作失可以再读一遍。
利用memcache实现锁

PHP主要是過程式編程,但也支持面向對象編程(OOP);Python支持多種範式,包括OOP、函數式和過程式編程。 PHP適合web開發,Python適用於多種應用,如數據分析和機器學習。

PHP起源於1994年,由RasmusLerdorf開發,最初用於跟踪網站訪問者,逐漸演變為服務器端腳本語言,廣泛應用於網頁開發。 Python由GuidovanRossum於1980年代末開發,1991年首次發布,強調代碼可讀性和簡潔性,適用於科學計算、數據分析等領域。

PHP適合網頁開發和快速原型開發,Python適用於數據科學和機器學習。 1.PHP用於動態網頁開發,語法簡單,適合快速開發。 2.Python語法簡潔,適用於多領域,庫生態系統強大。

PHP在現代化進程中仍然重要,因為它支持大量網站和應用,並通過框架適應開發需求。 1.PHP7提升了性能並引入了新功能。 2.現代框架如Laravel、Symfony和CodeIgniter簡化開發,提高代碼質量。 3.性能優化和最佳實踐進一步提升應用效率。

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

PHP類型提示提升代碼質量和可讀性。 1)標量類型提示:自PHP7.0起,允許在函數參數中指定基本數據類型,如int、float等。 2)返回類型提示:確保函數返回值類型的一致性。 3)聯合類型提示:自PHP8.0起,允許在函數參數或返回值中指定多個類型。 4)可空類型提示:允許包含null值,處理可能返回空值的函數。

PHP中使用clone關鍵字創建對象副本,並通過\_\_clone魔法方法定制克隆行為。 1.使用clone關鍵字進行淺拷貝,克隆對象的屬性但不克隆對象屬性內的對象。 2.通過\_\_clone方法可以深拷貝嵌套對象,避免淺拷貝問題。 3.注意避免克隆中的循環引用和性能問題,優化克隆操作以提高效率。

PHP適用於Web開發和內容管理系統,Python適合數據科學、機器學習和自動化腳本。 1.PHP在構建快速、可擴展的網站和應用程序方面表現出色,常用於WordPress等CMS。 2.Python在數據科學和機器學習領域表現卓越,擁有豐富的庫如NumPy和TensorFlow。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

Atom編輯器mac版下載
最受歡迎的的開源編輯器

Dreamweaver Mac版
視覺化網頁開發工具