JavaScript基于activexobject連接遠程數(shù)據(jù)庫SQL Server 2014的方法
本文實例講述了JavaScript基于activexobject連接遠程數(shù)據(jù)庫SQL Server 2014的方法。分享給大家供大家參考,具體如下:
最近翻開一本10年前買的JavaScript的書,這本書買回來只看了前半部分,后面的一直沒看,也一直沒有從事這方的工作。
看到有一節(jié)寫著js連access接數(shù)據(jù)庫,于是照著書上的代碼,寫了一段在chrome瀏覽器中運行,發(fā)現(xiàn)完全沒反應(yīng)。
查了一下才發(fā)現(xiàn),這個activexobject只有微軟的IE支持,其他的瀏覽器都不支持,我想可能是由于連接數(shù)據(jù)庫、訪問文件等屬于不安全的操作,應(yīng)該是讓服務(wù)器端來做,所以才導(dǎo)致絕大多數(shù)瀏覽器都不支持這個功能。
不過如果從另一個角度看,實際上這種功能適合服務(wù)器端的javascript,也就是說下面的代碼適合在服務(wù)器端運行,而不是在客戶端運行。
還有,如果這個代碼僅僅是在本地的個人電腦上運行,也是有用的。
比如,我只是想連接數(shù)據(jù)庫,然后把結(jié)果輸出,我不想搭建一個web服務(wù)器,然后還得寫個服務(wù)器端程序,也不想安裝其他軟件,太麻煩,比如,用Java或者c#等,就是想越簡單越好,什么也不用裝。其實這么一想,好像也只有用瀏覽器能達到這個要求了,瀏覽器特別方便,也無需安裝,所見即所得,也方便調(diào)試代碼。
所以,從這個特殊的需求來看,這個功能再適合不過了。
接下來說一下代碼的基本思路:
(1)通過window.ActiveXObject 判斷是否支持activexobject。
(2)獲取瀏覽器名稱、平臺、版本。
(3)通過activexobject獲取了E盤的卷名稱
(4)連接sql server 2014,數(shù)據(jù)庫名test,數(shù)據(jù)源是另外一臺機器的ip地址或者主機名。
(5)連接上后,執(zhí)行sql:select * from tb,查詢數(shù)據(jù)。
(6)遍歷每行數(shù)據(jù),同時在循環(huán)中遍歷1行數(shù)據(jù)中的每個字段的值。
創(chuàng)建數(shù)據(jù)庫、創(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,'語文',100),
(2,'數(shù)學',80),
(3,'英語',900),
(4,'政治',65),
(5,'物理',65),
(6,'化學',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 = "瀏覽器名稱:" + navigator.appName +"<br>" +
"瀏覽器平臺:" + 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盤的卷名稱是:" + od.VolumeName);
//連接數(shù)據(jù)庫
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;
//拼接表的字段名稱
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="查詢SQL Server 2014的Test數(shù)據(jù)庫的tb表數(shù)據(jù)">
<p>
<span id="support"></span>
<hr><br>
<span id="sp"></span>
</p>
</body>
</html>
在IE11 和 IE7 上運行的效果

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript數(shù)學運算用法總結(jié)》、《JavaScript排序算法總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》及《JavaScript錯誤與調(diào)試技巧總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
相關(guān)文章
Js中FileReader讀取文件內(nèi)容方法詳解(async/await)
這篇文章主要給大家介紹了關(guān)于Js中FileReader讀取文件內(nèi)容(async/await)的相關(guān)資料,FileReader是前端進行文件處理的一個重要的Api,特別是在對圖片的處理上,如果你想知道圖片的處理原理,你就永遠不可能繞過它,需要的朋友可以參考下2023-11-11
es6 super關(guān)鍵字的理解與應(yīng)用實例分析
這篇文章主要介紹了es6 super關(guān)鍵字的理解與應(yīng)用,結(jié)合實例形式分析了es6 super關(guān)鍵字的功能、原理、用法及相關(guān)操作注意事項,需要的朋友可以參考下2020-02-02
簡單談?wù)凜ommonsChunkPlugin抽取公共模塊
下面小編就為大家分享一篇簡單談?wù)凜ommonsChunkPlugin抽取公共模塊,具有很的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12
將rmb數(shù)字位錢數(shù)轉(zhuǎn)化為中文錢數(shù)的js函數(shù)
用力將用戶輸入的錢數(shù),中文化輸出的函數(shù)代碼,需要的朋友可以參考下。2010-07-07

