一、mysql中,replace into后怎么連接where子句
REPLACE INTO?語法完全?與?INSERT INTO?一樣工作,只是在新行已插入。
這意味著您應該將主鍵添加到被替換的值中,而不是?WHERE?子句以限制更新。
REPLACE INTO myTable (
? myPrimaryKey,
? myColumn1,
? myColumn2
) VALUES (
? 100,
? ‘value1’,
? ‘value2’
);
…將提供與…相同的結果
UPDATE myTable
SET myColumn1 = ‘value1’, myColumn2 = ‘value2’
WHERE myPrimaryKey = 100;
…或更準確地說:
DELETE FROM myTable WHERE myPrimaryKey = 100;
INSERT INTO myTable(
? myPrimaryKey,
? myColumn1,
? myColumn2
) VALUES (
? 100,
? ‘value1’,
? ‘value2’
);
replace into語句會根據少數鍵/主鍵刪除原有的一條記錄, 并且插入一條新的記錄來替換原記錄。如果沒有表不存在少數鍵/主鍵 或者 插入的數據少數鍵/主鍵沒有重復的,那么會新增一條記錄。
新建一個test表,三個字段,uid,name,mobile, id是自增的主鍵,mobile是少數索引;
create table test(
??? uid int(11) NOT NULL AUTO_INCREMENT,
??? name varchar(50),
??? mobile varchar(11) unique,
??? PRIMARY KEY (uid)
);
#插入兩條數據進行演示
insert into? test(name,mobile) VALUES (‘張三’,’135′);
insert into? test(name,mobile) VALUES (‘李四’,’137′);
延伸閱讀:
二、為什么要持久化連接
這和 web 服務器的工作方式有關。web 服務器可以通過三種方法來利用 PHP 生成 web 頁面。
名列前茅種方法是將 PHP 自以為 CGI“包裝器”用作一個單獨運行的語言解釋器(CGI Wapper)。當以這種方法運行時,PHP 會為向 web 服務器的每個 PHP 頁面請求創建并銷毀 PHP 解釋器的時候實例。由于其會隨每個請求的結束而銷毀,因此其獲取的任何資源(例如指向 SQL 數據庫服務器的鏈接)都會在銷毀時關閉。在這種情況下,不會從使用持久連接中獲得任何好處——因為根本不會持久。
第二,也是最流行的方法是把 PHP 用作多進程 web 服務器的一個模塊,這種方法目前只適用于 Apache。多進程的服務器通常有一個父進程和一組子進程協調運行,子進程負責提供網頁的工作。每當接收達到客戶端提出請求時,該請求會傳遞給尚未給其它客戶端提供服務的某個子進程。這也就是說當相同的客戶端第二次向服務端發出請求時,它將有可能由與名列前茅次不同的某個子進程提供服務。在開啟了一個持久連接后,所有請求 SQL 服務的后繼頁面都能夠重用與 SQL 服務器建立的相同連接。
最后一種方法是將 PHP 用作多線程 web 服務器的插件。目前 PHP 支持 WSAPI 和 NSAPI(在 Windows 上),允許 PHP 作為 Netscape FastTrack(iPlanet)、Microsoft 的 Internet Information Server (IIS) 和 O’Reilly 的 WebSite Pro 等多線程服務器的插件使用。該行為與前面描述的多過程模型相同。