真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

php數(shù)據(jù)庫(kù)sql php數(shù)據(jù)庫(kù)連接失敗的原因

PHP怎樣連接Sql Server數(shù)據(jù)庫(kù)

我用的php版本是php5.6.12,mssql數(shù)據(jù)庫(kù)版本為2008

創(chuàng)新互聯(lián)是一家專注于網(wǎng)站設(shè)計(jì)制作、網(wǎng)站制作與策劃設(shè)計(jì),陵水黎族網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)十多年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:陵水黎族等地區(qū)。陵水黎族做網(wǎng)站價(jià)格咨詢:18982081108

兩種途徑:

1、直接連接

$servname="captainhero567";

$conninfo=array(

"database"="netdata",

"uid"="lxz2005",

"pwd"="831140");

$conn=sqlsrv_connect($servname,

$conninfo);

$sql="select

*

from

pinfo";

$db=sqlsrv_query($conn,

$sql);

while($row=sqlsrv_fetch_array($db))

{

echo("

".iconv("gb2312","utf-8",$row["pname"])."

");

}

2、使用pdo抽象數(shù)據(jù)層連接

$hostname

=

"192.168.1.100";

$dbname

=

"northwind";

$username

=

"sa";

$pwd

=

"pwd100";

$dsn="sqlsrv:server=$hostname;database=$dbname";

$conn

=

new

pdo

($dsn,$username,$pwd);

$conn-setattribute(pdo::attr_errmode,pdo::errmode_exception);

echo

"mssql

database

connnection

sucessed!";

php中的sql語(yǔ)句

1、很多時(shí)候我們?cè)陂_(kāi)發(fā)時(shí)需要將字符串與變量連接起來(lái)顯示,在PHP中,字符串之間使用 “點(diǎn)” 來(lái)連接,也就是英文中的半角句號(hào)?" . " ,? " . " 是字符串連接符,可以把兩個(gè)或兩個(gè)以上的字符串鏈接成一個(gè)字符串。例如:

?php

$name?=?"百度知道:";

$url?=??"zhidao.baidu";

echo?$name.$url.".com";

?

輸出結(jié)果為:

百度知道:zhidao.baidu.com

2、php在進(jìn)行數(shù)據(jù)庫(kù)查詢時(shí),如果對(duì)象是字符串,則需要使用引號(hào)將字符串區(qū)分開(kāi),這就是上面你的第一個(gè)問(wèn)題,例如,你通過(guò)POST接受到的$username值是"zhanagsan",那么:

mysqli_query($conn,"SELECT?*?FROM?user?Where?username?=?'".$username."'");

php在進(jìn)行解析時(shí)就是

mysqli_query($conn,"SELECT?*?FROM?user?Where?username?=?'zhangsan'");

如果你覺(jué)得這樣會(huì)讓你有點(diǎn)看不過(guò)來(lái),還可以這樣寫:

mysqli_query($conn,"SELECT?*?FROM?user?Where?username?=?'{$username}'");

這里的{}也是起到連接的作用。

3、應(yīng)用字符串連接符號(hào)有時(shí)候沒(méi)有辦法實(shí)現(xiàn)大量字符串的連接,PHP允許程序員在雙引號(hào)中直接包含字符串變量,當(dāng)echo語(yǔ)句后面使用的是 雙引號(hào) (" ")時(shí),可以使用下面的格式來(lái)達(dá)到相同的效果(這是你的第二個(gè)問(wèn)題)。例如:

?php

$name?=?"百度知道:";

$url?=??"zhidao.baidu";

echo?"$name$url.com";?//?雙引號(hào)里的變量同一般的字符串自動(dòng)進(jìn)行區(qū)分

?

但是單引號(hào)(' ')就不可以了,這樣如果不加連接符,解析后還是字符串,例如:

?php

$name?=?"百度知道:";

$url?=??"zhidao.baidu";

echo?'$name$url.com';?//?單引號(hào)里的變量不會(huì)同一般的字符串自動(dòng)進(jìn)行區(qū)分

?

最終的輸出結(jié)果就變成了

$name$url.com???//最終只是輸出變量名,是字符串

php連接mssql數(shù)據(jù)庫(kù)的幾種方式

hp連接mssql數(shù)據(jù)庫(kù)有幾個(gè)注意事項(xiàng),尤其mssql的多個(gè)版本、32位、64位都有區(qū)別。

首先,php.ini文件中;extension=php_pdo_mssql.dll

;extension=php_pdo_odbc.dll

前面的分號(hào)去掉,對(duì)應(yīng)的使哪種方式連接mssql。注意要重啟服務(wù)使其生效。

一、建立連接

1、odbc

首先,在php程序所在的服務(wù)器設(shè)置odbc。這里32位和64位操作系統(tǒng)有區(qū)別。32位的從控制面板中管理工具中的數(shù)據(jù)源(odbc)直接建立就可以了,64位的要運(yùn)行C:\Windows\SysWOW64\odbcad32.exe

從這里面設(shè)置。注意:上面只的是數(shù)據(jù)庫(kù)服務(wù)器為32為的,數(shù)據(jù)源設(shè)置服務(wù)器為32位和64位兩種的情況。只要兩個(gè)服務(wù)器建立的數(shù)據(jù)源位數(shù)一致就好。

下面是odbc建立連接代碼。

$con

=

odbc_connect('odbc名稱','用戶名','密碼');

2、連接mssql2000

$con

=

mssql_connect('數(shù)據(jù)庫(kù)地址','用戶名','密碼');

3、連接mssql2008

$connectionInfo

=

array("UID"=用戶名,"PWD"=密碼,"Database"="數(shù)據(jù)庫(kù)名稱");

$con

=

sqlsrv_connect(

數(shù)據(jù)庫(kù)地址,$connectionInfo);

二、輸入查詢代碼

這個(gè)都一樣,可以直接寫入,也可以從mssql中驗(yàn)證好后復(fù)制過(guò)來(lái)。簡(jiǎn)單點(diǎn)說(shuō)就是把一個(gè)sql語(yǔ)句賦值給一個(gè)變量。

類似下面代碼

$query

=

"SELECT

top

12

*

數(shù)據(jù)庫(kù)名稱

order

by

id

desc";

三、建立查詢并取出數(shù)據(jù)

1、odbc

$result

=

odbc_do($con,$query);

while(odbc_fetch_row($result))

{

$變量名稱

=

odbc_result($result,

"字段名稱");

}

2、連接mssql2000

$result

=

mssql_query($con,

$query);

while($row

=mssql_fetch_array($result))

{

$變量名稱

=

$row["字段名稱"];

}

3、連接mssql2008

$result

=

sqlsrv_query($con,

$query);

while($row

=

sqlsrv_fetch_array($result))

{

$變量名稱

=

$row["字段名稱"];

}

在php5.3及以后的版本中不附帶sqlsrv庫(kù)了。所以要從微軟這里下載。

四、關(guān)閉連接

這個(gè)沒(méi)有什么區(qū)別,分別是odbc_close();和mssql_close()和sqlsrv_close();

怎樣用PHP連接sql數(shù)據(jù)庫(kù)

1、學(xué)習(xí)的方法,最好是看手冊(cè)

在前一篇文章中涉及到了連接數(shù)據(jù)庫(kù)sqlsrv_connect();還記得我們mysql連接數(shù)據(jù)庫(kù)的時(shí)候也是mysql_connect();兩者操作數(shù)據(jù)庫(kù)是很相似的。從零基礎(chǔ)開(kāi)始學(xué)起的話,只能是查閱手冊(cè)。查看一下sqlsrv有哪些函數(shù)提供我們使用!推薦網(wǎng)址是:

【注意】很多的方法都跟mysql提供的方法很相似,看到后面的函數(shù)名就大概知道里面的用法,比如說(shuō)mysql執(zhí)行sql語(yǔ)句的時(shí)候調(diào)用mysql_query();而sqlserver執(zhí)行sql語(yǔ)句的時(shí)候調(diào)用也是sqlsrv_query(),但是特別注意一點(diǎn)就是,它們的傳遞參數(shù)不一樣。詳細(xì)的只能看一下手冊(cè)。接下來(lái)我簡(jiǎn)單總結(jié)一下操作數(shù)據(jù)的方法

2、連接數(shù)據(jù)庫(kù)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ù)庫(kù)

1)執(zhí)行sql語(yǔ)句sqlsrv_query(),返回值為true或者false,這里函數(shù)的用法跟mysql_query(),不一樣。它需要把連接的資源句柄當(dāng)作參數(shù)傳進(jìn)去,看源碼。資源句柄就是上面代碼連接數(shù)據(jù)庫(kù)的“$conn”。

$sql = "select * from test1"; ? //sql語(yǔ)句$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 ?

//以對(duì)象形式檢索下一行的數(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ù)庫(kù)發(fā)生錯(cuò)誤,都可以使用這個(gè)函數(shù)打印出來(lái)看一下壓

這里就不用上代碼了


網(wǎng)頁(yè)標(biāo)題:php數(shù)據(jù)庫(kù)sql php數(shù)據(jù)庫(kù)連接失敗的原因
文章URL:http://weahome.cn/article/dojeohs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部