溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

JavaScript基于activexobject連接遠(yuǎn)程數(shù)據(jù)庫SQL Server 2014的方法

發(fā)布時(shí)間:2020-09-23 02:00:32 來源:腳本之家 閱讀:282 作者:不想長大啊 欄目:web開發(fā)

本文實(shí)例講述了JavaScript基于activexobject連接遠(yuǎn)程數(shù)據(jù)庫SQL Server 2014的方法。分享給大家供大家參考,具體如下:

最近翻開一本10年前買的JavaScript的書,這本書買回來只看了前半部分,后面的一直沒看,也一直沒有從事這方的工作。

看到有一節(jié)寫著js連access接數(shù)據(jù)庫,于是照著書上的代碼,寫了一段在chrome瀏覽器中運(yùn)行,發(fā)現(xiàn)完全沒反應(yīng)。

查了一下才發(fā)現(xiàn),這個(gè)activexobject只有微軟的IE支持,其他的瀏覽器都不支持,我想可能是由于連接數(shù)據(jù)庫、訪問文件等屬于不安全的操作,應(yīng)該是讓服務(wù)器端來做,所以才導(dǎo)致絕大多數(shù)瀏覽器都不支持這個(gè)功能。

不過如果從另一個(gè)角度看,實(shí)際上這種功能適合服務(wù)器端的javascript,也就是說下面的代碼適合在服務(wù)器端運(yùn)行,而不是在客戶端運(yùn)行。

還有,如果這個(gè)代碼僅僅是在本地的個(gè)人電腦上運(yùn)行,也是有用的。

比如,我只是想連接數(shù)據(jù)庫,然后把結(jié)果輸出,我不想搭建一個(gè)web服務(wù)器,然后還得寫個(gè)服務(wù)器端程序,也不想安裝其他軟件,太麻煩,比如,用Java或者c#等,就是想越簡(jiǎn)單越好,什么也不用裝。其實(shí)這么一想,好像也只有用瀏覽器能達(dá)到這個(gè)要求了,瀏覽器特別方便,也無需安裝,所見即所得,也方便調(diào)試代碼。

所以,從這個(gè)特殊的需求來看,這個(gè)功能再適合不過了。

接下來說一下代碼的基本思路:

(1)通過window.ActiveXObject 判斷是否支持activexobject。
(2)獲取瀏覽器名稱、平臺(tái)、版本。
(3)通過activexobject獲取了E盤的卷名稱
(4)連接sql server 2014,數(shù)據(jù)庫名test,數(shù)據(jù)源是另外一臺(tái)機(jī)器的ip地址或者主機(jī)名。
(5)連接上后,執(zhí)行sql:select * from tb,查詢數(shù)據(jù)。
(6)遍歷每行數(shù)據(jù),同時(shí)在循環(huán)中遍歷1行數(shù)據(jù)中的每個(gè)字段的值。

創(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ù)學(xué)',80),
   (3,'英語',900),
   (4,'政治',65),
   (5,'物理',65),
   (6,'化學(xué)',85),
   (7,'生物',55),
   (8,'地理',100)

JavaScript基于activexobject連接遠(yuǎn)程數(shù)據(jù)庫SQL Server 2014的方法

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>" +
              "瀏覽器平臺(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盤的卷名稱是:" + 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 上運(yùn)行的效果

JavaScript基于activexobject連接遠(yuǎn)程數(shù)據(jù)庫SQL Server 2014的方法

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《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ì)有所幫助。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI