中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

php調(diào)用數(shù)據(jù)庫函數(shù) php 調(diào)用函數(shù)

php 在自定義函數(shù)中 能直接使用數(shù)據(jù)庫函數(shù)不?

完全可以;

創(chuàng)新互聯(lián)專注于中大型企業(yè)的網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計和網(wǎng)站改版、網(wǎng)站營銷服務(wù),追求商業(yè)策劃與數(shù)據(jù)分析、創(chuàng)意藝術(shù)與技術(shù)開發(fā)的融合,累計客戶1000多家,服務(wù)滿意度達97%。幫助廣大客戶順利對接上互聯(lián)網(wǎng)浪潮,準(zhǔn)確優(yōu)選出符合自己需要的互聯(lián)網(wǎng)運用,我們將一直專注品牌網(wǎng)站建設(shè)和互聯(lián)網(wǎng)程序開發(fā),在前進的路上,與客戶一起成長!

$conn = mysql_connect('主機','用戶','密碼');

mysql_select_db('數(shù)據(jù)庫名', $conn);

$rs = mysql_query('select 字段 from 表 limit 1;');

$row = mysql_fetch_array($rs);

echo $row['字段'];

Php數(shù)據(jù)庫和函數(shù)問題

這兩個函數(shù)功能完全不同:

mysql_affected_rows 取得前一次 MySQL 操作所影響的記錄行數(shù),操作是指INSERT、UPDATE、DELETE等,影響是指修改、變化的。如果函數(shù)失敗,返回值是-1。此函數(shù)參數(shù)為連接ID,也可以不要參數(shù)(當(dāng)前默認(rèn)的連接)。

mysql_num_rows()返回結(jié)果集中行的數(shù)目,僅對 SELECT 語句有效。注意其參數(shù)是mysql_query返回的結(jié)果集ID。

php引用函數(shù)的使用方法

php引用函數(shù)的使用方法

在技術(shù)學(xué)習(xí)的道路上,能掌握一些有用的技巧,對于初學(xué)者是非常有幫助的,下面是php引用函數(shù)的使用方法,希望大家會喜歡。

1.不要在你的應(yīng)用程序中g(shù)zip輸出,讓apache來做

考慮使用ob_gzhandler?不,別這樣做。它沒有任何意義。PHP應(yīng)該是來寫應(yīng)用程序的。不要擔(dān)心PHP中有關(guān)如何優(yōu)化在服務(wù)器和瀏覽器之間傳輸?shù)臄?shù)據(jù)。

使用apache mod_gzip/mod_deflate通過.htaccess文件壓縮內(nèi)容。

2.從php echo javascript代碼時使用json_encode

有些時候一些JavaScript代碼是從php動態(tài)生成的。

$images = array( 'myself.png' , 'friends.png' , 'colleagues.png');

$js_code = '';foreach($images as $image)

{

$js_code .= "'$image' ,";

}

$js_code = 'var images = [' . $js_code . ']; ';echo $js_code;//Output is var images = ['myself.png' ,'friends.png' ,'colleagues.png' ,];

放聰明點。使用json_encode:

$images = array( 'myself.png' , 'friends.png' , 'colleagues.png');

$js_code = 'var images = ' . json_encode($images);

echo $js_code;//Output is : var images = ["myself.png","friends.png","colleagues.png"]

這不是很整潔?

3.在寫入任何文件之前檢查目錄是否可寫

在寫入或保存任何文件之前,請務(wù)必要檢查該目錄是否是可寫的,如果不可寫的話,會閃爍錯誤消息。這將節(jié)省你大量的“調(diào)試”時間。當(dāng)你工作于Linux時,權(quán)限是必須要處理的,并且會有很多很多的權(quán)限問題時,當(dāng)目錄不可寫,文件無法讀取等的時候。

請確保你的應(yīng)用程序盡可能智能化,并在最短的時間內(nèi)報告最重要的信息。

$contents = "All the content";

$file_path = "/var/www/project/content.txt";

file_put_contents($file_path , $contents);

這完全正確。但有一些間接的問題。file_put_contents可能會因為一些原因而失?。?/p>

父目錄不存在

目錄存在,但不可寫

鎖定文件用于寫入?

因此,在寫入文件之前最好能夠一切都弄明確。

$contents = "All the content";

$dir = '/var/www/project';

$file_path = $dir . "/content.txt";if(is_writable($dir))

{

file_put_contents($file_path , $contents);

}else{ ? ?die("Directory $dir is not writable, or does not exist. Please check");

}

通過這樣做,你就能得到哪里文件寫入失敗以及為什么失敗的準(zhǔn)確信息。

4.改變應(yīng)用程序創(chuàng)建的文件的權(quán)限

當(dāng)在Linux環(huán)境下工作時,權(quán)限處理會浪費你很多時間。因此,只要你的php應(yīng)用程序創(chuàng)建了一些文件,那就應(yīng)該修改它們的權(quán)限以確保它們在外面“平易近人”。否則,例如,文件是由“php”用戶創(chuàng)建的,而你作為一個不同的用戶,系統(tǒng)就不會讓你訪問或打開文件,然后你必須努力獲得root權(quán)限,更改文件權(quán)限等等。

// Read and write for owner, read for everybody elsechmod("/somedir/somefile", 0644);// Everything for owner, read and execute for otherschmod("/somedir/somefile", 0755);

5.不要檢查提交按鈕值來檢查表單提交

if($_POST['submit'] == 'Save')

{ ? ?//Save the things}

以上代碼在大多數(shù)時候是正確的,除了應(yīng)用程序使用多語言的情況。然后“Save”可以是很多不同的東西。那么你該如何再做比較?所以不能依靠提交按鈕的值。相反,使用這個:

if( $_SERVER['REQUEST_METHOD'] == 'POST' and isset($_POST['submit']) )

{ ? ?//Save the things}

現(xiàn)在你就可以擺脫提交按鈕的值了。

6.在函數(shù)中總是有相同值的地方使用靜態(tài)變量

//Delay for some timefunction delay(){

$sync_delay = get_option('sync_delay'); ? ?echo "

Delaying for $sync_delay seconds...";

sleep($sync_delay); ? ?echo "Done

";

}

相反,使用靜態(tài)變量:

//Delay for some timefunction delay(){ ? ?static $sync_delay = null; ? ?if($sync_delay == null)

{

$sync_delay = get_option('sync_delay');

} ? ?echo "

Delaying for $sync_delay seconds...";

sleep($sync_delay); ? ?echo "Done

";

}

7.不要直接使用$ _SESSION變量

一些簡單的例子是:

$_SESSION['username'] = $username;

$username = $_SESSION['username'];

但是這有一個問題。如果你正在相同域中運行多個應(yīng)用程序,會話變量會發(fā)生沖突。2個不同的應(yīng)用程序在會話變量中可能會設(shè)置相同的鍵名。舉個例子,一個相同域的前端門戶和后臺管理應(yīng)用程序。

因此,用包裝函數(shù)使用應(yīng)用程序特定鍵:

define('APP_ID' , 'abc_corp_ecommerce');//Function to get a session variablefunction session_get($key){

$k = APP_ID . '.' . $key; ? ?if(isset($_SESSION[$k]))

{ ? ? ? ?return $_SESSION[$k];

} ? ?return false;

}//Function set the session variablefunction session_set($key , $value){

$k = APP_ID . '.' . $key;

$_SESSION[$k] = $value; ? ?return true;

}

8.封裝實用輔助函數(shù)到一個類中

所以,你必須在一個文件中有很多實用函數(shù):

function utility_a(){ ? ?//This function does a utility thing like string processing}function utility_b(){ ? ?//This function does nother utility thing like database processing}function utility_c(){ ? ?//This function is ...}

自由地在應(yīng)用程序中使用函數(shù)。那么你或許想要將它們包裝成一個類作為靜態(tài)函數(shù):

class Utility{ ? ?public static function utility_a()

{

} ? ?public static function utility_b()

{

} ? ?public static function utility_c()

{

}

}//and call them as $a = Utility::utility_a();

$b = Utility::utility_b();

這里你可以得到的一個明顯好處是,如果php有相似名稱的內(nèi)置函數(shù),那么名稱不會發(fā)生沖突。

從另一個角度看,你可以在相同的應(yīng)用程序中保持多個版本的相同類,而不會發(fā)生任何沖突。因為它被封裝了,就是這樣。

9.一些傻瓜式技巧

使用echo代替print

使用str_replace代替preg_replace,除非你確定需要它

不要使用short tags

對于簡單的'字符串使用單引號代替雙引號

在header重定向之后要記得做一個exit

千萬不要把函數(shù)調(diào)用放到for循環(huán)控制行中。

isset比strlen快

正確和一致地格式化你的代碼

不要丟失循環(huán)或if-else塊的括號。

不要寫這樣的代碼:

if($a == true) $a_count++;

這絕對是一種浪費。

這樣寫

if($a == true)

{

$a_count++;

}

不要通過吃掉語法縮短你的代碼。而是要讓你的邏輯更簡短。使用具有代碼高亮功能的文本編輯器。代碼高亮有助于減少錯誤。

10. 使用array_map快速處理數(shù)組

比方說,你要trim一個數(shù)組的所有元素。新手會這樣做:

foreach($arr as $c = $v)

{

$arr[$c] = trim($v);

}

但它可以使用array_map變得更整潔:

$arr = array_map('trim' , $arr);

這適用于trim數(shù)組$arr的所有元素。另一個類似的函數(shù)是array_walk。

11.使用php過濾器驗證數(shù)據(jù)

你是不是使用正則表達式來驗證如電子郵件,IP地址等值?是的,每個人都是這樣做的?,F(xiàn)在,讓我們試試一個不同的東西,那就是過濾器。

php過濾器擴展程序?qū)⑻峁┖唵蔚姆椒▉碛行炞C或校驗值。

12.強制類型檢查

$amount = intval( $_GET['amount'] );

$rate = (int) $_GET['rate'];

這是一種好習(xí)慣。

13.使用set_error_handler()將Php錯誤寫入到文件

set_error_handler()可以用來設(shè)置自定義的錯誤處理程序。在文件中編寫一些重要的錯誤用于日志是個好主意。

14.小心處理大型數(shù)組

大型的數(shù)組或字符串,如果一個變量保存了一些規(guī)模非常大的東西,那么要小心處理。常見錯誤是創(chuàng)建副本,然后耗盡內(nèi)存,并得到內(nèi)存溢出的致命錯誤:

$db_records_in_array_format; //This is a big array holding 1000 rows from a table each having 20 columns , every row is atleast 100 bytes , so total 1000 * 20 * 100 = 2MB$cc = $db_records_in_array_format; //2MB moresome_function($cc); //Another 2MB ?

當(dāng)導(dǎo)入csv文件或?qū)С霰淼絚sv文件時,上面這樣的代碼很常見。

像上面這樣做可能經(jīng)常會由于內(nèi)存限制而讓腳本崩潰。對于小規(guī)模的變量它不會出現(xiàn)問題,但當(dāng)處理大型數(shù)組時一定要對此加以避免。

考慮通過引用傳遞它們,或者將它們存儲在一個類變量中:

$a = get_large_array();

pass_to_function($a);

這樣一來,相同的變量(并非其副本)將用于該函數(shù)。

class A{ ? ?function first()

{ ? ? ? ?$this-a = get_large_array(); ? ? ? ?$this-pass_to_function();

} ? ?function pass_to_function()

{ ? ? ? ?//process $this-a

}

}

盡快復(fù)原它們,這樣內(nèi)存就能被釋放,并且腳本的其余部分就能放松。

下面是關(guān)于如何通過引用來賦值從而節(jié)省內(nèi)存的一個簡單示例。

?phpini_set('display_errors' , true);

error_reporting(E_ALL);

$a = array();for($i = 0; $i 100000 ; $i++)

{

$a[$i] = 'A'.$i;

}echo 'Memory usage in MB : '. memory_get_usage() / 1000000 . '

';

$b = $a;

$b[0] = 'B';echo 'Memory usage in MB after 1st copy : '. memory_get_usage() / 1000000 . '

';

$c = $a;

$c[0] = 'B';echo 'Memory usage in MB after 2st copy : '. memory_get_usage() / 1000000 . '

';

$d = $a;

$d[0] = 'B';echo 'Memory usage in MB after 3st copy (reference) : '. memory_get_usage() / 1000000 . '

';

一個典型php 5.4機器上的輸出是:

Memory usage in MB : 18.08208Memory usage in MB after 1st copy : 27.930944Memory usage in MB after 2st copy : 37.779808Memory usage in MB after 3st copy (reference) : 37.779864

因此可以看出,內(nèi)存被保存在第3份通過引用的副本中。否則,在所有普通副本中內(nèi)存將被越來越多地使用。

15.在整個腳本中使用單一的數(shù)據(jù)庫連接

請確保你在整個腳本使用單一的數(shù)據(jù)庫連接。從一開始就打開連接,使用至結(jié)束,并在結(jié)束時關(guān)閉它。不要像這樣在函數(shù)內(nèi)打開連接:

function add_to_cart(){

$db = new Database();

$db-query("INSERT INTO cart .....");

}function empty_cart(){

$db = new Database();

$db-query("DELETE FROM cart .....");

}

有多個連接也不好,會因為每個連接都需要時間來創(chuàng)建和使用更多的內(nèi)存,而導(dǎo)致執(zhí)行減緩。

在特殊情況下。例如數(shù)據(jù)庫連接,可以使用單例模式。

;

幾種常用PHP連接數(shù)據(jù)庫的代碼示例

PHP連接數(shù)據(jù)庫之PHP連接MYSQL數(shù)據(jù)庫代碼

?php? ? $mysql_server_name= localhost ;? //改成自己的mysql數(shù)據(jù)庫服務(wù)器 ? $mysql_username= root ;? //改成自己的mysql數(shù)據(jù)庫用戶名 ? $mysql_password= ;? //改成自己的mysql數(shù)據(jù)庫密碼 ? $mysql_database= mycounter ; ?//改成自己的mysql數(shù)據(jù)庫名 ? $conn=mysql_connect($mysql_server_name $mysql_username $mysql_password $mysql_database);? ? $sql= CREATE?DATABASE?mycounter? DEFAULT?CHARACTER?SET?gbk?COLLATE?gbk_chinese_ci;? ? ;? ? mysql_query($sql);? ? $sql= CREATE?TABLE?`counter`? (`id`?INT( )?UNSIGNED?NOT?NULL? AUTO_INCREMENT? `count`?INT( )? UNSIGNED?NOT?NULL?DEFAULT? PRIMARY?KEY? (?`id`?)?)?TYPE?=?innodb; ;? ? mysql_select_db($mysql_database $conn);? ? $result=mysql_query($sql);? ? //echo?$sql;? ? mysql_close($conn);? ? echo?"Hello!數(shù)據(jù)庫mycounter已經(jīng)成功建立!";? ? ?

PHP連接數(shù)據(jù)庫之PHP連接ACCESS數(shù)據(jù)庫代碼方法

? ? $conn?=?new?("ADODB Connection");? ? $connstr?=?"DRIVER={Microsoft?Access?Driver?(* mdb)};?DBQ=" ?realpath("data/db mdb");? ? $conn Open($connstr);? ? $rs?=?new?("ADODB RecordSet");? ? $rs Open("select?*?from?szd_t" $conn );? ? while(!?$rs eof)?{? ? $f?=?$rs Fields( );? ? echo?$f value;? ? $rs MoveNext();? ? }? ? ?

PHP連接數(shù)據(jù)庫之PHP連接MS SQL數(shù)據(jù)庫代碼方法

安裝SQL服務(wù)器并添加PHP的MSSQL擴展

使用以下代碼連接并測試

?php? ? $myServer?=?localhost;?//主機 ? $myUser?=?sa;?//用戶名 ? $myPass?=?password;?//密碼 ? $myDB?=?Northwind;?//MSSQL庫名 ? $s?=?@mssql_connect($myServer ?$myUser ?$myPass)? ? or?die(Couldnt?connect?to?SQL?Server?on?$myServer);? ? $d?=?@mssql_select_db($myDB ?$s)? ? or?die(Couldnt?open?database?$myDB);? ? $query?=?SELECT?TitleOfCourtesy+?+FirstName+?+LastName?AS?Employee?;? ? $query? =?FROM?Employees?;? ? $query? =?WHERECountry=USA?AND?Left(HomePhone ? )?=?( );? ? $result?=?mssql_query($query);? ? $numRows?=?mssql_num_rows($result);? ? echo? h ? ?$numRows? ?Row? ?($numRows?==? ???:?s)? ?Returned?/ h ;? ? while($row?=?mssql_fetch_array($result))? ? {? ? echo? li? ?$row[Employee]? ? /li;? ? }? ? ?

PHP連接數(shù)據(jù)庫之PHP連接Oracle數(shù)據(jù)庫

PHP提供了兩套函數(shù)與Oracle連接 分別是ORA_和OCI函數(shù) 其中ORA_函數(shù)略顯陳舊 OCI函數(shù)更新?lián)f更好一些 兩者的使用語法幾乎相差無幾 你的PHP安裝選項應(yīng)該可以支持兩者的使用

 ?? if?($conn=Ora_Logon("user@TNSNAME" "password"))? ? {?echo?"SUCCESS?!?Connected?to?databasen";? ? }else? ? {echo?"Failed?: (?Could?not?connect?to?databasen";}? ? Ora_Logoff($conn);? ? phpinfo();? ? ?? ? lishixinzhi/Article/program/PHP/201405/30761

本文標(biāo)題:php調(diào)用數(shù)據(jù)庫函數(shù) php 調(diào)用函數(shù)
標(biāo)題網(wǎng)址:http://www.rwnh.cn/article4/dosphie.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動態(tài)網(wǎng)站、面包屑導(dǎo)航品牌網(wǎng)站設(shè)計、網(wǎng)頁設(shè)計公司、網(wǎng)站維護、網(wǎng)站改版

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化
泰安市| 米脂县| 富宁县| 娱乐| 巴彦县| 怀安县| 浠水县| 南木林县| 宜阳县| 合阳县| 门头沟区| 辛集市| 扶风县| 沐川县| 德化县| 新密市| 阿勒泰市| 城步| 和平区| 榕江县| 汕头市| 从化市| 迁西县| 桦甸市| 泰兴市| 宁乡县| 垣曲县| 耿马| 福鼎市| 德钦县| 鄂尔多斯市| 孟州市| 福鼎市| 噶尔县| 玉山县| 崇信县| 溧水县| 同仁县| 太康县| 张北县| 乌审旗|