ASP設計經(jīng)常見問題及回答精要-3
發(fā)表時間:2024-02-02 來源:明輝站整理相關軟件相關文章人氣:
[摘要]17、問題:在ASP中使用ADO的AddNew方法和直接使用“Insert into...”語句有何不同?哪種方式更好? 答:ADO的AddNew方法只是將“Insert into ”語句封裝了起來,所以,當對大量數(shù)據(jù)進行操作的時候,直接使用SQL語句將會大大加快存取數(shù)據(jù)的速度,因為它減少了A...
17、問題:在ASP中使用ADO的AddNew方法和直接使用“Insert into...”語句有何不同?哪種方式更好?
答:ADO的AddNew方法只是將“Insert into ”語句封裝了起來,所以,當對大量數(shù)據(jù)進行操作的時候,直接使用SQL語句將會大大加快存取數(shù)據(jù)的速度,因為它減少了ADO的“翻譯”時間,由于SQL語句所執(zhí)行的操作是直接在數(shù)據(jù)庫服務器中進行的,尤其在數(shù)據(jù)量很大的時候有顯著的優(yōu)勢。
18、問題:為什么我在ASP中使用標準的插入記錄語句 insert into books(name,email) values(“kitty”, “kitty@263.com”)會出錯?
答:SQL(Structured Query Language/結構式查詢語言)是IBM公司在1970年代所發(fā)展出來的數(shù)據(jù)查詢語言,它現(xiàn)在已經(jīng)成為關系型數(shù)據(jù)庫查詢語言的標準。SQL語句是一種以英文為基礎的程序語言,可以使用它來添加,管理以及存取數(shù)據(jù)庫。
在SQL語句中添加時的字符串雖然可以使用雙引號,但在ASP中卻需要使用單引號才能正常執(zhí)行。所以應當寫成insert into books(name,email) values(‘kitty’,‘kitty@263.com’)。
19、問題:什么是ActiveX 控件? 在哪里可以得到這些ActiveX控件?
答:Microsoft ActiveX控件是由軟件提供商開發(fā)的可重用的軟件組件。除了ASP的內(nèi)嵌對象外,另外安裝進來的ActiveX控件也可以在ASP中使用,這樣可以節(jié)省許多寶貴的開發(fā)時間,在ASP中其實也內(nèi)嵌了很多的ActiveX控件可以使用。
使用ActiveX控件,可以很快地Web應用程序、以及開發(fā)工具中加入特殊的功能。例如,使用AdRotator對象來制作廣告滾動板,使用FileSystemObject對象進行文件存取,使用Marquee對象實現(xiàn)滾動文字。
現(xiàn)在,已有1000多個商用的ActiveX控件,開發(fā)ActiveX控件可以使用各種編程語言,如C,C++等,以及微軟公司的 Visual Java開發(fā)環(huán)境Microsoft Visual J++。 ActiveX控件一旦被開發(fā)出來,設計和開發(fā)人員就可以把它當作預裝配組件,用于開發(fā)客戶程序。以此種方式使用 ActiveX控件,使用者無需知道這些組件是如何開發(fā)的,在很多情況下,甚至不需要自己編程,就可以完成網(wǎng)頁或應用程序的設計。
目前由第三方軟件開發(fā)商提供的商用控件有1000多種。微軟ActiveX組件庫(ActiveX Component Gallery)中存著有關信息以及相關的連接,它們指向微軟及第三方開發(fā)商提供的各種 ActiveX 控件。在微軟ActiveX組件庫(ActiveX Component Gallery)中,可以找到開發(fā)Internet增強型ActiveX 控件的公司列表。
20、問題:為什么使用strStartPort=(Request.Form ("catmenu_0")語句取到表單中起始站點的值在數(shù)據(jù)庫卻找不到?
答:這是因為取到的起始站點的值可能有空格,比如原意是“杭州”,但是由于空格存在,ASP程序取到的值可能就是“ 杭州”,而數(shù)據(jù)庫中只有“杭州”的記錄,當然就找不到了,解決的方法是利用Trim 函數(shù)將字符串兩頭空格全部去除,相應的語句為:
strStartPort=TRIM(Request.Form("catmenu_0"))
21、問題:在ASP中當變量的生命周期結束后,有幾種保留變量內(nèi)容的方法?
答:任何導致網(wǎng)頁結束的操作,比如當按下瀏覽器的“刷新”按鈕,或者關閉了瀏覽器,再重新打開它,都會導致變量生命周期的結束。
如果希望在網(wǎng)頁結束執(zhí)行時,還能夠保留變量的內(nèi)容,以備下一次執(zhí)行時使用,就可以借助Application對象來實現(xiàn)。比如可以利用Application對象來制作統(tǒng)計網(wǎng)站訪問量的計數(shù)器。
Session對象跟Application對象一樣,可以在網(wǎng)頁結束時將變量的內(nèi)容存儲下來,但是與Application對象不同的是,每個聯(lián)機是一個獨立的Session對象,簡單地說就是所有聯(lián)機上網(wǎng)者只會共享一個Application對象,但每位聯(lián)機上網(wǎng)者卻會擁有自己的Session對象。
Application對象與Session對象可以幫我們把信息記錄在服務器端,而Cookies對象則會借助瀏覽器提供的Cookies功能將信息記錄在客戶端。有一點要注意,Cookies是記錄在瀏覽器的信息,所以數(shù)據(jù)的存取并不象存取其他ASP對象(信息存儲在Server端)那么簡單,就實際運行來看,只有在瀏覽器開始瀏覽Server的某一網(wǎng)頁,而Server尚未下載任何數(shù)據(jù)給瀏覽器之前,瀏覽器才能夠與Server進行Cookies數(shù)據(jù)的交換。
22、問題:對象使用完后應該怎么辦?
答:當使用完對象后,首先使用Close方法來釋放對象所占用的系統(tǒng)資源;然后設置對象值為“nothing”來釋放對象占用的內(nèi)存,否則會因為對象太多導致WEB服務站點運行效率降低乃至崩潰,相應語句如下:
< %
對象.close
set對象= nothing
% >