<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                企業??AI智能體構建引擎,智能編排和調試,一鍵部署,支持知識庫和私有化部署方案 廣告
                # 數據庫操作 這一小節是對數據庫操作做一個簡單的封裝,不涉及復雜的事務操作等。 我選用了Sql2o作為底層數據庫框架作為支持,它的簡潔易用性讓我刮目相看,后面我們也會寫如何實現一個ORM框架。 ```java /** * 數據庫支持 * @author biezhi * */ public final class MarioDb { private static Sql2o sql2o = null; private MarioDb() { } /** * 初始化數據庫配置 * @param url * @param user * @param pass */ public static void init(String url, String user, String pass){ sql2o = new Sql2o(url, user, pass); } /** * 初始化數據庫配置 * @param dataSource */ public static void init(DataSource dataSource){ sql2o = new Sql2o(dataSource); } /** * 查詢一個對象 * @param sql * @param clazz * @return */ public static <T> T get(String sql, Class<T> clazz){ return get(sql, clazz, null); } /** * 查詢一個列表 * @param sql * @param clazz * @return */ public static <T> List<T> getList(String sql, Class<T> clazz){ return getList(sql, clazz, null); } /** * 查詢一個對象返回為map類型 * @param sql * @return */ public static Map<String, Object> getMap(String sql){ return getMap(sql, null); } /** * 查詢一個列表并返回為list<map>類型 * @param sql * @return */ public static List<Map<String, Object>> getMapList(String sql){ return getMapList(sql, null); } /** * 插入一條記錄 * @param sql * @param params * @return */ public static int insert(String sql, Object ... params){ StringBuffer sqlBuf = new StringBuffer(sql); sqlBuf.append(" values ("); int start = sql.indexOf("(") + 1; int end = sql.indexOf(")"); String a = sql.substring(start, end); String[] fields = a.split(","); Map<String, Object> map = new HashMap<String, Object>(); int i=0; for(String name : fields){ sqlBuf.append(":" + name.trim() + " ,"); map.put(name.trim(), params[i]); i++; } String newSql = sqlBuf.substring(0, sqlBuf.length() - 1) + ")"; Connection con = sql2o.open(); Query query = con.createQuery(newSql); executeQuery(query, map); int res = query.executeUpdate().getResult(); con.close(); return res; } /** * 更新 * @param sql * @return */ public static int update(String sql){ return update(sql, null); } /** * 帶參數更新 * @param sql * @param params * @return */ public static int update(String sql, Map<String, Object> params){ Connection con = sql2o.open(); Query query = con.createQuery(sql); executeQuery(query, params); int res = query.executeUpdate().getResult(); con.close(); return res; } public static <T> T get(String sql, Class<T> clazz, Map<String, Object> params){ Connection con = sql2o.open(); Query query = con.createQuery(sql); executeQuery(query, params); T t = query.executeAndFetchFirst(clazz); con.close(); return t; } @SuppressWarnings("unchecked") public static Map<String, Object> getMap(String sql, Map<String, Object> params){ Connection con = sql2o.open(); Query query = con.createQuery(sql); executeQuery(query, params); Map<String, Object> t = (Map<String, Object>) query.executeScalar(); con.close(); return t; } public static List<Map<String, Object>> getMapList(String sql, Map<String, Object> params){ Connection con = sql2o.open(); Query query = con.createQuery(sql); executeQuery(query, params); List<Map<String, Object>> t = query.executeAndFetchTable().asList(); con.close(); return t; } public static <T> List<T> getList(String sql, Class<T> clazz, Map<String, Object> params){ Connection con = sql2o.open(); Query query = con.createQuery(sql); executeQuery(query, params); List<T> list = query.executeAndFetch(clazz); con.close(); return list; } private static void executeQuery(Query query, Map<String, Object> params){ if (null != params && params.size() > 0) { Set<String> keys = params.keySet(); for(String key : keys){ query.addParameter(key, params.get(key)); } } } } ``` 設計MVC框架部分已經完成,下一節是一個增刪改查的例子
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看