JavaScript基于activexobject連接遠(yuǎn)程數(shù)據(jù)庫(kù)SQL Server 2014的方法
本文實(shí)例講述了JavaScript基于activexobject連接遠(yuǎn)程數(shù)據(jù)庫(kù)SQL Server 2014的方法。分享給大家供大家參考,具體如下:
最近翻開(kāi)一本10年前買(mǎi)的JavaScript的書(shū),這本書(shū)買(mǎi)回來(lái)只看了前半部分,后面的一直沒(méi)看,也一直沒(méi)有從事這方的工作。
看到有一節(jié)寫(xiě)著js連access接數(shù)據(jù)庫(kù),于是照著書(shū)上的代碼,寫(xiě)了一段在chrome瀏覽器中運(yùn)行,發(fā)現(xiàn)完全沒(méi)反應(yīng)。
查了一下才發(fā)現(xiàn),這個(gè)activexobject只有微軟的IE支持,其他的瀏覽器都不支持,我想可能是由于連接數(shù)據(jù)庫(kù)、訪問(wèn)文件等屬于不安全的操作,應(yīng)該是讓服務(wù)器端來(lái)做,所以才導(dǎo)致絕大多數(shù)瀏覽器都不支持這個(gè)功能。
不過(guò)如果從另一個(gè)角度看,實(shí)際上這種功能適合服務(wù)器端的javascript,也就是說(shuō)下面的代碼適合在服務(wù)器端運(yùn)行,而不是在客戶(hù)端運(yùn)行。
還有,如果這個(gè)代碼僅僅是在本地的個(gè)人電腦上運(yùn)行,也是有用的。
比如,我只是想連接數(shù)據(jù)庫(kù),然后把結(jié)果輸出,我不想搭建一個(gè)web服務(wù)器,然后還得寫(xiě)個(gè)服務(wù)器端程序,也不想安裝其他軟件,太麻煩,比如,用Java或者c#等,就是想越簡(jiǎn)單越好,什么也不用裝。其實(shí)這么一想,好像也只有用瀏覽器能達(dá)到這個(gè)要求了,瀏覽器特別方便,也無(wú)需安裝,所見(jiàn)即所得,也方便調(diào)試代碼。
所以,從這個(gè)特殊的需求來(lái)看,這個(gè)功能再適合不過(guò)了。
接下來(lái)說(shuō)一下代碼的基本思路:
(1)通過(guò)window.ActiveXObject 判斷是否支持activexobject。
(2)獲取瀏覽器名稱(chēng)、平臺(tái)、版本。
(3)通過(guò)activexobject獲取了E盤(pán)的卷名稱(chēng)
(4)連接sql server 2014,數(shù)據(jù)庫(kù)名test,數(shù)據(jù)源是另外一臺(tái)機(jī)器的ip地址或者主機(jī)名。
(5)連接上后,執(zhí)行sql:select * from tb,查詢(xún)數(shù)據(jù)。
(6)遍歷每行數(shù)據(jù),同時(shí)在循環(huán)中遍歷1行數(shù)據(jù)中的每個(gè)字段的值。
創(chuàng)建數(shù)據(jù)庫(kù)、創(chuàng)建表代碼:
create database Test; go use test; go if object_id('tb') is not null drop table tb; go CREATE TABLE TB(ID INT,NAME NVARCHAR(20),SCORE NUMERIC(10,2)); INSERT INTO TB(ID,NAME,SCORE) VALUES(1,'語(yǔ)文',100), (2,'數(shù)學(xué)',80), (3,'英語(yǔ)',900), (4,'政治',65), (5,'物理',65), (6,'化學(xué)',85), (7,'生物',55), (8,'地理',100)
javascript 代碼:
<!doctype html> <html> <head> <meta charset="gb2312"> <title>Document</title> <script language="javascript"> function query() { var ss = (window.ActiveXObject) ? "此瀏覽器支持ActiveXObject" : "此瀏覽器不支持ActiveXObject"; //alert(navigator.appVersion); var xx = document.getElementById("support"); var a = ( navigator.appVersion+";").split(";"); xx.innerHTML = "瀏覽器名稱(chēng):" + navigator.appName +"<br>" + "瀏覽器平臺(tái):" + navigator.platform +"<br>" + "瀏覽器版本:" + a[1].replace("MS","") + "<br>"+ "<br><b>"+ss+"</b><br><br>"; var o = new ActiveXObject("Scripting.FileSystemObject"); var od = o.GetDrive("E"); xx.innerHTML += ("E盤(pán)的卷名稱(chēng)是:" + od.VolumeName); //連接數(shù)據(jù)庫(kù) var db = new ActiveXObject("ADODB.Connection"); db.open("Provider=SQLOLEDB.1;Data Source=WIN-6;User ID=sa;Password=yupeigu;Initial Catalog=test"); var rs = db.Execute("select * from tb"); var c = rs.Fields.Count-1; //拼接表的字段名稱(chēng) var str = "<table border=1><tr>"; for(var i = 0; i <=c; i++) { str += "<td>" + rs.Fields(i).Name + "</td>"; } str += "</tr>"; //拼接表的數(shù)據(jù) while(!rs.EOF) { str += "<tr>"; for(var i = 0;i <= c; i++) { str += "<td>" + rs.Fields(i).Value + "</td>"; } str += "</tr>"; rs.moveNext(); } str += "</table>"; var yy = document.getElementById("sp"); yy.innerHTML = str; rs.Close(); db.Close(); } </script> </head> <body > <input type="button" onclick="query()" value="查詢(xún)SQL Server 2014的Test數(shù)據(jù)庫(kù)的tb表數(shù)據(jù)"> <p> <span id="support"></span> <hr><br> <span id="sp"></span> </p> </body> </html>
在IE11 和 IE7 上運(yùn)行的效果
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》、《JavaScript排序算法總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》及《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
axios的get請(qǐng)求傳入數(shù)組參數(shù)原理詳解
這篇文章主要為大家介紹了axios的get請(qǐng)求傳入數(shù)組參數(shù)原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06JavaScript基于對(duì)象方法實(shí)現(xiàn)數(shù)組去重及排序操作示例
這篇文章主要介紹了JavaScript基于對(duì)象方法實(shí)現(xiàn)數(shù)組去重及排序操作,涉及javascript基于對(duì)象方法的數(shù)組遍歷、比較、去重、排序等相關(guān)操作技巧,需要的朋友可以參考下2018-07-07英文首字母全大寫(xiě)的js實(shí)現(xiàn)腳本
輸入內(nèi)容活直接點(diǎn)轉(zhuǎn)換即可,講單詞的首字母大寫(xiě)。2008-09-09text-align:justify實(shí)現(xiàn)文本兩端對(duì)齊 兼容IE
對(duì)于text-align 我們?cè)偈煜げ贿^(guò)了,可是它有個(gè)justify屬性,平時(shí)很少用到,就鮮為人知了。justify是一種文本靠?jī)蛇叢季址绞?,一般?yīng)用于書(shū)刊雜志排版;合理運(yùn)用text-align:justify 有時(shí)會(huì)省去很多開(kāi)發(fā)的時(shí)間,通過(guò)本文介紹text-align:justify實(shí)現(xiàn)文本兩端對(duì)齊 兼容IE2015-08-08js中offset,client , scroll 三大元素知識(shí)點(diǎn)總結(jié)
在本篇文章里小編給大家整理了關(guān)于js 元素offset,client , scroll 三大系列總結(jié),有需要的朋友們可以學(xué)習(xí)下。2019-09-09JS 輸入字?jǐn)?shù)判斷實(shí)現(xiàn)代碼
判斷輸入的字?jǐn)?shù)2009-08-08Enter轉(zhuǎn)換為T(mén)ab的小例子(兼容IE,Firefox)
這篇文章介紹了Enter轉(zhuǎn)換為T(mén)ab的小例子(兼容IE,Firefox),有需要的朋友可以參考一下2013-11-11js實(shí)現(xiàn)圖片上傳到服務(wù)器和回顯
這篇文章主要介紹了js實(shí)現(xiàn)圖片上傳到服務(wù)器和回顯,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-01-01JavaScript實(shí)現(xiàn)格式化字符串函數(shù)String.format
本文主要介紹了JavaScript實(shí)現(xiàn)格式化字符串函數(shù)String.format(可自動(dòng)解析引號(hào)轉(zhuǎn)義字符)。具有很好的參考價(jià)值,需要的朋友一起來(lái)看下吧2016-12-12