工具 EZDML表結構設計器

来源:https://www.cnblogs.com/Aaxuan/archive/2018/04/24/8617816.html
-Advertisement-
Play Games

軟體官網:http://www.ezdml.com/ 作者郵箱:[email protected] EZDML EZDML是一個資料庫建表的軟體。 可快速的進行資料庫表結構設計,建立數據模型。 類似大家常用的資料庫建模工具如 PowerDesigner、ERWIN、ER-Studio 和 Rational- ...


軟體官網:http://www.ezdml.com/

作者郵箱:[email protected]

 

 EZDML

 

EZDML是一個資料庫建表的軟體。

可快速的進行資料庫表結構設計,建立數據模型。

類似大家常用的資料庫建模工具如 PowerDesigner、ERWIN、ER-Studio 和 Rational-Rose 等的超級精簡版。

該軟體是從 2006 年 4 月開發至今仍然在維護,最近在 2017 年 8 月 5 日 更新了 V2.15 版本。

作者的精神值得我們學習。

 

包含功能:

 

1. 表結構設計:創建表、欄位、主鍵、外鍵、索引和註釋;

2. 表描述:可直接編輯文字描述快速生成表結構,愛用鍵盤的人會喜歡這個功能;

3. 模型圖:自動生成模型圖;可設計和顯示物理/邏輯視圖,支持自動佈局、平移、縮小放大等操作;

4. 導入資料庫:導入資料庫中的已有對象,即所謂的逆向工程(支持ORACLE、MYSQL、SQLSERVER和ODBC);

5. 生成資料庫:可生成直接創建資料庫的SQL腳本;也可與現有資料庫比較,然後生成同步腳本的功能,不至於丟失現有數據;

6. 生成代碼:目前可生成C++、Pas、C#和Java的簡單類定義代碼;

7. 導出EXCEL。 

 

使用說明:


模型圖中可 按加減號放大縮小,方向鍵平移,R複原,F居中;

表的描述字中,可以輸入簡寫字母代替數據類型,S,I,F,D,Y,E,B分別代表文本,整數,浮點數,時間,真假,枚舉,文件,如 
  
測試表 
-------- 
ID PK 
RID FK 
標題 S(200) 
數量 I 
單價 F(10,2) 
日期 D 
註釋 S 
  
外鍵關係目前可以在模型圖上創建顯示,或在欄位的關聯表欄位里設置;

導入生成功能可支持ORACLE、MYSQL、SQLSERVER和ODBC資料庫; 

生成功能在未連接資料庫時,生成的是創建資料庫的初始化SQL;只有連接了資料庫,才會與資料庫進行比對生成升級SQL;

為避免數據丟失,同步資料庫時不會刪除欄位,但仍然會生成註釋形式的相應SQL;

 


修改INI文件自定義配置(菜單:工具|修改INI配置):

[DefaultFieldTypes] ——修改預設數據類型對應的物理類型
1=String:VARSTR(2000) ——修改邏輯類型名為String的物理類型名為VARSTR,預設長度為2000
2=Integer:DECIMAL ——修改邏輯類型名為Integer的物理類型名為DECIMAL,無預設長度
[CustFieldTypes] ——添加額外的數據類型到類型下拉列表
1=BigInt
2=Decimal
3=TestUnk
[CustDataTypeReplaces] ——指定替換欄位類型
1=VARCHAR2:NVARCHAR2 ——將VARCHAR2替換為NVARCHAR2(全字匹配)
2=NUMBER(10):DECIMAL ——將NUMBER(10)替換為DECIMAL(全字匹配)
3=%TEXT%:NCLOB ——將TEXT替換為NCLOB(模糊匹配,類似SQL中的like操作)
4=%RAW:BLOB ——將RAW替換為BLOB(左邊模糊匹配,右邊精確匹配,類似SQL中的like操作)
[Options]
AutoSaveMinutes=5  ——定時每5分鐘自動保存,保存為同目錄.tmp文件(打開時自動載入tmp,想恢復載入原始文件的話要先刪除tmp),為0則不保存
FieldNameMaxDrawSize=64  ——在模型圖上允許顯示的最大欄位名長度
FieldTypeMaxDrawSize=48  ——在模型圖上允許顯示的最大欄位類型長度
CreateSeqForOracle=0  ——禁止為ORACLE表生成序列號
OCIDLL=D:\oracle\ora112\instantclient\oci.dll  ——指定OCI.dll的路徑(用於instant client或裝了多個ORACLE client時)

 

還有一些快捷的小操作:

/ 鍵 縮放至最佳大小

在一個模型內,按表名的第一個字母的鍵,會直接打開該表的描述界面。

 

接下來講一下我認為能對我們日常開發有很大幫助的的功能,那就是他的腳本。

腳本語言是 pascal 語言,一個已經涼了的語言。所以不建議大家在上面花費精力。

而且該軟體的語言似乎和普通的 pascal 語言規則不太一樣,pascal是有幾種版本的,這裡我也懶得深入研究了。

 

下麵這個就是 C# 的實體類腳本,在軟體的預設基礎上修剪改造的。大家可以簡單理解一下,語言的語法都是相通的。

function DEF_CTMETAFIELD_DATATYPE_NAMES_CSHARP(idx: TCtFieldDataType): string;
begin
  case Integer(idx) of
    0: Result := 'unknown';
    1: Result := 'string';
    2: Result := 'int';
    3: Result := 'decimal';//替換double
    4: Result := 'DateTime?';//可空類型
    5: Result := 'bool';
    6: Result := 'enum';
    7: Result := 'var';
    8: Result := 'object';
    9: Result := 'List';
    10: Result := 'function';
    11: Result := 'EventHnadler';
    12: Result := 'type';
  else
    Result := 'unknown';
  end;
end;

//獲取屬性名
function getPublicName(N: string): string;
begin
  Result := N;
  if (Result <> '') then
    if Result[1] >= 'a' then
      if Result[1] <= 'z' then
        Result[1] := Chr(Ord(Result[1]) - (Ord('a') - Ord('A')));
end;

function GetDesName(p, n: string): string;
begin
  if p = '' then
    Result := n
  else
    Result := p;
end;




var
  I, L: Integer;
  clsName, S, T, V, FT: string;
  f: TCtMetaField;

//獲取欄位名
function GFieldName(Fld: TCtMetaField): string;
begin
  Result := GetDesName(f.Name, f.DisplayName);
end;

//獲取欄位類型
function GFieldType(Fld: TCtMetaField): string;
begin
    Result := DEF_CTMETAFIELD_DATATYPE_NAMES_CSHARP(f.DataType);
end;

//程式開始
procedure AddFieldInfo;
begin
  S := GetDesName(f.Name, f.DisplayName);
  begin
      FT := DEF_CTMETAFIELD_DATATYPE_NAMES_CSHARP(f.DataType);
    S := 'public ' + FT + ' ' + getPublicName(S)
      + '{'
      + 'get;'
      + 'set;'
      + '}' + #13#10;
  end;

  T := F.GetFieldComments;
  if T <> '' then
  begin
      S :='/// <summary>' + #13#10
      + '///' + T + #13#10
      + '/// </summary>' + #13#10
      + S;
  end;

  CurOut.Add('    ' + StringReplace(S, #13#10, #13#10'    ', [rfReplaceAll]));
end;


begin
  with CurTable do
  begin
    S := GetTableComments;

    CurOut.Add('');

    CurOut.Add('using System;');
    CurOut.Add('using System.Text;');
    CurOut.Add('');
    CurOut.Add('namespace ' + Name);
    CurOut.Add('{');

    S := GetTableComments;
    if S <> '' then
    begin
      S := StringReplace(S, '}', '%7D', [rfReplaceAll]);
      CurOut.Add('  //' + StringReplace(S, #13#10, #13#10'  ', [rfReplaceAll]));
    end;

    L := 0;
    for I := 0 to MetaFields.Count - 1 do
    begin
      f := MetaFields[I];
      S := GetDesName(f.Name, f.DisplayName);
      if L < Length(S) then
        L := Length(S);
    end;

    //表名
    clsName := Name;
    CurOut.Add('  [NPoco.TableName("' + clsName + '")]');
    CurOut.Add('  [NPoco.PrimaryKey("Id", AutoIncrement = true)]');
    CurOut.Add('  public class ' + clsName);
    CurOut.Add('  {');
    CurOut.Add('');

    //構造函數
    CurOut.Add('    public ' + clsName + '()');
    CurOut.Add('    {');
    CurOut.Add('    }');

    for I := 0 to MetaFields.Count - 1 do
    begin
      f := MetaFields[I];
      AddFieldInfo;
    end;

    CurOut.Add('  }');
    CurOut.Add('}');
  end;
end.

 


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

-Advertisement-
Play Games
更多相關文章
  • Golang的包管理亂得不行,各種工具橫空出世,各顯神通啊。用了幾個下來,發現 Glide 是比較好用的,使用了 vender 來進行管理,多個開發環境的版本不衝突,功能強大,配置文件也足夠簡單。初始化一個已有的工程想要引入glide進行管理→ glide create這時,Glide會掃描工程中所... ...
  • 之前用 Servlet + JSP 實現了一個 "簡易版的學生管理系統" ,在學習了 SSM 框架之後,我們來對之前寫過的項目重構一下! 技術準備 為了完成這個項目,需要掌握如下技術: Java 基礎知識 前端: HTML, CSS, JAVASCRIPT, JQUERY J2EE: Tomcat, ...
  • 從知乎作者Rui L學來的一招。應該用過 IPython 吧?想象一下,拋出異常時自動把你帶到 IPython Shell 是不是很開心?而且和普通的IPython不同,這個時候可以調用 p (print), up(up stack), down(down stack) 之類的命令。還能創建臨時變數... ...
  • 課前預習 1.編譯型語言:將源碼一次性轉化為二進位代碼再執行(嚼碎了再吃,執行效率高)優點:執行效率高;缺點:開發效率低,不能跨平臺。 解釋型語言:程式運行時,從上往下將源碼一句一句轉化為二進位的同時執行(邊解釋邊執行,一心二用所以執行效率低)優點:開發效率高,可跨平臺;缺點:執行效率低。 2.py ...
  • .NET 單元測試的利劍——模擬框架Moq 前言 這篇文章是翻譯文,因為通過自己參與的項目,越發覺得單元測試的重要性,特別是當跟業務數據打交道的時候的,Moq就如雪中送炭,所以想學習這個框架,就從這篇譯文開始吧,順便提升下自己英文閱讀水平吧,由於英語實在不行,藉助有道翻譯有時候還理解不了原文的意思。 ...
  • 1 namespace Test 2 { 3 class Program 4 { 5 static void Main(string[] args) 6 { 7 //作業:橡皮rubber鴨子、木wood鴨子、真實的鴨子realduck。 8 //三個鴨子都會游泳,而橡皮鴨子和真實的鴨... ...
  • 場景: EF底層,獲取完主表,點擊按鈕,添加主表,字表內容時,報以上錯誤 解決方案: 在EF文件的空白處右鍵--屬性,將“應用延遲載入”,改為False ...
  • RabbitMQ是一個由erlang開發的AMQP(Advanved Message Queue)的開源實現,是實現消息隊列應用的一個中間件,消息隊列中間件是分散式系統中重要的組件,主要解決應用耦合,非同步消息,流量削鋒等問題。實現高性能,高可用,可伸縮和最終一致性架構。是大型分散式系統不可缺少的中間... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...