『壹』 在asp里,怎樣用html里的表單提交多於255個字元
1.關於提交大數據量的問題:
提交方式用post,資料庫欄位用備注型
2.關於驗證字元數,舉個例子吧:
<script language="javascript">
function chk()
{
var str=document.getElementById("txt").value;
if(str.length>10000){
alert("提交內容不能大於10000字!")
return false;
}
}
</script>
<form method="post" action="topic.asp" onsubmit="return chk()">
<textarea id="txt"></textarea>
<input type="submit" value="提交">
</form>
客戶端僅是簡單的驗證,具體的非法字元過濾,驗證還要在服務端進行
『貳』 若要提交大數據量的數據,則應採用什麼方法
post和get兩種方法都是可以的,對於大數據量還是推薦使用post方法,不容易產生歧義!而且產生的url地址很乾凈!
『叄』 如何向Oracle資料庫表中進行大數據量的插入並提交
一次折騰幾千萬的話,
那麼設置一下,
有
20W了,
就自動提交一下。
set
autocommit
on;
set
autocommit
200000;
然後,假如你的目標資料庫,
是歸檔的話,
可以
INSERT
/*+
append
*/
INTO
目標表
nologging
SELECT
*
FROM
源表@DBLINK;
commit;
set
autocommit
off;
假如你的
目標表
上面,
有
索引的話,
建議先刪除
索引。
等
上面的
INSERT
語句執行完畢後,
再重建索引。
『肆』 前端上傳大型文件或超長數據的解決辦法
我們設計的上傳文件大約在500m左右
我第一反應是blob,在HTML5中添加了blob類型用來定義前端較大數據,之前使用過blob流傳輸視頻再使用html5中<video>標簽讀取blob流,所以blob可以作為這種文件傳輸的載體,那如何提交呢,使用可formdata提交blob數據,這種方式可以承受較大數據量的文件,但在使用formdata傳輸的過程中,瀏覽器會卡死,無法操作。
還是舍友提醒,可採用數據或殲分割的方式,一部分一部分上傳。後經網路得知,文件分割要防止數據棗帆丟失進行大小校驗,以及防止外部入侵,進行分段前端加密,後端校驗。
網路發布了一款分割上傳的組件web upload,可包含文件分割,大小校驗等功能。
網站為: http://fex..com/webuploader/getting-started.html
佩服我們大學宿舍的技術氛圍,出差回來的火車上跟大學舍衫岩沖友在微信上聊了兩三個小時的技術,,,那天剛好是大學生開學那幾天,路上好多大學生,好懷念自己的大學生活,好懷念與大學舍友談天說地或技術探討到深夜的日子
說了幾個前端的問題,總結記錄一下吧
其中只有一個我會的,,,先說這個問題,其他的我學習完再分享,留坑。。。。。。
『伍』 如何向Oracle資料庫表中進行大數據量的插入並提交
一次折騰幾千萬的話, 那麼設置一下, 有 20W了, 就自動提交一下。
set autocommit on;
set autocommit 200000;
然後,假如你回的目標資料庫, 是歸檔的答話, 可以
INSERT /*+ append */ INTO 目標表 nologging SELECT * FROM 源表@DBLINK;
commit;
set autocommit off;
假如你的 目標表 上面, 有 索引的話, 建議先刪除 索引。
等 上面的 INSERT 語句執行完畢後, 再重建索引。
『陸』 mysql 數據量超過百萬後怎麼處理
1、應盡量避免在 where 子句中使用!=或<>操作符,否則將引擎放棄使用索引而進行全表掃描。
2、對查詢進行優化,應盡量避免全表掃描,首先應考慮在 where 及 order by 涉及的列上建立索引。
3、應盡量避免在 where 子句中對欄位進行 null 值判斷,否則將導致引擎放棄使用索引而進行全表掃描,如:
select id from t where num is null
可以在num上設置默認值0,確保表中num列沒有null值,然後這樣查詢:
select id from t where num=0
4、盡量避免在 where 子句中使用 or 來連接條件,否則將導致引擎放棄使用索引而進行全表掃描,如:
select id from t where num=10 or num=20
可以這樣查詢:
select id from t where num=10
union all
select id from t where num=20
5、下面的查詢也將導致全表掃描:(不能前置百分號)
select id from t where name like 『�1�7c%』
若要提高效率,可以考慮全文檢索。
6、in 和 not in 也要慎用,否則會導致全表掃描,如:
select id from t where num in(1,2,3)
對於連續的數值,能用 between 就不要用 in 了:
select id from t where num between 1 and 3
7、如果在 where 子句中使用參數,也會導致全表掃描。因為SQL只有在運行時才會解析局部變數,但優化程序不能將訪問計劃的選擇推遲到運行時;它必須在編譯時進行選擇。然 而,如果在編譯時建立訪問計劃,變數的值還是未知的,因而無法作為索引選擇的輸入項。如下面語句將進行全表掃描:
select id from t where num=@num
可以改為強制查詢使用索引:
select id from t with(index(索引名)) where num=@num
8、應盡量避免在 where 子句中對欄位進行表達式操作,這將導致引擎放棄使用索引而進行全表掃描。如:
select id from t where num/2=100
應改為:
select id from t where num=100*2
9、應盡量避免在where子句中對欄位進行函數操作,這將導致引擎放棄使用索引而進行全表掃描。如:
select id from t where substring(name,1,3)=』abc』–name以abc開頭的id
select id from t where datediff(day,createdate,』2005-11-30′)=0–』2005-11-30′生成的id
應改為:
select id from t where name like 『abc%』
select id from t where createdate>=』2005-11-30′ and createdate<』2005-12-1′
10、不要在 where 子句中的「=」左邊進行函數、算術運算或其他表達式運算,否則系統將可能無法正確使用索引。
11、在使用索引欄位作為條件時,如果該索引是復合索引,那麼必須使用到該索引中的第一個欄位作為條件時才能保證系統使用該索引,否則該索引將不會被使 用,並且應盡可能的讓欄位順序與索引順序相一致。
12、不要寫一些沒有意義的查詢,如需要生成一個空表結構:
select col1,col2 into #t from t where 1=0
這類代碼不會返回任何結果集,但是會消耗系統資源的,應改成這樣:
create table #t(…)
13、很多時候用 exists 代替 in 是一個好的選擇:
select num from a where num in(select num from b)
用下面的語句替換:
select num from a where exists(select 1 from b where num=a.num)
14、並不是所有索引對查詢都有效,SQL是根據表中數據來進行查詢優化的,當索引列有大量數據重復時,SQL查詢可能不會去利用索引,如一表中有欄位 sex,male、female幾乎各一半,那麼即使在sex上建了索引也對查詢效率起不了作用。
15、索引並不是越多越好,索引固然可以提高相應的 select 的效率,但同時也降低了 insert 及 update 的效率,因為 insert 或 update 時有可能會重建索引,所以怎樣建索引需要慎重考慮,視具體情況而定。一個表的索引數最好不要超過6個,若太多則應考慮一些不常使用到的列上建的索引是否有 必要。
16.應盡可能的避免更新 clustered 索引數據列,因為 clustered 索引數據列的順序就是表記錄的物理存儲順序,一旦該列值改變將導致整個表記錄的順序的調整,會耗費相當大的資源。若應用系統需要頻繁更新 clustered 索引數據列,那麼需要考慮是否應將該索引建為 clustered 索引。
17、盡量使用數字型欄位,若只含數值信息的欄位盡量不要設計為字元型,這會降低查詢和連接的性能,並會增加存儲開銷。這是因為引擎在處理查詢和連接時會 逐個比較字元串中每一個字元,而對於數字型而言只需要比較一次就夠了。
18、盡可能的使用 varchar/nvarchar 代替 char/nchar ,因為首先變長欄位存儲空間小,可以節省存儲空間,其次對於查詢來說,在一個相對較小的欄位內搜索效率顯然要高些。
19、任何地方都不要使用 select * from t ,用具體的欄位列表代替「*」,不要返回用不到的任何欄位。
20、盡量使用表變數來代替臨時表。如果表變數包含大量數據,請注意索引非常有限(只有主鍵索引)。
21、避免頻繁創建和刪除臨時表,以減少系統表資源的消耗。
22、臨時表並不是不可使用,適當地使用它們可以使某些常式更有效,例如,當需要重復引用大型表或常用表中的某個數據集時。但是,對於一次性事件,最好使 用導出表。
23、在新建臨時表時,如果一次性插入數據量很大,那麼可以使用 select into 代替 create table,避免造成大量 log ,以提高速度;如果數據量不大,為了緩和系統表的資源,應先create table,然後insert。
24、如果使用到了臨時表,在存儲過程的最後務必將所有的臨時表顯式刪除,先 truncate table ,然後 drop table ,這樣可以避免系統表的較長時間鎖定。
25、盡量避免使用游標,因為游標的效率較差,如果游標操作的數據超過1萬行,那麼就應該考慮改寫。
26、使用基於游標的方法或臨時表方法之前,應先尋找基於集的解決方案來解決問題,基於集的方法通常更有效。
27、與臨時表一樣,游標並不是不可使用。對小型數據集使用 FAST_FORWARD 游標通常要優於其他逐行處理方法,尤其是在必須引用幾個表才能獲得所需的數據時。在結果集中包括「合計」的常式通常要比使用游標執行的速度快。如果開發時 間允許,基於游標的方法和基於集的方法都可以嘗試一下,看哪一種方法的效果更好。
28、在所有的存儲過程和觸發器的開始處設置 SET NOCOUNT ON ,在結束時設置 SET NOCOUNT OFF 。無需在執行存儲過程和觸發器的每個語句後向客戶端發送 DONE_IN_PROC 消息。
29、盡量避免向客戶端返回大數據量,若數據量過大,應該考慮相應需求是否合理。
30、盡量避免大事務操作,提高系統並發能力。
『柒』 若要提交大數據量的數據,則應採用什麼方法
表單在form裡面,使method=「get」就可以了,get和post傳值相差不多,一般表現在安全性和傳值的大小存在差異。相關的具體內容可以上網查查
『捌』 JSP頁面表單怎麼提交大數據,求分享,求交流
在動態生成table時對每個input賦予不同名稱 然後數據提交時同樣用生成表格的方法讀取用戶輸入的數據 然後更新即可
『玖』 若要利用表單提交大數據量的數據,則應採用 提交方法,表單提交後的數據處理程序由表單的 屬性指定
別是最後一問,好像有點奇怪,如何用Sql語句返回一個記錄集的欄位數?我都不明白!一下答案僅供參考啊!
一、單項選擇題:(每空2分,共30分)
1.在編寫ASP動態網頁時,通常使用的腳本語言是( A )。
A. VBScript或JavaScript B. C# C. VB D. VB.net
2.若要獲得名為form1的表單中文本框架user的值,以下方法正確的是( D )。
A. username= form1. user B. username=document. form1. user
B. username=document. user.value D. username=document. form1. user.value
3.以下標記中,可用來產生滾動文字或圖片的是( B )。
A.<scroll> B. <marquee> C. <textarea> D. <iframe>
4.以下標記符中,用於設置頁面標題的是( A )。
A. <title> B. <caption> C. <head> D. <html>
5.若要設置網頁的背景圖像為bg.jpg,以下用法中正確的是( A )。
A. <body background=bg.jpg> B. <body bground=bg.jpg>
C. <body image=bg.jpg> D. <body bgcolor=bg.jpg>
6.在靜態網頁中嵌入ASP代碼時,為了與HTML標記符區分開來,這部分代碼應使用( A )符號將其括起來。
A. <%...%> B. < ?... ?> C. <.../> D. <#...#>
7.ASP動態網頁中的ASP代碼是由( B )負責解釋執行的。
A. 客戶端瀏覽器 B. IIS Web伺服器 C. 伺服器端瀏覽器 D. HTML解釋器
8.在ASP提供的內置對象中,利用( B )對象的write方法,可實現從Web伺服器向客戶端瀏覽器輸出內容。
A. Request B. Response C. Server D. Session
9.伺服器端要獲得客戶端所提交的表單數據,應使用( B )對象來實現。
A. Response B. Request C. Server D. Session
10. 記錄集對象創建後為使其生效,應使用記錄集對象的( A )方法來打開記錄集。
A.open B. execute C. close D.openrecordset
11. 若要將記錄集指針定位到記錄集的最後一條記錄,則可使用( D )方法來實現。
A.movefirst B. movenext C. moveprevious D. movelast
12.若要將虛擬路徑轉換為真實的物理路徑,以下語句中正確的是(D )。
A.Response.mappath(虛擬路徑) B. Request.mappath(虛擬路徑)
C. Server.URLEncode(虛擬路徑) D. Server.mappath(虛擬路徑)
13.若要創建一個對於訪問網站的所有用戶都有效的變數flag,以下方法中正確的是( C )。
A.Session(「flag」)=0 B. Session(flag)=0
C. Application(「flag」)=0 D. Application(flag)=0
14.在伺服器端,若要將頁面導航到index.asp,應使用Response對象的( C )方法。
A.href B. Transfer C. Redirect D. flush
15.以下連接對象的創建方法,正確的是( D )。
A.conn=CreateObject(「ADODB.Connection」)
B. conn=Server.CreateObject(「ADODB.Connection」)
C. Set conn= Server.CreateObject(ADODB.Connection)
D. Set conn= Server.CreateObject(「ADODB.Connection」)
二、多選題(每題3分,共30分)
1. 下面哪些標記是用於HTML文件的頭部的( ABD )
A.<Title> B.<Meta> C.<Embed> D.<Base>
E.<Frame> F.<Bgsound> G.<Form> H.<Pre>
2. 要獲得記錄集rs中,當前記錄的「用戶名」欄位的值,該欄位的順序號為2,以下用法中,不正確的是( AEG )。
A.fdvalue=rs(2) B. fdvalue=rs.fields(「2」) C. fdvalue=rs.fields(2)
D. fdvalue=rs.fields(「用戶名」) E. fdvalue=rs.fields(「用戶名」).value
F. fdvalue=rs(用戶名) G. fdvalue=rs(「用戶名」)
3. 以下標記符中,沒有對應的結束標記的是(BEGH )。
A. <body> B. <br> C. <html> D. <title> E. <img> F. <a>
G. <input> H. <link>
4.若表單提交時採用的是Get方式,則伺服器端要獲得表彰所提交的數據,可採用( BC )來實現。
A. Request.Form(「表單域名」) B. Request.QueryString(「表單域名」)
C. Request(「表單域名」) D. Request.QueryString(表單域名)
E. Request.Form(表單域名) F. Request(表單域名)
5.伺服器向客戶端輸出「注冊成功」,以下語句中能實現該操作要求的是( CD )。
A.Response.write 注冊成功 B. Response.write(注冊成功)
C.Response.write(「注冊成功」) D. Response.write 「注冊成功」
6. 下面的HTML語句中,可以實現將文字顏色設置成黑色的是( AB )
A.<FONT Color=Black> B.<FONT Color=」#000000」>
C.<FONT Color=」000000」> D.< FONT Color=」FFFFFF」>
7.以下對ASP的描述,正確的是( ABCD )
A.ASP是一種Web編程語言 B. ASP頁面運行於伺服器端
C.ASP默認的腳本編程語言是VBScript,但也可使用其他的腳本語言
D.ASP除了可使用內置的對象外,也可根據需要創建其他對象,但所創建的對象必須在伺服器上注冊
8.以下對象哪些屬於ASP內置的對象( ABDEG )
A.Request B. Response C. RecordSet D. Server E. Session
F. Connection H. Command G. Application
9.在VBScript中,字元串連接可使用的運算符有( AD )。
A. + B. - C. $ D. &
10.在以下事件中,屬於瀏覽器自身產生的事件有( AC )。
A.Load B. Submit C. UnLoad D. MouseOver
三、填空題(每空1分,共15分)
1.判斷記錄指針是否到了記錄集的末尾的屬性是( EOF ),向下移動指針,可調用記錄集對象的( MoveNext )方法來實現。
2.關閉連接並徹底釋放所佔用的系統資源,應調用連接對象的( Close )方法,並使用( Set )語句來實現。
3.為了建立與資料庫的連接,必須調用連接對象的( Connection )方法,連接建立後,可利用連接對象的( Execute )方法來執行SQL語句。
4.表單對象的名稱由( name )屬性設定;數據提交方式由( method )屬性來指定;若要提交大數據量的數據,則應採用( post )方法;表單提交後的數據處理程序由( action )屬性指定。
5.若要獲得當前記錄集的記錄條數,可使用( recordset )對象的( recordcount )屬性來實現。另外,也可通過執行SQL語句( select count(數據名) from 數據表 )來獲得表記錄的總數,此時SQL語句執行後,所返回的記錄集有( rs.count(0) )條記錄,該記錄有( )個欄位。
四、判斷題:(每題1分,共10分)
1.SQL語句不區分大小寫,而VBScript語句則區分大小寫。( F )
2.利用SQL的delete語句可刪除一個表或索引。(T )
3.利用Application對象存儲變數,可創建作用域跨頁或跨用戶的變數。(T )
4.Session對象所存儲的變數,在當前用戶所請求的每個頁面中均有效。( F )
5、HTML文件存儲在任何目錄下都可以正常瀏覽到,而ASP文件只有存儲在網站的虛擬目錄或主目錄下才能正常瀏覽到。( T )
6、表單使用Post方法傳遞數據,則接收頁面可用Request.Querysting(「表單對象名稱」)獲取表單數據。( F )
7、在SQL語句中,用「%」表示一個任意字元。( T )
8.在JavaScript中,內置的對象在使用時必須創建它的實例。( T )
9. 要篩選出成績表中數學成績在80~90分之間(含80和90分),可用「Select * From 成績表 where 數學 Between 80 To 90」語句。( X )
10.在瀏覽器中通過「查看」菜單下的「源文件」項,可查看ASP網頁的真實源代碼。( F )
五、程序填空:(每空3分,共15分)
(請按要求在相應位置填寫合適的語句,或寫出語句的作用)
<%
Set newconn = Server.CreateObject("ADODB.Connection")
DBPath = Server.MapPath("MyDatabase.mdb") 『該語句作用:將資料庫虛擬路徑轉換為物理路徑,並且賦值到Dbpath上_______________________
newconn.Open "provider=Microsoft.jet.oledb.4.0;data source=" & DBPath
SQLcmd = "select * from STOCK"
Set RS = newconn.Execute(SQLcmd)
%>
<table align="center">
<tr bgcolor="aqua">
<%For i = 0 To RS.Fields.Count - 1%>
<th><%=RS(i).Name%>
<%Next%>
<%DO While _not rs.eof_______________ %> <!--填語句:當指針沒有指向文件尾的時候進行循環-->
<tr bgcolor="yellow">
<%For i = 0 To RS.Fields.Count - 1%>
<td><%=RS(i)%> 『該語句作用:___循環輸出當前計數___________________________
<%Next%>
<%
RS.MoveNext 『該語句作用:____移動記錄集指針到下一條____________________
Loop
RS.Close
newconn .colse______________ 『關閉資料庫連接對象
%>
</table>
『拾』 如何向Oracle資料庫表中進行大數據量的插入並提交
一次折騰幾千萬的話,
那麼設置一下,
有
20W了,
就自動提交一下。內
set
autocommit
on;
set
autocommit
200000;
然後,假如你的目標容資料庫,
是歸檔的話,
可以
INSERT
/*+
append
*/
INTO
目標表
nologging
SELECT
*
FROM
源表@DBLINK;
commit;
set
autocommit
off;
假如你的
目標表
上面,
有
索引的話,
建議先刪除
索引。
等
上面的
INSERT
語句執行完畢後,
再重建索引。