if($result2[stock]==0)
創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的阿壩州網(wǎng)站設(shè)計(jì)、移動媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
改成
if($result2['stock']==0)
另外
$bookid=$result[id];
改成
$bookid=$result['id'];
如果還解決不了問題。弊鄭高
你把sql語句打印出來,在庫里執(zhí)行下比對下結(jié)果,就租尺明白了。
echo "select stock from tb_bookinfo where id='$bookid'";
然后看看結(jié)果到底是什么,我就不信你查出來的會叢悔和程序不同步。
1、學(xué)習(xí)的方法,最好是看手冊
在前一篇文章中涉及到了連接數(shù)據(jù)庫sqlsrv_connect();還記得我們mysql連接數(shù)據(jù)庫的時(shí)候也是mysql_connect();兩者操作數(shù)據(jù)庫是很相似的。從零基礎(chǔ)開始學(xué)起的話,只能是查閱手冊。查看一下sqlsrv有哪些函數(shù)提供我們使用!推薦網(wǎng)址是:
【注意】很多的方法都跟mysql提供的方法很相似,看到后面的函數(shù)名就大概知道里面的用法,比如說mysql執(zhí)行sql語句的時(shí)候調(diào)用mysql_query();而sqlserver執(zhí)行sql語句的時(shí)候調(diào)用也是sqlsrv_query(),但是特別注意一點(diǎn)就是,它們的傳遞參數(shù)不一樣。詳細(xì)的只能看一下手冊。接下來我簡單總結(jié)一下操作數(shù)據(jù)的方法
2、連接數(shù)據(jù)庫sqlsrv_connect()
?php$serverName = "serverName\sqlexpress";//服務(wù)器的名字,本地localhost$connectionInfo = array( "Database"="dbName"沒敏, "UID"="userName", "PWD"="password");$conn = sqlsrv_connect( $serverName, $connectionInfo);if( $conn ) { ? ? echo "Connection established.br /";
}else{ ? ? echo "Connection could not be established.br /"; ? ? die( print_r( sqlsrv_errors(), true));
}
3、操作數(shù)據(jù)庫
1)執(zhí)行sql語句sqlsrv_query(),返回值為true或者false,這里函數(shù)的用法跟mysql_query(),不一樣。它需要把連接的資源句柄當(dāng)作參數(shù)傳進(jìn)去,看源碼。資源句柄就是上面代碼連接數(shù)據(jù)庫的“$conn”。
$sql = "select * from test1"; ? //sql語句$data = sqlsrv_query($conn,$sql); ?//$conn資源句柄if($data == true){ ? ?die("執(zhí)行成功");
}else{ ? ?die("執(zhí)行失敗");
}
2)獲取結(jié)果集
//以數(shù)值索引數(shù)組、關(guān)聯(lián)數(shù)組或這兩種數(shù)組的形式檢索下一行的鄭伍數(shù)據(jù)。類似于mysql_fetch_arraysqlsrv_fetch_array ?
//以對象形式檢索下一行的數(shù)據(jù)。sqlsrv_fetch_object 1234
$sql = "select * from test1";$data = sqlsrv_query($conn,$sql);if($data == true){ ? ?while($row = sqlsrv_fetch_array( $data, SQLSRV_FETCH_ASSOC) ) { ? ? ? ? ?echo $row['id'].", ".$row['name']."br /";
}else{ ? ? ? ? die( print_r( sqlsrv_errors(), true));
}
}
$sql = "SELECT fName, lName FROM Table_1";$stmt = sqlsrv_query( $conn, $sql);if( $stmt === false ) { ? ? die( print_r( sqlsrv_errors(), true));
}while( $obj = sqlsrv_fetch_object( $stmt)) { ? ? ?echo $obj-fName.", ".$obj-lName."br /";
}
3)顯示錯(cuò)誤信息sqlsrv_errors():上面都有用到這個(gè)函數(shù),只要是操作數(shù)據(jù)庫發(fā)生錯(cuò)誤,都可喊察或以使用這個(gè)函數(shù)打印出來看一下壓
這里就不用上代碼了
if(!empty($row[1])){
//$row[1]不為空的話,則怎么怎么樣
}else{
//$row[1]為空的話,則怎么怎么樣
}
不要用!$row[1]這樣判斷,$row[1]并不是一個(gè)布爾值,所以一定為false
你說得我不太明白:
你說碧卜信:“如果我弊氏要判讀$row[1]的數(shù)據(jù)是否在數(shù)據(jù)庫里面查到了沒 應(yīng)該怎么判斷 ”
是判悔輪斷外部傳進(jìn)來的數(shù)據(jù)是否和數(shù)據(jù)表中對應(yīng)的字段匹配是嗎?
簡單的舉例一下:
還是用if來判斷
if(in_array($_POST[1],$row)){
}