atitit.atiOrmStoreService 框架的原理與設計 part1  概述與新特性

来源:http://www.cnblogs.com/attilax/archive/2016/02/27/5223410.html
-Advertisement-
Play Games

atitit.atiOrmStoreService 框架的原理與設計 part1 概述與新特性 1. 新特性如下 支持生成sql在無資料庫連接的情況下 2. Orm設計 主要的倆個以來service如下 @Inject Dsl2sqlService dsl2sqlSvr; @Inject DBX d


atitit.atiOrmStoreService 框架的原理與設計 part1  概述與新特性

 

 

1. 新特性如下

支持生成sql在無資料庫連接的情況下

 

 

2. Orm設計

主要的倆個以來service如下

@Inject

Dsl2sqlService dsl2sqlSvr;

@Inject

DBX dbSvr;

作者:: 綽號:老哇的爪子 ( 全名::Attilax Akbar Al Rapanui 阿提拉克斯 阿克巴 阿爾 拉帕努伊 ) 漢字名:艾龍,  EMAIL:[email protected]

轉載請註明來源: http://www.cnblogs.com/attilax/

 

 

3. code

 

/atiPlatf_bet/src/com/attilax/store/OrmStoreService.java

 

 

 

package com.attilax.store;

 

import java.util.List;

import java.util.Map;

 

import com.attilax.db.DBX;

import com.attilax.io.filex;

import com.attilax.ioc.IocXq214;

import com.attilax.json.AtiJson;

import com.attilax.lang.MapX;

import com.attilax.orm.AOrm;

import com.attilax.orm.Aorm4view;

import com.attilax.orm.View;

import com.attilax.sql.Dsl2sqlService;

import com.google.common.collect.Lists;

import com.google.common.collect.Maps;

import com.google.inject.Inject;

 

public class OrmStoreService extends StoreService {

 

public static void main(String[] args) {

System.setProperty("apptype", "bet");

OrmStoreService ormSvr = IocXq214.getBean(OrmStoreService.class);

Map m = Maps.newLinkedHashMap();

m.put("$table", "orderView");

m.put("$tabletype", "view");

m.put("$view_store_path","com/attilax/order");

m.put("$op", "insert");

m.put("good_id","2005");

m.put("order_id",filex.getUUidName());

List<String> insertSql = ormSvr.insertSql(m);

System.out.println( AtiJson.toJson( insertSql));

System.out.println("--f1");

}

 

@Inject

Dsl2sqlService dsl2sqlSvr;

@Inject

DBX dbSvr;

 

public List<String> insertSql(Map m) {

List<String> li = Lists.newArrayList();

if (m.get("$tabletype") != null && m.get("$tabletype").equals("view")) {

String[] tabs = new View(m.get("$table"), m.get("$view_store_path"))

.getTables();

for (String tab : tabs) {

Map m2 = MapX.clone(m);

m2.put("$table", tab);

String s = get_insert_singleTable_sql(m2);

li.add(s);

}

 

return li;

}

return li;

}

 

public void insert(Map m) {

 

List<String> li = insertSql(m);

for (String sql : li) {

dbSvr.execSql(sql);

}

 

}

 

public String get_insert_singleTable_sql(Map m) {

 

String sql = dsl2sqlSvr.dsl2sql(m);

return sql;

 

}

 

}

 

 


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

-Advertisement-
Play Games
更多相關文章
  • 我們在開發項目時,喜歡引入好多的第三方包,大大的方便了我們的開發,但同時,因為android方法總數的限制,不能超過65k,然而呢,隨著我們的開發,65k最終還是會超過,所以,google就給出了這個解決方案,但一直好奇它是內部是怎麼實現的,我們今天就來根據源碼來看看這個包到底做了什麼,怎麼把多個d
  • 機器學習 視頻教程 數據挖掘 實戰 開發 應用 演算法 案例 R語言 Hadoop、Redis、Memcached、MongoDB、Spark、Storm、雲計算、R語言、機器學習、Nginx、Linux、MySQL、Java EE、.NET、PHP
  • Hadoop、Redis、Memcached、MongoDB、Spark、Storm、雲計算、R語言、機器學習、Nginx、Linux、MySQL、Java EE、.NET、PHP Hadoop 視頻教程 大數據 高性能 集群 NoSQL 實戰 權威 入門 安裝
  • SQL優化的最終目的是用戶體驗-在最短時間內讓用戶在頁面數據。因此,執行時間是SQL優化的重要指標。在SQL查詢中,I/O操作最占系統性能的。I/O操作量越大,時間越久。減少I/O操作量是優化SQL的目標。同時,CPU,緩存命中率也很重要。 並不是所有SQL都需要被優化,使用頻率高,性能差的SQL語
  • 關於sqlnet.ora的參數SQLNET.INBOUND_CONNECT_TIMEOUT,它表示等待用戶認證超時的時間,單位是秒,預設值是60秒,如果用戶認證超時了,伺服器日誌alert.log顯示出錯信息"WARNING: inbound connection timed out (ORA-31...
  • Hadoop安裝 Hadoop安裝 Hive元數據三種存儲方式 Derby:hive預設的存儲模式,不可以併發調用hive 本地MySQL 遠程MySQL 採用第二種方式,安裝MySQL,啟動並創建Hive用戶,創建Hive元資料庫 insert into mysql.user(Host,User,...
  • 我們開發了一個會員管理系統,隨著使用的人越來越多,異地備份資料庫就顯得十分重要,萬一硬碟出問題了怎麼辦呢.所以就著手做這個工作. 首先呢,找到了幾個專門用來提供備份資料庫的網站,一年好幾百,好貴.放棄這個方案. 然後想到了辦法,如果備份到百度雲上是不是就很好呢.超大的空間.嘗試了一下,需要分三步:
  • ORACLE的執行計劃分為預估執行計劃和實際執行計劃。其中,你用Toad、PL/SQL Developer、SQL Developer、EXPLAIN PLAN FOR或者SET ATUOTRACE TRACEONLY等獲取的執行計劃都是預估的執行計劃。有時候預估執行計劃和實際執行計劃有很大的差別,...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...