常用函數比較多
10年積累的網站設計制作、成都網站設計經驗,可以快速應對客戶對網站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網絡服務。我雖然不認識你,你也不認識我。但先網站制作后付款的網站建設流程,更有江都免費網站建設讓你可以放心的選擇與我們合作。
如:字符串處理函數,數組函數,日期函數,MySQL函數,文件系統(tǒng)函數,GD函數庫等
主要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); //獲取記錄數
--------------------------------------------
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引用函數的使用方法,希望大家會喜歡。
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í)行減緩。
在特殊情況下。例如數據庫連接,可以使用單例模式。
;