Oracle(甲骨文)是世界上最為流行的關(guān)系數(shù)據(jù)庫。它是大公司推崇的工業(yè)化的強(qiáng)有力的引擎。我們先看看其相關(guān)的函數(shù):
創(chuàng)新互聯(lián)公司長期為成百上千客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為冠縣企業(yè)提供專業(yè)的做網(wǎng)站、成都網(wǎng)站制作,冠縣網(wǎng)站改版等技術(shù)服務(wù)。擁有十多年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。
(1)integer
ora_logon(string
user
,
string
password)
開始對一個Oracle數(shù)據(jù)庫服務(wù)器的連接。
(2)integer
ora_open(integer
connection)
打開給出的連接的游標(biāo)。
(3)integer
ora_do(integer
connection,
string
query)
在給出的連接上執(zhí)行查詢。PHP生成一個指示器,解析查詢,并執(zhí)行之。
(4)integer
ora_parse(integer
cursor,
string
query)
解析一個查詢并準(zhǔn)備好執(zhí)行。
(5)boolean
ora_exec(integer
cursor)
執(zhí)行一個先前由ora_parse函數(shù)解析過的查詢。
(6)boolean
ora_fetch(integer
cursor)
此函數(shù)會使得一個執(zhí)行過的查詢中的行被取到指示器中。這使得您可以調(diào)用ora_getcolumn函數(shù)。
(7)string
ora_getcolumn(integer
cursor,
integer
column)
返回當(dāng)前的值。列由零開始的數(shù)字索引。
(8)boolean
ora_logoff(integer
connection)
斷開對數(shù)據(jù)庫服務(wù)器的鏈接。
以下是向ORACLE數(shù)據(jù)庫插入數(shù)據(jù)的示例程序:
html
headtitle向ORACLE數(shù)據(jù)庫中插入數(shù)據(jù)/title/head
body
form
action="?echo
$PHP_SELF;?"
method="post"
table
border="1"
cellspacing="0"
cellpadding="0"
tr
thID/th
thname/th
thDescription/th
/tr
tr
tdinput
type="text"
name="name"
maxlength="50"
size="10"/td
tdinput
type="text"
name="email"
maxlength="255"
size="30"/td
tdinput
type="text"
name="Description"
maxlength="255"
size="50"/td
/tr
tr
align="center"
td
colspan="3"input
type="submit"
value="提交" input
type="reset"
value="重寫"/td
/tr
/table
/form
?
//先設(shè)置兩個環(huán)境變量ORACLE_HOME,ORACLE_SID
putenv("ORACLE_HOME=/oracle/app/oracle/product/8.0.4");
putenv("ORACLE_SID=ora8");
//設(shè)置網(wǎng)頁顯示中文
putenv("NLS_LANG=Simplified_Chinese.zhs16cgb231280");
if($connection=ora_logon("scott","tiger"))
{
//庫表test有ID,name,Description三項(xiàng)
$sql
=
'insert
into
test(ID,name,Description)
values
';
$sql
.=
'(''
.
$ID
.
'',''
.
$name
.
'',''.
$Description
.
'')';
if($cursor=ora_do($connect,$sql))
{
print("insert
finished!");
}
$query
=
'select
*
from
test';
if($cursor=ora_do($connect,$query))
{
ora_fetch($cursor);
$content0=ora_getcolumn($cursor,0);
$content1=ora_getcolumn($cursor,1);
$content2=ora_getcolumn($cursor,2);
print("$content0");
print("$content1");
print("$content2");
ora_close($cursor);
}
ora_logoff($connection);
}
?
/body
/html
PHP代碼call_user_func函數(shù)類似于一種特別的調(diào)用函數(shù)的方法,使用方法如下:
function
a($b,$c)
{
echo
$b;
echo
$c;
}
call_user_func('a',
"111","222");
call_user_func('a',
"333","444");
//顯示
111
222
333
444
?
調(diào)用類內(nèi)部的方法比較奇怪,居然用的是array,不知道開發(fā)者是如何考慮的,當(dāng)然省去了new,也是滿有新意的:
class
a
{
function
b($c)
{
echo
$c;
}
}
call_user_func(array("a",
"b"),"111");
//顯示
111
?
call_user_func_array函數(shù)和call_user_func很相似,只不過是換了一種方式傳遞了參數(shù),讓參數(shù)的結(jié)構(gòu)更清晰:
function
a($b,
$c)
{
echo
$b;
echo
$c;
}
call_user_func_array('a',
array("111",
"222"));
//顯示
111
222
?
call_user_func_array函數(shù)也可以調(diào)用類內(nèi)部的方法的
Class
ClassA
{
function
bc($b,
$c)
{
$bc
=
$b
+
$c;
echo
$bc;
}
}
call_user_func_array(array('ClassA','bc'),
array("111",
"222"));
//顯示
333
?
call_user_func函數(shù)和call_user_func_array函數(shù)都支持引用,這讓他們和普通的函數(shù)調(diào)用更趨于功能一致:
function
a($b)
{
$b++;
}
$c
=
0;
call_user_func('a',
$c);
echo
$c;//顯示
1
call_user_func_array('a',
array($c));
echo
$c;//顯示
2
另:call_user_func函數(shù)和call_user_func_array函數(shù)都支持引用。
?phpfunction
increment($var){
$var++;}$a
=
0;call_user_func('increment',
$a);echo
$a;
//
0call_user_func_array('increment',
array($a));
//
You
can
use
this
insteadecho
$a;
//
1?
你那個set()函數(shù)本身有問題
test.php
?php
require_once "test2.php";
set();
?
test2.php
?php
function set(){
echo "wdqwdqwdqw"
}
?
弄個簡單的函數(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' ,];
放聰明點(diǎn)。使用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)報(bào)告最重要的信息。
$contents = "All the content";
$file_path = "/var/www/project/content.txt";
file_put_contents($file_path , $contents);
這完全正確。但有一些間接的問題。file_put_contents可能會因?yàn)橐恍┰蚨。?/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)限處理會浪費(fèi)你很多時間。因此,只要你的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ùn)行多個應(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ù)到一個類中
所以,你必須在一個文件中有很多實(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ā)生任何沖突。因?yàn)樗环庋b了,就是這樣。
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++;
這絕對是一種浪費(fèi)。
這樣寫
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過濾器驗(yàn)證數(shù)據(jù)
你是不是使用正則表達(dá)式來驗(yàn)證如電子郵件,IP地址等值?是的,每個人都是這樣做的?,F(xiàn)在,讓我們試試一個不同的東西,那就是過濾器。
php過濾器擴(kuò)展程序?qū)⑻峁┖唵蔚姆椒▉碛行?yàn)證或校驗(yàn)值。
12.強(qiáng)制類型檢查
$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機(jī)器上的輸出是:
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 .....");
}
有多個連接也不好,會因?yàn)槊總€連接都需要時間來創(chuàng)建和使用更多的內(nèi)存,而導(dǎo)致執(zhí)行減緩。
在特殊情況下。例如數(shù)據(jù)庫連接,可以使用單例模式。
;
?php
function factorial($num){
$base=1;
if(!intval($num)0){
die("false!!");
}
for($i=1;$i=$num;$i++){
$base*=$i;
}
echo $base;
}
echo factorial(10);
?
人家問的是PHP調(diào)用JS函數(shù)。。。樓主,我可以很負(fù)責(zé)的告訴你,這是不可能的。PHP是在服務(wù)器端運(yùn)行的腳本,而JS是在瀏覽器運(yùn)行的腳本,你要調(diào)用可以,直接echo個script就可以,但是獲取返回值是不可能的,只有讓JS把返回值通過AJAX發(fā)送給PHP才可以。