假设有个用户发文章的场景。
一个用户表,一个类别表,一个文章表,文章表有个user_id关联用户表,一个category_id关联类别表。用mysql的数据库,没有做外键约束。
当用户发布一篇文章的时候,我需要去更新类别表的post_count字段,表示这个类别下有多少篇文章之类的。因为考虑到数据完整性要求不那么高,所以我这里没放在一个事务中去更新两张表的数据,而是分别去更新每张表的数据。
我希望能够在插入文章表之后就返回给客户端,创建成功的信息,断开与客户端的连接,然后再完成后续更新类别表的post_count字段。
lz之前是写python的,tornado框架就有个概念叫is_finish,标明当前与客户端的连接是否已经断开了,不知道codeinighter里面有没类似的概念呢?或者说怎么样主动断开与客户端的连接?
PS:lz也不知道这种不用事务的做法是不是不太合适,没真实在产品环境上跑过.....
回复内容:
假设有个用户发文章的场景。
一个用户表,一个类别表,一个文章表,文章表有个user_id关联用户表,一个category_id关联类别表。用mysql的数据库,没有做外键约束。
当用户发布一篇文章的时候,我需要去更新类别表的post_count字段,表示这个类别下有多少篇文章之类的。因为考虑到数据完整性要求不那么高,所以我这里没放在一个事务中去更新两张表的数据,而是分别去更新每张表的数据。
我希望能够在插入文章表之后就返回给客户端,创建成功的信息,断开与客户端的连接,然后再完成后续更新类别表的post_count字段。
lz之前是写python的,tornado框架就有个概念叫is_finish,标明当前与客户端的连接是否已经断开了,不知道codeinighter里面有没类似的概念呢?或者说怎么样主动断开与客户端的连接?
PS:lz也不知道这种不用事务的做法是不是不太合适,没真实在产品环境上跑过.....
http是无状态协议,PHP是URL驱动的脚本语言,没有守护进程,不支持异步。
用户访问一个PHP页面,一般情况下,Apache会单开一个进程来处理这个页面,处理完毕进程退出,nginx会发送一个请求给一个PHP守护进程,同样的,会新开一个进程或线程,处理完毕立刻退出。
如果想异步,可以用redis等存储队列、另开守护进程处理队列。
根据题主的情况,建议一次完成。
你说的应该是指返回数据后,php再继续在后台处理剩余数据,你这个需求在php中应该实现不了,php这门语言在http通信结束后,就会回收当前通信过程中使用到的所有局部变量,所以你这个需求很有可能实现不了。
其实你的这个需求是属于异步处理,这是node.js的强项。
水平不足,没看明白断开客户端连接的意思。
不过可以给你推荐两个ci的查询辅助函数,如下:
$this->db->insert_id()
执行数据插入时的ID,也就是返回插入成功后的ID$this->db->affected_rows()
当执行写入操作(insert,update等)的查询后,显示被影响的行数。
相关文档的链接在此:http://codeigniter.org.cn/user_guide/database/helpers.html
利用这两个函数应该足够确认插入数据成功了,希望能帮到你 : )

thesecrettokeepingaphp-poweredwebsterunningsmootlyunderheavyloadinvolvesseveralkeystrategies:1)emform opcodecoduceSciptionexecutiontime、2)aatabasequerycachingwithiThing withiThistolessendavasoload、

コードをより明確かつ維持しやすくするため、依存関係が関心(DI)に注意する必要があります。 1)DIは、クラスを切り離すことにより、よりモジュール化されます。2)テストとコードの柔軟性の利便性を向上させ、3)DIコンテナを使用して複雑な依存関係を管理しますが、パフォーマンスの影響と円形の依存関係に注意してください。

はい、最適化されたAphPossibleandessention.1)CachingingusapCutoredatedAtabaseload.2)最適化、効率的なQueries、およびConnectionPooling.3)EnhcodeCodewithBultinctions、Avoididingglobalbariables、およびUsingopcodeching

keyStrategIestsoSificlyvoostphpappliceperformanceare:1)useopcodecachinglikeToreexecutiontime、2)最適化abaseの相互作用とプロペラインデックス、3)3)構成

aphpDependencyInjectionContaineriSATOULTAINATINAGECLASSDEPTINCIES、強化測定性、テスト可能性、および維持可能性。

SELECT DEPENTENCINGINOFCENT(DI)大規模なアプリケーションの場合、ServicElocatorは小さなプロジェクトまたはプロトタイプに適しています。 1)DIは、コンストラクターインジェクションを通じてコードのテスト可能性とモジュール性を改善します。 2)ServiceLocatorは、センター登録を通じてサービスを取得します。これは便利ですが、コードカップリングの増加につながる可能性があります。

phpapplicationscanbeoptimizedforspeedandEfficiencyby:1)enabingopcacheinphp.ini、2)PreparedStatementswithpordatabasequeriesを使用して、3)LoopswithArray_filterandarray_mapfordataprocessing、4)の構成ngincasaSearverseproxy、5)

PHPemailvalidationinvolvesthreesteps:1)Formatvalidationusingregularexpressionstochecktheemailformat;2)DNSvalidationtoensurethedomainhasavalidMXrecord;3)SMTPvalidation,themostthoroughmethod,whichchecksifthemailboxexistsbyconnectingtotheSMTPserver.Impl


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

メモ帳++7.3.1
使いやすく無料のコードエディター

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール
