在mysql數(shù)據(jù)庫中,創(chuàng)建一個(gè)test數(shù)據(jù)庫,用于測(cè)試。
創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比晉城網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式晉城網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋晉城地區(qū)。費(fèi)用合理售后完善,十年實(shí)體公司更值得信賴。
請(qǐng)點(diǎn)擊輸入圖片描述
新建一個(gè)php文件,命名為test.php,用于講解php如何選擇要操作的數(shù)據(jù)庫。
請(qǐng)點(diǎn)擊輸入圖片描述
在test.php文件中,使用header()方法將頁面的編碼格式設(shè)置為utf-8,避免輸出中文亂碼。
請(qǐng)點(diǎn)擊輸入圖片描述
在test.php文件中,使用mysql_connect()函數(shù),通過賬號(hào)和密碼創(chuàng)建一個(gè)數(shù)據(jù)庫的連接。
請(qǐng)點(diǎn)擊輸入圖片描述
在test.php文件中,再使用mysql_select_db()函數(shù)選擇要操作的數(shù)據(jù)庫test,選擇數(shù)據(jù)庫成功,則返回true,否則,返回false。最后,通過if語句判斷結(jié)果。
請(qǐng)點(diǎn)擊輸入圖片描述
在瀏覽器打開test.php文件,查看結(jié)果。
請(qǐng)點(diǎn)擊輸入圖片描述
END
總結(jié):
1、創(chuàng)建一個(gè)test數(shù)據(jù)庫。
2、使用mysql_connect()函數(shù)創(chuàng)建一個(gè)數(shù)據(jù)庫的連接。
3、再使用mysql_select_db()函數(shù)選擇要操作的數(shù)據(jù)庫test,并通過if語句判斷結(jié)果。
你這些語句都不是選擇數(shù)據(jù)庫的,標(biāo)題好像不合適:)
明明那么多句,你問這句話是什么意思,你究竟是指的哪句:)
言歸正傳,你的程序段是一般數(shù)據(jù)庫操作的基本模板,學(xué)懂了這幾句以后寫什么數(shù)據(jù)庫操作都不難了,我把你這些語句一一注釋一下:
$sql="select sum(num) as total_num from vote";
//這一句第一層意思從PHP角度理解,就是定義一個(gè)字符串變量,值是引號(hào)里面的那些,無論那些字符串是什么命令,此時(shí)僅僅是賦值,并不運(yùn)行
//從MYSQL的角度理解,這是一個(gè)數(shù)據(jù)庫命令,獲取數(shù)據(jù)庫里面vote表的記錄數(shù)量,并作為名total_num返回
$result=mysql_query($sql);
//這一句讓MYSQL數(shù)據(jù)庫運(yùn)行變量$sql里面的語句,結(jié)果存入$result中
$myarray=mysql_fetch_array($result);
//這一句獲取執(zhí)行結(jié)果$result里面的一行返回?cái)?shù)據(jù),取到數(shù)組$myarray中
$total_num=$myarray["total_num"];
//這一句把數(shù)組變量$myarray里面名字叫做total_num的元素賦給變量$total_num
1、redis 中的每一個(gè)數(shù)據(jù)庫,都由一個(gè) redisDb 的結(jié)構(gòu)存儲(chǔ)。其中,redisDb.id 存儲(chǔ)著 redis 數(shù)據(jù)庫以整數(shù)表示的號(hào)碼。redisDb.dict 存儲(chǔ)著該庫所有的鍵值對(duì)數(shù)據(jù)。redisDb.expires 保存著每一個(gè)鍵的過期時(shí)間。
2、當(dāng)redis 服務(wù)器初始化時(shí),會(huì)預(yù)先分配 16 個(gè)數(shù)據(jù)庫(該數(shù)量可以通過配置文件配置),所有數(shù)據(jù)庫保存到結(jié)構(gòu) redisServer 的一個(gè)成員 redisServer.db 數(shù)組中。當(dāng)我們選擇數(shù)據(jù)庫 select number 時(shí),程序直接通過 redisServer.db[number] 來切換數(shù)據(jù)庫。有時(shí)候當(dāng)程序需要知道自己是在哪個(gè)數(shù)據(jù)庫時(shí),直接讀取 redisDb.id 即可。
3、既然我們知道一個(gè)數(shù)據(jù)庫的所有鍵值都存儲(chǔ)在redisDb.dict中,那么我們要知道如果找到key的位置,就有必要了解一下dict 的結(jié)構(gòu)了:
typedef struct dict {
// 特定于類型的處理函數(shù)
dictType *type;
// 類型處理函數(shù)的私有數(shù)據(jù)
void *privdata;
// 哈希表(2個(gè))
dictht ht[2];
// 記錄 rehash 進(jìn)度的標(biāo)志,值為-1 表示 rehash 未進(jìn)行
int rehashidx;
// 當(dāng)前正在運(yùn)作的安全迭代器數(shù)量
int iterators;
} dict;
由上述的結(jié)構(gòu)可以看出,redis 的字典使用哈希表作為其底層實(shí)現(xiàn)。dict 類型使用的兩個(gè)指向哈希表的指針,其中 0 號(hào)哈希表(ht[0])主要用于存儲(chǔ)數(shù)據(jù)庫的所有鍵值,而1號(hào)哈希表主要用于程序?qū)?0 號(hào)哈希表進(jìn)行 rehash 時(shí)使用,rehash 一般是在添加新值時(shí)會(huì)觸發(fā),這里不做過多的贅述。所以redis 中查找一個(gè)key,其實(shí)就是對(duì)進(jìn)行該dict 結(jié)構(gòu)中的 ht[0] 進(jìn)行查找操作。
4、既然是哈希,那么我們知道就會(huì)有哈希碰撞,那么當(dāng)多個(gè)鍵哈希之后為同一個(gè)值怎么辦呢?redis采取鏈表的方式來存儲(chǔ)多個(gè)哈希碰撞的鍵。也就是說,當(dāng)根據(jù)key的哈希值找到該列表后,如果列表的長(zhǎng)度大于1,那么我們需要遍歷該鏈表來找到我們所查找的key。當(dāng)然,一般情況下鏈表長(zhǎng)度都為是1,所以時(shí)間復(fù)雜度可看作o(1)。
二、當(dāng)redis 拿到一個(gè)key 時(shí),如果找到該key的位置。
了解了上述知識(shí)之后,我們就可以來分析redis如果在內(nèi)存找到一個(gè)key了。
1、當(dāng)拿到一個(gè)key后, redis 先判斷當(dāng)前庫的0號(hào)哈希表是否為空,即:if (dict-ht[0].size == 0)。如果為true直接返回NULL。
2、判斷該0號(hào)哈希表是否需要rehash,因?yàn)槿绻谶M(jìn)行rehash,那么兩個(gè)表中者有可能存儲(chǔ)該key。如果正在進(jìn)行rehash,將調(diào)用一次_dictRehashStep方法,_dictRehashStep 用于對(duì)數(shù)據(jù)庫字典、以及哈希鍵的字典進(jìn)行被動(dòng) rehash,這里不作贅述。
3、計(jì)算哈希表,根據(jù)當(dāng)前字典與key進(jìn)行哈希值的計(jì)算。
4、根據(jù)哈希值與當(dāng)前字典計(jì)算哈希表的索引值。
5、根據(jù)索引值在哈希表中取出鏈表,遍歷該鏈表找到key的位置。一般情況,該鏈表長(zhǎng)度為1。
6、當(dāng) ht[0] 查找完了之后,再進(jìn)行了次rehash判斷,如果未在rehashing,則直接結(jié)束,否則對(duì)ht[1]重復(fù)345步驟。
到此我們就找到了key在內(nèi)存中的位置了。
這是數(shù)據(jù)庫的基本常用語句之一,$link =mysql_connect("localhost","root","");
mysql_select_db("aaa", $link); 譬如這一句,括號(hào)里的是數(shù)據(jù)庫(aaa),$link
就是執(zhí)行第一句的鏈接到aaa數(shù)據(jù)庫里面,通過select語句查詢出數(shù)據(jù)庫當(dāng)中的參數(shù),然后進(jìn)行根據(jù)你以后的命令具體處理。
當(dāng)然如果你喜歡,變量名隨意改換!
基本的意思就是這樣,好好體會(huì)一下吧!祝你成功!