導航:首頁 > 編程語言 > phpmysql鎖表

phpmysql鎖表

發布時間:2023-04-12 21:45:44

php 中的mysql for update 加鎖後還其他用戶還能讀取嗎

加鎖後只能讀,但不能寫。

② php 面試必考題 mysql的MyISAM 和 InnoDB 的區別

1.InnoDB不支持FULLTEXT類型的索引。

2.InnoDB 中不保存表的具體行數,也就是說,執行select count(*) from
table時,InnoDB要掃描一遍整個表來計算有多少行,但是MyISAM只要簡單的讀出保存好的行數即可。注意的是,當count(*)語句包含
where條件時,兩種表的操作是一樣的。

3.對於AUTO_INCREMENT類型的欄位,InnoDB中必須包含只有該欄位的索引,但是在MyISAM表中,可以和其他欄位一起建立聯合索引。

4.DELETE FROM table時,InnoDB不會重新建立表,而是一行一行的刪除。MyISAM 是表所
innodb是行鎖

5.LOAD TABLE FROM MASTER(從主負載表)操作對InnoDB是不起作用的,解決方法是首先把InnoDB表改成MyISAM表,導入數據後再改成InnoDB表,但是對於使用的額外的InnoDB特性(例如外鍵)的表不適用。

另外,InnoDB表的行鎖也不是絕對的,如果在執行一個SQL語句時MySQL不能確定要掃描的范圍,InnoDB表同樣會鎖全表,例如update
table set num=1 where name like 「"2%」

6.InnoDB 支持事物

選擇存儲引擎 根據實際情況選擇。

一般情況下如果查詢多建議使用myIsam 。

如果你需要事務處理或是外鍵,那麼InnoDB 可能是比較好的方式。

優化MYSQL資料庫的方法:

1,選取最適用的欄位屬性,盡可能減少定義欄位長度,盡量把欄位設置NOT NULL,例如'省份,性別',最好設置為ENUM

2,使用join代替子查詢

3,使用聯合(UNION)來代替手動創建的臨時表

4,事務處理(保證數據完整性,例如添加和修改同時,兩者成立則都執行,一者失敗都失敗)

5,適當建立索引(如何建立索引?索引的利與弊?)

6,優化sql語句

7,explain可以看到mysql執行計劃

8,分表(垂直分表,水平分表?)

9,資料庫主從

③ PHP MYSQL中 表鎖和行鎖 一般什麼情況下使用 另外具體怎麼寫

手動加鎖:
表級鎖
lock tables tablename read;//共享鎖
lock tables tablename write;//排它鎖
unlock tables;//解鎖

php直接query就行了。

除了MyIsam,誰還會無聊到顯式加鎖?
InnoDB直接跑事務默認會觸發隱式鎖,不需要自己lock和unlock。

④ php操作mysql InnoDB表,導出並刪除日誌表裡數據,由於數據量過大

下面是基本的步驟:
1 使用mysqlmp命令將InnoDB資料庫導出
2 停止MySQL
3 刪除所有InnoDB資料庫文件和日誌
4 啟動MySQL並自動重建InnoDB資料庫文件和日誌文件
5 導入前面備份的資料庫文件還有什麼疑問的話可以多去後盾們看一些相關的視頻,這樣你可以更加清楚。

⑤ php向mysql首次插入數據怎麼保持兩個欄位數字相同

很簡單,先執行一條插入語句,sid這個欄位先為空,$uid = mysql_insert_id();得到這條插入自增的id。然後用修改update語句修改這個$uid的sid就可以了。

⑥ 關於php操作mysql執行資料庫查詢的一些常用操作匯總

php操作mysql步驟:
1.$connect=mysql_connect('localhost','root','123456')
or
die('資料庫連接失敗。'mysql_error());鏈接mysql。
2.mysql_select_db('database',$connect)選擇鏈接的資料庫。
3.mysql_query('Set
names
gb2312');$sql
=
"select
*
from
blog_article";准備要查詢的數據。
4.$datas
=
mysql_query($sql);執行sql查詢。
5.$data
=
mysql_fetch_assoc($datas)得到查詢到的緩存在內存中的一條數據。
6.print_r($data);
相同點:三個函數都是返回資料庫中查詢到的一行數據(說的再清楚點就是一條數據)。
不同點:mysql_fetch_assoc()用的是資料庫中相應的欄位名作為的key值(也就是數組下標)
如:filed['id']=1;
mysql_fetch_row()用的是自動生成的數字(從0開始依次生成)作為的key值(也就是數組下標)
如:filed[0]=1;
mysql_fetch_array()用的是自動生成的數字(從0開始依次生成)作為的key值(也就是數組下標),而且它還同時生成資料庫中相應的欄位名作為的key值(也就是數組下標)
如:
filed[0]=1,filed['id']=1;也就是說,mysql_fetch_array()將mysql_fetch_assoc()和mysql_fetch_row()查詢到的結果合為了一體了。
mysql_fetch_object()與mysql_fetch_assoc()差不多。只是mysql_fetch_assoc()返回的是數組。mysql_fetch_object()返回的是object對象。
mysql_insert_id() 取得上一步
INSERT
操作產生的
ID。
mysql_result()
函數返回結果集中一個欄位的值。
mysql_num_fields()
函數返回結果集中欄位的數目。
mysql_affected_rows();返回前一次
MySQL
操作所影響的記錄行數。
mysql_num_rows(mysql_query($sql))獲得結果集中行的數目。
mysql_pconnect()
函數打開一個到
MySQL
伺服器的持久連接。
mysql_pconnect()

mysql_connect()
非常相似,但有兩個主要區別:
1.
當連接的時候本函數將先嘗試尋找一個在同一個主機上用同樣的用戶名和密碼已經打開的(持久)連接,如果找到,則返回此連接標識而不打開新連接。
2.
其次,當腳本執行完畢後到
SQL
伺服器的連接不會被關閉,此連接將保持打開以備以後使用(mysql_close()
不會關閉由
mysql_pconnect()
建立的連接)。
mysql_data_seek(mysql_query($sql),8);獲得結果集中的第8條數據。(mysql_num_rows(mysql_query($sql))和mysql_data_seek(mysql_query($sql),8)在mysql_unbuffered_query($sql)不可以使用。)
mysql_unbuffered_query($sql)和mysql_query($sql)效果差不多,但是
mysql_unbuffered_query($sql)不緩存。mysql_query($sql)會緩存查詢的結果。
mysql_close();關閉mysql的最近的鏈接。
mysql_field_flags(mysql_query($sql),6)返回第六個欄位的表屬性輸出如:not_null
primary_key
auto_increment

mysql_fetch_lengths(mysql_query($sql))返回該條數據的所有欄位的每個欄位的長度。返回的是一個數字組成的數組。
mysql_field_name(mysql_query($sql),3)返回第三個欄位的欄位名。
mysql_field_table(mysql_query($sql),0)返回指定欄位所在的表名。
mysql_free_result(mysql_query($sql))
函數釋放結果內存。
mysql_get_client_info()
函數返回
MySQL
客戶端信息。
mysql_get_host_info()
取得
MySQL
主機信息。

⑦ php中mysql加鎖問題

有表鎖,行鎖,頁鎖

頁級:引擎 BDB。
表級:引擎 MyISAM , 理解為鎖住整個表,可以同時讀,寫不行
行級:引擎 INNODB , 單獨的一行記錄加鎖

1) 表級鎖:開銷小,加鎖快;不會出現死鎖;鎖定粒度大,發生鎖沖突的概率最高,並發度最低。
2) 行級鎖:開銷大,加鎖慢;會出現死鎖;鎖定粒度最小,發生鎖沖突的概率最低,並發度也最高。
3) 頁面鎖:開銷和加鎖時間界於表鎖和行鎖之間;會出現死鎖;鎖定粒度界於表鎖和行鎖之間,並發度一般。

一般不在PHP中使用鎖操作,因為如果鎖了庫,如果遇到錯誤沒有及時的解鎖,就會導致不能訪問數據的情況。

可以使用MYSQL的事務,就是定義事務開始,然後有幾個語句要執行,然後根據情況,如果有一個語句沒有執行成功,可以回滾(取消這幾個語句的執行),從而達到幾個語句都執行成功或者都不執行的效果,在強事務型的應用中一般使用這個方式
你可以去後盾人平台看看,裡面的東西不錯

⑧ 開發php網站,mysql做資料庫一定要用鎖嗎

一般情況下,MYSQL在更新操作會自動加表鎖。不需要顯式加鎖。除非是數據要求嚴格的邏輯寫順序。
執行查詢語句(SELECT)前,會自動給涉及的所有表加讀鎖,在執行更新操作 (UPDATE、DELETE、INSERT等)前,會自動給涉及的表加寫鎖,這個過程並不需要用戶干預,因此,用戶一般不需要直接用LOCK TABLE命令給MyISAM表顯式加鎖。

⑨ mysql備份方案有哪些有什麼缺點

1、mysqlmp,mysql自帶的備份,每日業務低峰期全備一次,備份完未壓縮前大小10G-50G不等,不管mysql多大,這個備份最好每日都備份一次,選擇業務最不忙的時候,例如凌晨3、4點鍾。不建議每天備份若干次,因為備份時間長,期間佔用資源比較高
2、xtrabackup,第三方percona公司出的全備+增量備份工具,根據你業務特徵,如果需要恢復級別很高。例如只允許丟失半小時數據,那麼就凌晨全備,之後都在前一個備份的基礎上進行增量備份。對於innodb引擎表不會鎖表,且增量備份時間短且佔用系統資源不高,且可以實現相對實時的備份,所以還是很實用的mysql備份工具的。具體內容你上perocona官網周到xtrabackup文檔好好閱讀下,不是很多內容,很快能讀完的。答案摘自希賽系統學院

⑩ php mysql的鎖機制 怎麼寫

MYSQL中的鎖:
語法 :
LOCK TABLE 表名1 READ|WRITE, 表名2 READ|WRITE .................. 【鎖表】
UNLOCK TABLES 【釋放表】

Read:讀鎖|共享鎖 : 所有的客戶端只能讀這個表不能寫這個表
Write:寫鎖|排它鎖: 所有當前鎖定客戶端可以操作這個表,其他客戶端只能阻塞
注意:在鎖表的過程中只能操作被鎖定的表,如果要操作其他表,必須把所有要操作的表都鎖定起來!

PHP中的文件鎖 (鎖的是文件,不是表)
文件鎖的文件與表有什麼關系?:一點關系也沒有,與令牌相似,誰拿到誰操作。所以表根本沒鎖。
測試時,有個文件就行,叫什麼名無所謂

閱讀全文

與phpmysql鎖表相關的資料

熱點內容
海南免稅溯源碼怎麼查 瀏覽:979
蘋果系統轉換安卓系統有什麼麻煩 瀏覽:692
pdf如何拆分成多個pdf 瀏覽:109
廣西dns聯通伺服器地址大全 瀏覽:500
問道端游下載了忘了在哪個文件夾 瀏覽:251
開源phpoa框架 瀏覽:293
惠普511類似文件夾圖標閃動 瀏覽:53
php通訊錄系統 瀏覽:73
javajar包maven 瀏覽:108
仿圖怪獸安卓源碼 瀏覽:977
程序員越來越困 瀏覽:865
女朋友java程序員 瀏覽:338
魔獸世界加密貨幣 瀏覽:783
程序員打卡日記 瀏覽:766
車間壓縮空氣有水怎麼處理 瀏覽:835
java類調用php 瀏覽:476
php時間控制 瀏覽:808
用流程圖表示演算法分類 瀏覽:931
本地git文件夾誤刪除怎麼恢復 瀏覽:748
java快速開發平台開源 瀏覽:996