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

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

php函數行數據 php數學函數

PHP常用函數有哪些

常用函數比較多

10年積累的網站設計制作、成都網站設計經驗,可以快速應對客戶對網站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網絡服務。我雖然不認識你,你也不認識我。但先網站制作后付款的網站建設流程,更有江都免費網站建設讓你可以放心的選擇與我們合作。

如:字符串處理函數,數組函數,日期函數,MySQL函數,文件系統(tǒng)函數,GD函數庫等

php 取得結果集中行的數目 有幾種方法

主要2種:

獲取查詢結果的記錄數

int mysql_num_rows(mysql_result $result)

$result 為 mysql_query 返回的結果集。

[該函數返回一個整數,表示記錄中有多少行數據]

mysql_affected_row()

可以用來獲取 insert, update, delete語句影響的記錄行數。

例:

--------------------------------------------

$sql = "select * from course";

$rs = mysql_query($sql) or die('數據庫連接失敗');

$s = mysql_num_rows($rs); //獲取記錄數

--------------------------------------------

如何正確理解PHP獲取顯示數據庫數據函數

1、PHP獲取顯示數據庫數據函數之 mysql_result()

mixed mysql_result(resource result_set, int row [,mixed field])

從result_set 的指定row 中獲取一個field 的數據. 簡單但是效率低.

舉例:

$link1?=?@mysql_connect("server1",?

"webuser",?"password")?

or?die("Could?not?connect?

to?mysql?server!");

@mysql_select_db("company")?

or?die("Could?not?select?database!");

$query?=?"select?id,?name?

from?product?order?by?name";?

$result?=?mysql_query($query);

$id?=?mysql_result($result,?0,?"id");

$name?=?mysql_result($result,?0,?"name");

mysql_close();

注意,上述代碼只是輸出結果集中的第一條數據的字段值,如果要輸出所有記錄,需要循環(huán)處理.

for?($i?=?0;?$i?=?mysql_num_rows($result);?$i++)

{

$id?=?mysql_result($result,?0,?"id");

$name?=?mysql_result($result,?0,?"name");

echo?"Product:?$name?($id)";

}

注意,如果查詢字段名是別名,則mysql_result中就使用別名.

2、PHP獲取顯示數據庫數據函數之mysql_fetch_row()

array mysql_fetch_row(resource result_set)

從result_set中獲取整行,把數據放入數組中.

舉例(注意和list 的巧妙配合):

$query?=?"select?id,?

name?from?product?order?by?name";?

$result?=?mysql_query($query);

while(list($id,?$name)?

=?mysql_fetch_row($result))?{

echo?"Product:?$name?($id)";

}

3、PHP獲取顯示數據庫數據函數之mysql_fetch_array()

array mysql_fetch_array(resource result_set [,int result_type])

mysql_fetch_row()的增強版.

將result_set的每一行獲取為一個關聯(lián)數組或/和數值索引數組.

默認獲取兩種數組,result_type可以設置:

MYSQL_ASSOC:返回關聯(lián)數組,字段名=字段值?

MYSQL_NUM:返回數值索引數組.

MYSQL_BOTH:獲取兩種數組.因此每個字段可以按索引偏移引用,也可以按字段名引用.

舉例:

$query?=?"select?id,

name?from?product?order?by?name";

$result?=?mysql_query($query);

while($row?=?mysql_fetch_array

($result,?MYSQL_BOTH))?{?

$name?=?$row['name'];

//或者?$name?=?$row[1];

$name?=?$row['id'];

//或者?$name?=?$row[0];

echo?"Product:?$name?($id)";

}

4、PHP獲取顯示數據庫數據函數之mysql_fetch_assoc()

array mysql_fetch_assoc(resource result_set)

相當于 mysql_fetch_array($result, MYSQL_ASSOC)

5、PHP獲取顯示數據庫數據函數之mysql_fetch_object()

object mysql_fetch_object(resource result_set)?

和mysql_fetch_array()功能一樣,不過返回的不是數組,而是一個對象.

舉例:

$query?=?"select?id,?name?

from?product?order?by?name";

$result?=?mysql_query($query);?

while($row?=?mysql_fetch_object

($result))?{

$name?=?$row-name;

$name?=?$row-id;

echo?"Product:?$name?($id)";

}

以上這些函數就是PHP獲取顯示數據庫數據函數的全部總結。

php引用函數的使用方法

php引用函數的使用方法

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

1.不要在你的應用程序中gzip輸出,讓apache來做

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

使用apache mod_gzip/mod_deflate通過.htaccess文件壓縮內容。

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.在寫入任何文件之前檢查目錄是否可寫

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

請確保你的應用程序盡可能智能化,并在最短的時間內報告最重要的信息。

$contents = "All the content";

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

file_put_contents($file_path , $contents);

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

父目錄不存在

目錄存在,但不可寫

鎖定文件用于寫入?

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

$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");

}

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

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

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

// 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}

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

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

{ ? ?//Save the things}

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

6.在函數中總是有相同值的地方使用靜態(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'];

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

因此,用包裝函數使用應用程序特定鍵:

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.封裝實用輔助函數到一個類中

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

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 ...}

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

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有相似名稱的內置函數,那么名稱不會發(fā)生沖突。

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

9.一些傻瓜式技巧

使用echo代替print

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

不要使用short tags

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

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

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

isset比strlen快

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

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

不要寫這樣的代碼:

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

這絕對是一種浪費。

這樣寫

if($a == true)

{

$a_count++;

}

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

10. 使用array_map快速處理數組

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

foreach($arr as $c = $v)

{

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

}

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

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

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

11.使用php過濾器驗證數據

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

php過濾器擴展程序將提供簡單的方法來有效驗證或校驗值。

12.強制類型檢查

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

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

這是一種好習慣。

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

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

14.小心處理大型數組

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

$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 ?

當導入csv文件或導出表到csv文件時,上面這樣的代碼很常見。

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

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

$a = get_large_array();

pass_to_function($a);

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

class A{ ? ?function first()

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

} ? ?function pass_to_function()

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

}

}

盡快復原它們,這樣內存就能被釋放,并且腳本的其余部分就能放松。

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

?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

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

15.在整個腳本中使用單一的數據庫連接

請確保你在整個腳本使用單一的數據庫連接。從一開始就打開連接,使用至結束,并在結束時關閉它。不要像這樣在函數內打開連接:

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)建和使用更多的內存,而導致執(zhí)行減緩。

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

;


文章名稱:php函數行數據 php數學函數
URL標題:http://weahome.cn/article/ddephpi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部