nodejs環境使用Typeorm連接查詢Oracle

来源:https://www.cnblogs.com/KKKA/archive/2019/12/05/11984360.html

首先是typeorm的官方地址, 國內有人翻了中文版,不保證時效性 ·通過npm安裝下列包: typeorm //typeorm連接資料庫 @types/node //類型系統 typescript //ts基礎 oracledb //oracle基礎 ts-node //nodejs編譯運行ts的 ...


首先是typeorm的官方地址

國內有人翻了中文版,不保證時效性

·通過npm安裝下列包:

  • typeorm //typeorm連接資料庫
  • @types/node //類型系統
  • typescript //ts基礎
  • oracledb //oracle基礎
  • ts-node //nodejs編譯運行ts的工具;

·根路徑配置:

  • package.json //項目依賴、腳本、描述等
  • tsconfig.json //ts編譯設置
 1 {
 2     "compilerOptions": {
 3         "module": "commonjs",
 4         "noImplicitAny": true,
 5         "removeComments": true,
 6         "preserveConstEnums": true,
 7         "sourceMap": true,
 8         "outDir": "./dist",
 9         "emitDecoratorMetadata": true,  //typeorm特需
10         "experimentalDecorators": true  //typeorm特需
11     },
12     "include": [
13         "src/**/*"
14     ],
15     "exclude": [
16         "node_modules",
17         "**/*.spec.ts"
18     ]
19 }

 

  • ormconfig.json //資料庫連接參數 
{
    "type": "oracle",
    "host": "10.16.2.41",
    "port": 1521,
    "username": "admin",
    "password": "admin",
    "sid": "ORCL",
    "synchronize": true,
    "logging": true,
    "entities": [
        "src/entity/**/*.ts"
    ],
    "migrations": [
        "src/migration/**/*.ts"
    ],
    "subscribers": [
        "src/subscriber/**/*.ts"
    ]
}

 

  • .vscode配置:launch.json ,主要配置vscode在debug時由ts編譯所得的js路徑,此項與項目勿關,只為了方便調試
 1 {
 2     "name": "Current TS File",
 3     "type": "node",
 4     "request": "launch",
 5     "program": "${workspaceRoot}\\node_modules\\ts-node\\dist\\bin.js",
 6     "args": [
 7         "${relativeFile}"
 8     ],
 9     "cwd": "${workspaceRoot}",
10     "protocol": "inspector"
11 }

 

·編寫主體:

根路徑下創建/編輯index.ts(名字可自定義),配置package中start腳本命令為ts-node index.ts,
 1 import "reflect-metadata";
 2 import {createConnection} from "typeorm";
 3 import {xxx} from "./src/entity/xxx";  //引入數據表結構映射文件
 4 
 5 createConnection().then(async connection => {  //連接參數為空時自動按照路徑下ormconfig.json信息連接
 6     /*let a = await connection.query(
 7         `SELECT * FROM xxx`
 8     ); *///直接使用原生sql語句查詢
 9  
10     let a = await connection.manager.find(xxx)  //使用連接器查詢 connection.manager
11     console.log("result: ", a);
12 }).catch(error => console.log(error));

 在src/entity/下構建數據表實體結構xxx.js,格式參考官網

 在cmd根路徑運行npm start,或使用vscode調試

 至此,我們已經成功使用typeorm連接到了Oracle資料庫,若要構成完整的後端只需添加中間件等等

·與sequelize的差異

從Sequelize轉移到typeorm,是因為sequelize官方不支持連接Oracle

typeorm像名字中描述的那樣,是個使用typescript編寫的、類型系統非常完整的資料庫關係映射,放張數據類型截圖:

 

 這還是js嗎?當然,如此完整的類型系統得益於typescript,我們也可以在構建時酌情使用類型聲明,因為它不是必須的(本質仍是js)

 很多類型都可以使用js原生類型+長度代替,是否使用專用類型聲明取決於實際需求

 

 根據資料庫自動生成/更新映射文件腳本會相對複雜

 

 typescript也是初次接觸,文章只是通過短短幾星期的摸索得來,內容難免有誤,若有錯誤還請點撥,謝謝

 
 
 

您的分享是我們最大的動力!

更多相關文章
  • 這裡介紹的是Win平臺的安裝方法,其他平臺請至Github>Puppeteer. 首先要安裝node.js 可以看我這篇的開頭>【Angular】學習筆記-環境部署、項目建立相關 1.新建項目目錄 2.打開gitbush(常用的Terminal都可以) 3.鍵入 npm i puppeteer 4. ...
  • 總結獲取元素的方式 1. 根據id屬性的值獲取元素,返回來的是一個元素對象 document.getElementById("id屬性的值"); document.getElementById("btn"); 2. 根據標簽名字獲取元素,返回來的是一個偽數組,裡面保存了多個的DOM對象 docume ...
  • 本文由葡萄城技術團隊於博客園翻譯並首發 轉載請註明出處:葡萄城官網,葡萄城為開發者提供專業的開發工具、解決方案和服務,賦能開發者。 如果我們自己編寫從URL中分析和提取元素的代碼,那麼有可能會比較痛苦和麻煩。程式員作為這個社會中最“懶”的群體之一,無休止的重覆造輪子必然是令人難以容忍的,所以大多數瀏 ...
  • 條件語句用於基於不同條件執行不同的動作。 條件語句 在您寫代碼時,經常會需要基於不同判斷執行不同的動作。 您可以在代碼中使用條件語句來實現這一點。 在 JavaScript 中,我們可使用如下條件語句: 使用 if 來規定要執行的代碼塊,如果指定條件為 true 使用 else 來規定要執行的代碼塊 ...
  • 案例1:點擊按鈕禁用文本框 <input type="button" value="禁用文本框" id="btn" /> <input type="text" value="文本框" id="txt" /> <script> document.getElementById("btn").onclic ...
  • part1複習 JavaScript分三個部分: 1. ECMAScript標準 JS基本的語法 2. DOM:Document Object Model 文檔對象模型 3. BOM:瀏覽器對象模型 DOM的作用: 操作頁面的元素 DOM樹: 把html頁面或者是xml文件看成是一個文檔,文檔就是一 ...
  • 安裝完上述插件之後,就可以進行引用了 如果源碼出現以下錯誤:則說明sass版本過高,只需要調為較低版本即可。實證有效版本:7.3.1 修改之後刪除 文件夾 然後 重新下載 即可 TypeError: this.getResolve is not a function ...
  • 一、寫在前頭 接到某廠電話問什麼是事件代理的時候,一開始說addEventListener,然後他說直接綁定新的元素不會報dom不存在的錯誤嗎?然後我就混亂了,我印象中這個方法是可以綁定新節點的。後面才知道,原來他要考察的是事件委托(代理)的原理,他指的是未來還不清楚會創建多少個節點,所以沒辦法實現 ...
一周排行
  • 比如要拆分“呵呵呵90909086676喝喝999”,下麵當type=0返回的是中文字元串“呵呵呵,喝喝”,type=1返回的是數字字元串“90909086676,999”, private string GetStrings(string str,int type=0) { IList<strin ...
  • Swagger一個優秀的Api介面文檔生成工具。Swagger可以可以動態生成Api介面文檔,有效的降低前後端人員關於Api介面的溝通成本,促進項目高效開發。 1、使用NuGet安裝最新的包:Swashbuckle.AspNetCore。 2、編輯項目文件(NetCoreTemplate.Web.c ...
  • 2020 年 7 月 30 日, 由.NET基金會和微軟 將舉辦一個線上和為期一天的活動,包括 微軟 .NET 團隊的演講者以及社區的演講者。本次線上大會 專註.NET框架構建微服務,演講者分享構建和部署雲原生應用程式的最佳實踐、模式、提示和技巧。有關更多信息和隨時瞭解情況:https://focu... ...
  • #abp框架Excel導出——基於vue #1.技術棧 ##1.1 前端採用vue,官方提供 UI套件用的是iview ##1.2 後臺是abp——aspnetboilerplate 即abp v1,https://github.com/aspnetboilerplate/aspnetboilerp ...
  • 前言 本文的文字及圖片來源於網路,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理。 作者:碧茂大數據 PS:如有需要Python學習資料的小伙伴可以加下方的群去找免費管理員領取 input()輸入 Python提供了 input() 內置函數從標準輸入讀入一 ...
  • 從12年到20年,python以肉眼可見的趨勢超過了java,成為了當今It界人人皆知的編程語言。 python為什麼這麼火? 網路編程語言搜索指數 適合初學者 Python具有語法簡單、語句清晰的特點,這就讓初學者在學習階段可以把精力集中在編程對象和思維方法上。 大佬都在用 Google,YouT ...
  • 在社會上存在一種普遍的對培訓機構的學生一種歧視的現象,具體表現在,比如:當你去公司面試的時候,一旦你說了你是培訓機構出來的,那麼基本上你就涼了,那麼你瞞著不說,然後又通過了面試成功入職,但是以後一旦在公司被髮現有培訓經歷,可能會面臨被降薪,甚至被辭退,培訓機構出來的學生,在用人單位眼裡就是能力低下的 ...
  • from typing import List# 這道題看了大佬寫的代碼,經過自己的理解寫出來了。# 從最外圍的四周找有沒有為O的,如果有的話就進入深搜函數,然後深搜遍歷# 判斷上下左右的位置是否為Oclass Solution: def solve(self, board: List[List[s ...
  • import requests; import re; import os; # 1.請求網頁 header = { "user-agent":'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537.36 (KHTML, li ...
  • import requests; import re; import os; import parsel; 1.請求網頁 header = { "user-agent":'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537. ...