用java連接數(shù)據(jù)庫的時候就是要慢啊,所以通常的做法是不關(guān)閉連接,這樣就不會慢啊。
目前創(chuàng)新互聯(lián)已為上1000家的企業(yè)提供了網(wǎng)站建設(shè)、域名、雅安服務(wù)器托管、網(wǎng)站托管維護、企業(yè)網(wǎng)站設(shè)計、丹徒網(wǎng)站維護等服務(wù),公司將堅持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
你是不是每次都去連接,用完了在關(guān)閉,這個不行,要用連接池的。連接池一直存放著一系列的連接。
可以用php的curl模擬瀏覽器請求是訪問java服務(wù)器程序,或者用java的一個http類庫同樣發(fā)送http請求來訪問PHP服務(wù)器
1、PHP編程能力?由于PHP的入門較為簡單,所以暫時只有熟悉和精通兩個級別。
1、熟悉PHP:精通PHP語法,安徽IT培訓(xùn)建議掌握常用的函數(shù),熟悉PHP5下的OOP應(yīng)用,這個是基礎(chǔ),也沒什么好說的。
2、精通PHP:對PHP運行機制的理解;對系統(tǒng)資源的調(diào)用交互理解;關(guān)健性能的優(yōu)化能力。
2、MySQL能力?在開發(fā)上的應(yīng)用基于幾個能力體現(xiàn):?1、了解:知道用PHP連接數(shù)據(jù)庫;懂得寫一些簡單的SQL;建一些簡單的索引;懂得用工具簡單操作一下數(shù)據(jù)庫(增刪改庫表結(jié)構(gòu)數(shù)據(jù)等等)。
2、熟悉:懂得在開發(fā)應(yīng)用上設(shè)計數(shù)據(jù)庫,建立一些有效的索引,用explain分析SQL性能,壓力測試等等。
3、很熟悉:深入了解數(shù)據(jù)庫索引、存儲引擎原理以及運行機制,能有效地構(gòu)建高性能可擴展的數(shù)據(jù)庫結(jié)構(gòu)/架構(gòu),有效地優(yōu)化數(shù)據(jù)庫性能配置并加以調(diào)試,分析數(shù)據(jù)庫運行狀態(tài)。
4、精通:簡單地說具備以上所有能力的同時,有多年高負載分布式環(huán)境下的優(yōu)化管理經(jīng)驗。
據(jù)我觀察以及交往經(jīng)驗,70%的PHPer處在了解階段,25%處于熟悉階段,4%很熟悉,精通的人基本就不是phper了。
70%這個群體最容易忽視MySQL,以為MySQL只是簡單的存儲媒介,沒有優(yōu)化意識,認為加個內(nèi)存、CPU就能解決問題。
典型事件:join、orderby、groupby等語句性能一塌糊涂,數(shù)據(jù)庫根本沒有設(shè)計(僅限于拆成一個主表,N個附表等),搞不清字段類型及作用,碰到大表的復(fù)雜查詢就沒轍。
20%這個群體的人只是MySQL運行機制理解不透徹,對影響MySQL性能的關(guān)健因素把握不明確,不熟練。
典型事件:熟讀手冊,但說不清索引原理,不知道二叉樹、HASH等算法對于數(shù)據(jù)庫的作用?4%的群體已經(jīng)基本可以勝任DBA的職能。
3、OOP能力?1、了解:了解變量的作用域、類型,及其意義,了解繼承機制等,懂得復(fù)用、封裝概念。
2、熟悉:熟練應(yīng)用接口、抽象等技術(shù)混合開發(fā)程序,并理解其中含義,一般研究過。
3、很熟悉:有過OOP架構(gòu)設(shè)計經(jīng)驗,熟悉設(shè)計模式、UML,熟悉PHP對象運行機制,內(nèi)容管理等。
4、精通:應(yīng)該是架構(gòu)師級別了,不限于PHP。
經(jīng)常我們會碰到一些自稱熟悉OOP卻連public、private、protected、static都解釋不清的人,是肯定沒有經(jīng)歷過正規(guī)的OOP項目。
4、大型網(wǎng)站經(jīng)驗?1、了解:熟悉PHP開發(fā)下的緩存應(yīng)用(memcache、APC等);接觸過LVS、SQUID應(yīng)用;有一定的session處理方案;熟悉負載均衡;熟悉PHP數(shù)據(jù)連接池應(yīng)用;了解PHP編程性能優(yōu)化。
2、熟悉:掌握分布式緩存及緩存性能優(yōu)化、熟悉存儲系統(tǒng)、文件系統(tǒng)、數(shù)據(jù)庫,開發(fā)可擴展平臺。
能結(jié)合負載均衡合理布置流量,對PHP運行性能進行監(jiān)控與分析。
3、非常熟悉:具備系統(tǒng)分析師能力,已經(jīng)超出phper環(huán)節(jié)...?4、精通:太深奧..?5、操作系統(tǒng)應(yīng)用能力?操作系統(tǒng)的熟悉與精通需要需要廣泛且扎實的基礎(chǔ)理論,而對于開發(fā)者來說,熟悉基本的命令操作,對WEB相關(guān)服務(wù)的安裝、配置、優(yōu)化能力需要具備。
請注意:這里提供的代碼只是為了使你能簡單的連接Android項目和PHP,MySQL。你不能把它作為一個標準或者安全編程實踐。在生產(chǎn)環(huán)境中,理想情況下你需要避免使用任何可能造成潛在注入漏洞的代碼(比如MYSQL注入)。MYSQL注入是一個很大的話題,不可能用單獨的一篇文章來說清楚,并且它也不在本文討論的范圍內(nèi),所以本文不以討論。
1. 什么是WAMP Server
WAMP是Windows,Apache,MySQL和PHP,Perl,Python的簡稱。WAMP是一個一鍵安裝的軟件,它為開發(fā)PHP,MySQL Web應(yīng)用程序提供一個環(huán)境。安裝這款軟件你相當(dāng)于安裝了Apache,MySQL和PHP。或者,你也可以使用XAMP。
2. 安裝和使用WAMP Server
你可以從http://www。wampserver。com/en/下載WAMP,安裝完成之后,可以從開始-所有程序-WampServer-StartWampServer運行該程序。
在瀏覽器中輸入來測試你的服務(wù)器是否安裝成功。同樣的,也可以打開來檢驗phpmyadmin是否安裝成功。
3. 創(chuàng)建和運行PHP項目
現(xiàn)在,你已經(jīng)有一個能開發(fā)PHP和MYSQL項目的環(huán)境了。打開安裝WAMP Server的文件夾(在我的電腦中,是C:\wamp\),打開www文件夾,為你的項目創(chuàng)建一個新的文件夾。你必須把項目中所有的文件放到這個文件夾中。
新建一個名為android_connect的文件夾,并新建一個php文件,命名為test.php,嘗試輸入一些簡單的php代碼(如下所示)。輸入下面的代碼后,打開,你會在瀏覽器中看到“Welcome,I am connecting Android to PHP,MySQL”(如果沒有正確輸入,請檢查WAMP配置是否正確)
test.php
?php
echo"Welcome, I am connecting Android to PHP, MySQL";
?4. 創(chuàng)建MySQL數(shù)據(jù)庫和表
在本教程中,我創(chuàng)建了一個簡單的只有一張表的數(shù)據(jù)庫。我會用這個表來執(zhí)行一些示例操作?,F(xiàn)在,請在瀏覽器中輸入,并打開phpmyadmin。你可以用PhpMyAdmin工具創(chuàng)建數(shù)據(jù)庫和表。
創(chuàng)建數(shù)據(jù)庫和表:數(shù)據(jù)庫名:androidhive,表:product
CREATE DATABASE androidhive;
CREATE TABLE products(
pid int(11) primary key auto_increment,
name varchar(100) not null,
price decimal(10,2) not null,
description text,
created_at timestamp defaultnow(),
updated_at timestamp
);5. 用PHP連接MySQL數(shù)據(jù)庫
現(xiàn)在,真正的服務(wù)器端編程開始了。新建一個PHP類來連接MYSQL數(shù)據(jù)庫。這個類的主要功能是打開數(shù)據(jù)庫連接和在不需要時關(guān)閉數(shù)據(jù)庫連接。
新建兩個文件db_config.php,db_connect.php
db_config.php--------存儲數(shù)據(jù)庫連接變量
db_connect.php-------連接數(shù)據(jù)庫的類文件
db_config.php
?php
/*
* All database connection variables
*/
define('DB_USER', "root"); // db user
define('DB_PASSWORD', ""); // db password (mention your db password here)
define('DB_DATABASE', "androidhive"); // database name
define('DB_SERVER', "localhost"); // db serverdb_connect.php
?php
/**
* A class file to connect to database
*/
classDB_CONNECT {
// constructor
function__construct() {
// connecting to database
$this-connect();
}
// destructor
function__destruct() {
// closing db connection
$this-close();
}
/**
* Function to connect with database
*/
functionconnect() {
// import database connection variables
require_once__DIR__ . '/db_config.php';
// Connecting to mysql database
$con= mysql_connect(DB_SERVER, DB_USER, DB_PASSWORD) ordie(mysql_error());
// Selecing database
$db= mysql_select_db(DB_DATABASE) ordie(mysql_error()) ordie(mysql_error());
// returing connection cursor
return$con;
}
/**
* Function to close db connection
*/
functionclose() {
// closing db connection
mysql_close();
}
}
?怎么調(diào)用:當(dāng)你想連接MySQl數(shù)據(jù)庫或者執(zhí)行某些操作時,可以這樣使用db_connect.php
$db= newDB_CONNECT(); // creating class object(will open database connection)
比較PHP和JSP這兩個Web開發(fā)技術(shù),在目前的情況是其實是比較PHP和Java的Web開發(fā)。以下是我就幾個主要方面進行的比較:
一、 語言比較
PHP是解釋執(zhí)行的服務(wù)器腳本語言,首先php有簡單容易上手的特點。語法和c語言比較象,所以學(xué)過c語言的程序員可以很快的熟悉php的開發(fā)。而java需要先學(xué)好java的語法和熟悉一些核心的類庫,懂得面向?qū)ο蟮某绦蛟O(shè)計方法。所以java不如php好學(xué)。
Java首先要編譯成字節(jié)碼.class文件,然后在java虛擬機上解釋執(zhí)行。Java的Web開發(fā)首先最容易想到的就是JSP(現(xiàn)在已經(jīng)到JSP2.0),原來的java的Web開發(fā)都是用servlet來實現(xiàn)的,用servlet來開發(fā)需要程序員在java的源文件中嵌入大量的html代碼。所以后來就出現(xiàn)了JSP,JSP可以方便的嵌入到html文件當(dāng)中,其實jsp文件在服務(wù)器上執(zhí)行的時候首先會被應(yīng)用服務(wù)器轉(zhuǎn)換成servlet,然后再編譯執(zhí)行。Jsp可以通過servlet和JavaBean的支持產(chǎn)生強大的功能。JavaBean 是一種可復(fù)用的、跨平臺的軟件組件。使用javabean可以方便的實現(xiàn)java代碼和html的分離,能夠增強系統(tǒng)的功能和軟件的復(fù)用性。
Java的Web開發(fā)屬于SUN公司定義的J2EE其中的規(guī)范。而且在J2EE中包括了java的Web開發(fā)的所有方面,如:JSP、Servlet、JDBC、JNDI、JAVABEAN、EJB等等。J2EE就特別適合于做大型的企業(yè)級的應(yīng)用。
二、 數(shù)據(jù)庫訪問比較
Java通過JDBC來訪問數(shù)據(jù)庫,通過不同的數(shù)據(jù)庫廠商提供的數(shù)據(jù)庫驅(qū)動方便地訪問數(shù)據(jù)庫。訪問數(shù)據(jù)庫的接口比較統(tǒng)一。
PHP對于不同的數(shù)據(jù)庫采用不同的數(shù)據(jù)庫訪問接口,所以數(shù)據(jù)庫訪問代碼的通用性不強。例如:用Java開發(fā)的Web應(yīng)用從MySQL數(shù)據(jù)庫轉(zhuǎn)到Oracle數(shù)據(jù)庫只需要做很少的修改。而PHP則需要做大量的修改工作。
三、 系統(tǒng)設(shè)計架構(gòu)比較
采用Java的Web開發(fā)技術(shù),需要使用的是面向?qū)ο蟮南到y(tǒng)設(shè)計方法,而PHP還是采用面向過程的開發(fā)方法。所以用Java進行開發(fā)前期需要做大量的系統(tǒng)分析和設(shè)計的工作。
四、 跨平臺性
Java和PHP都有很好的跨平臺的特性。幾乎都可以在不作任何修改的情況下運行在Linux或者Windows等不同的操作系統(tǒng)上。
五、 開發(fā)成本比較
PHP最經(jīng)典的組合就是:PHP + MySQL + Apache。非常適合開發(fā)中小型的Web應(yīng)用,開發(fā)的速度比較快。而且所有的軟件都是開源免費的,可以減少投入。
Java的Web應(yīng)用服務(wù)器有免費Tomcat、JBoss等,如果需要更好的商業(yè)化的服務(wù)有:Web Sphere和 Web logic。
六、 分布式多層架構(gòu)比較
PHP只能實現(xiàn)簡單的分布式兩層或三層的架構(gòu),而JAVA在這方面就比較強大,可以實現(xiàn)多層的網(wǎng)絡(luò)架構(gòu)。數(shù)據(jù)庫層(持久化層)、應(yīng)用(業(yè)務(wù))邏輯層、表示邏輯層彼此分開,而且現(xiàn)在不同的層都已經(jīng)有一些成熟的開發(fā)框架的支持。例如Struts就是利用java的Web開發(fā)技術(shù)實現(xiàn)了MVC的設(shè)計模式,而在業(yè)務(wù)邏輯層也有Spring框架,數(shù)據(jù)庫持久化層有Hibernate等框架。這些框架可以方便開發(fā)者高效、合理、科學(xué)得架構(gòu)多層的商業(yè)應(yīng)用。
下面簡要的說一下Struts,它實質(zhì)上是在JSP Model2的基礎(chǔ)上實現(xiàn)的一個MVC(Model、View、Controler)框架。JSP Model2體系結(jié)構(gòu)是一種聯(lián)合使用JSP 與Servlet 來提供動態(tài)內(nèi)容的方法。在Struts框架中,模型由實現(xiàn)業(yè)務(wù)邏輯的JavaBean或EJB組件構(gòu)成,控制器由Servlet實現(xiàn)的,視圖由一組JSP文件組成。采用Struts可以明確角色的定義和開發(fā)者與網(wǎng)頁設(shè)計者的分工。而且項目越復(fù)雜,其優(yōu)勢越明顯。
七、 源代碼安全
PHP開發(fā)的程序的源代碼都是公開的,他人拿到php開發(fā)的程序后都可以進行修改。
Java開發(fā)的程序,最后用戶拿到的是只是一些編譯好的class類,無法看到完整的源代碼,安全性高。
八、性能比較
有人做過試驗,對這兩種種語言分別做回圈性能測試及存取Oracle數(shù)據(jù)庫測試。
在循環(huán)性能測試中,JSP只用了令人吃驚的四秒鐘就結(jié)束了20000*20000的回圈。而PHP測試的是2000*2000循環(huán)(少一個數(shù)量級),卻分別用了63秒。
數(shù)據(jù)庫測試中,二者分別對 Oracle 8 進行 1000 次 Insert,Update,Select和Delete: JSP 需要 13 秒,PHP 需要 69 秒。
綜上所述,我個人認為,PHP適合于快速開發(fā),中小型應(yīng)用系統(tǒng),開發(fā)成本低,能夠?qū)ψ儎拥男枨笞鞒隹焖俚姆磻?yīng)。而Java適合于開發(fā)大型的應(yīng)用系統(tǒng),應(yīng)用的前景比較廣闊,系統(tǒng)易維護、可復(fù)用性較好。還有,同樣功能的系統(tǒng)用Java開發(fā)的系統(tǒng)要比PHP開發(fā)的系統(tǒng)的價格要高。