为什么我的代码不起作用,所以将记录添加到SQL数据库

时间:2019-06-25 15:59:59

标签: javascript html sql sql-server

我只是设置一个SQL Server数据库,最初我创建了一个名为“ Contacts”的表,并在MS Server Management Studio中手动向其中添加了2条记录。然后,我用下面的代码对其进行测试,以查看是否可以使用JavaScript通过我的网站向其中添加新记录。我已经运行了代码并且没有错误,但是它也没有向数据库添加新记录吗?有人可以看一下,看看他们是否看到任何原因,为什么这样做不起作用?

我已经用Google搜索了它,但是找不到任何解决方案。

  <!-- Open Database & add to it -->      
  <script type="text/javascript">
      var db = openDatabase('C:/Program Files/Microsoft SQL 
               Server/MSSQL14.SQLEXPRESS/MSSQL/DATA/SFF-Database.mdf', 
                '1.0', 'Test DB', 8 * 1024 * 1024);
      var msg;

       db.transaction(function(tx) {
      //  tx.executeSql('CREATE TABLE IF NOT EXISTS CONTACTS (FirstName, 
                         LastName, Address, City, State, PostalCode)');
      tx.executeSql('INSERT INTO CONTACTS VALUES (3, "Jeff", "Williams", 
                      "32568 Williams Street NW", "Portland", "OR", 
                       "93445")');
      msg = '<p>Log message created and row inserted.</p>';
              document.querySelector('#status').innerHTML = msg;
       })

      db.transaction(function(tx) {
         tx.executeSql('SELECT * FROM CONTACTS', [], function(tx, results) 
      {
      var len = results.rows.length,
        i;
      msg = "<p>Found rows: " + len + "</p>";
      document.querySelector('#status').innerHTML += msg;

      for (i = 0; i < len; i++) {
        msg = "<p><b>" + results.rows.item(i).FirstName + " " + 
            results.rows.item(i).LastName + " " + 
            results.rows.item(i).Address + " " + 
            results.rows.item(i).City + " " + results.rows.item(i).State +
            " " + results.rows.item(i).PostalCode + "</b></p>";
        document.querySelector('#status').innerHTML += msg;
        }
      }, null);
    });
  </script>

为什么没有错误?但它不会将记录添加到数据库中。

1 个答案:

答案 0 :(得分:0)

  

有人可以看看这个,看看是否有什么原因不能解决这个问题?

这不是SQL Server兼容的代码:

CREATE TABLE IF NOT EXISTS

如果您搜索或搜索该命令,还有其他StackOverflow主题涉及此主题。

CREATE TABLE IF NOT EXISTS equivalent in SQL Server