問題是這樣:
資料庫中一個欄位cate的資料是以逗號分隔儲存的,如:1,2,3,4,5,
查詢時傳入的參數是一個數組,如:array(1,2 );
我這比較笨的方法是循環這個數組,然後用like拼接起來實現的,如:
<code>(cate like '%1,%' or cate like '%2,%')</code>
但在數據量很大的時候這個效率就太低了,有沒更有效的辦法呢?謝謝。 。
回覆內容:
問題是這樣:
資料庫中一個欄位cate的資料是以逗號分隔儲存的,如:1,2,3,4,5,
查詢時傳入的參數是一個數組,如:array(1,2 );
我這比較笨的方法是循環這個數組,然後用like拼接起來實現的,如:
<code>(cate like '%1,%' or cate like '%2,%')</code>
但在數據量很大的時候這個效率就太低了,有沒更有效的辦法呢?謝謝。 。
<code>程序循环你传入的数组,循环体内部调用mysql的find_in_set函数,当字串不是太长时,find_in_set的效率比like快很多。</code>
1.修改欄位類型為SET,使用FINd_IN_SET比你用like快得多,但是它也是屬於字串操作,用在欄位上,得全表掃描。 SET類型有一些限制,比較建議SET適用於值域小,取值固定,整體查詢的狀態集合。例如記錄某人去過中國哪些省:可以直接比較兩個人是否去過相同的省份,或者直接獲得差別,可以有效率地查詢哪些人只去過某省或某些省,但查哪些人去過某省或某些省份依然是掃全表。
<code>FIND_IN_SET(str,strlist) 如果字符串str是在的strlist组成的N子串的字符串列表,返回值的范围为1到N。 </code>
SQL> SELECT FIND_IN_SET('b','a,b,c,d'); |
---|
SELECT FIND_IN_SET('b','a,b,c,d') |
2 |
2.
用中间(映射)表,可以借助索引提高查询效率。
不管怎么写,怎么改,用函数也好,这样的数据结构稍微量大效率都很低,索引几乎用不上了
只能改下你们的储存方式,不要把1,2,3,4,5,这种放到一个字段,分开来,或者用nosql
可以考虑下MySQL的正则查询
重新设计数据库吧!!!无论怎么说 字符串匹配的花销都不小。把cate字段抽出来形成一个新的关系表
如果查询的频繁建议缓存数据后用程序来查缓存或者重新设计表,MYSQL里面用正则效率很低的。
你应该去问设计数据表的那个人。
建议修改数据存储格式吧....不是说这么存问题有多大
而是这么存了之后却又需要快捷高效的查...那势必就是自己给自己添堵了 能调整尽快调整
where cate like '%1,%' or cate like '%2,%' 这个条件本身有两个问题都导致无法使用索引:
1、or条件; 2、like '%...'格式。
针对这个查询做优化的:
1、or改为union all
2、在程序里做模糊查询, 将所有数据取出来(或者按10%取,取10次),循环做strpos的模糊匹配。 因为php的array操作时非常快速的,所以这样操作,会比直接入库查询快,但是会耗内存。
另外这样的话,分页这些,也就只有在程序里做了。
其实这个数据库设计是有问题的, 将'1,2,3..'这种格式的字符串设计成字段,mysql效率很低,建议根据位运算去设计cate字段,数据多的话,cate可以为bigint, 这样查询会非常快,也省去了like、 or这些mysql的瓶颈。
不建议使用mysql自带的函数,没太明白你说的1,2 1,2,3,4,5 是具体的什么意思,我猜可能是每条记录所属的类型是哪些,
例如:
<code>老九门 是哪些?包括 语文、数学、英语、化学、生物、物理、地理、历史、政治 这九门都有一个类型是 “老九门”,那么这九门里又有理科和文科, 老九门、理科、文科分别是1、2、3 那么 语文、数学、英语的类型字段是1,2,3 化学、物理、生物的类型字段是1,2 地理、历史、政治的类型字段是1,3</code>
(建议不要把业务逻辑放到mysql中处理,mysql字段类型越简单越好,下面会用到)
<code>语文、数学、英语、化学、生物、物理、地理、历史、政治已经有了各自的类型所属 是否考虑将1,2,3 1,2 1,3 定义成数组格式呢 这里应用php的写法 $arr = array( 1=>array(1,2,3), 2=>array(1,2), 3=>array(1,3) ); 在往表中插入数据时,你的cate字段就存1 2 3就可以了,到时候直接查询1或者2或者3就可以了,业务逻辑去脚本程序 中处理,不要在mysql中做太多的处理,越简单越好 如果还是不太懂的话 也可以 $arr = array( '1,2,3'=>1, '1,2'=>2, '1,3'=>3 ); 在程序中处理完后再去查相应的mysql数据就可以了</code>

要保護應用免受與會話相關的XSS攻擊,需採取以下措施:1.設置HttpOnly和Secure標誌保護會話cookie。 2.對所有用戶輸入進行輸出編碼。 3.實施內容安全策略(CSP)限制腳本來源。通過這些策略,可以有效防護會話相關的XSS攻擊,確保用戶數據安全。

优化PHP会话性能的方法包括:1.延迟会话启动,2.使用数据库存储会话,3.压缩会话数据,4.管理会话生命周期,5.实现会话共享。这些策略能显著提升应用在高并发环境下的效率。

theSession.gc_maxlifetimesettinginphpdeterminesthelifespanofsessiondata,setInSeconds.1)它'sconfiguredinphp.iniorviaini_set().2)abalanceisesneededeededeedeedeededto toavoidperformance andunununununexpectedLogOgouts.3)

在PHP中,可以使用session_name()函數配置會話名稱。具體步驟如下:1.使用session_name()函數設置會話名稱,例如session_name("my_session")。 2.在設置會話名稱後,調用session_start()啟動會話。配置會話名稱可以避免多應用間的會話數據衝突,並增強安全性,但需注意會話名稱的唯一性、安全性、長度和設置時機。

會話ID應在登錄時、敏感操作前和每30分鐘定期重新生成。 1.登錄時重新生成會話ID可防會話固定攻擊。 2.敏感操作前重新生成提高安全性。 3.定期重新生成降低長期利用風險,但需權衡用戶體驗。

在PHP中設置會話cookie參數可以通過session_set_cookie_params()函數實現。 1)使用該函數設置參數,如過期時間、路徑、域名、安全標誌等;2)調用session_start()使參數生效;3)根據需求動態調整參數,如用戶登錄狀態;4)注意設置secure和httponly標誌以提升安全性。

在PHP中使用會話的主要目的是維護用戶在不同頁面之間的狀態。 1)會話通過session_start()函數啟動,創建唯一會話ID並存儲在用戶cookie中。 2)會話數據保存在服務器上,允許在不同請求間傳遞數據,如登錄狀態和購物車內容。

如何在子域名間共享會話?通過設置通用域名的會話cookie實現。 1.在服務器端設置會話cookie的域為.example.com。 2.選擇合適的會話存儲方式,如內存、數據庫或分佈式緩存。 3.通過cookie傳遞會話ID,服務器根據ID檢索和更新會話數據。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

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

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

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

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

SublimeText3 Linux新版
SublimeText3 Linux最新版