# 数据库操作 这一小节是对数据库操作做一个简单的封装,不涉及复杂的事务操作等。 我选用了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 get(String sql, Class clazz){ return get(sql, clazz, null); } /** * 查询一个列表 * @param sql * @param clazz * @return */ public static List getList(String sql, Class clazz){ return getList(sql, clazz, null); } /** * 查询一个对象返回为map类型 * @param sql * @return */ public static Map getMap(String sql){ return getMap(sql, null); } /** * 查询一个列表并返回为list类型 * @param sql * @return */ public static List> 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 map = new HashMap(); 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 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 get(String sql, Class clazz, Map 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 getMap(String sql, Map params){ Connection con = sql2o.open(); Query query = con.createQuery(sql); executeQuery(query, params); Map t = (Map) query.executeScalar(); con.close(); return t; } public static List> getMapList(String sql, Map params){ Connection con = sql2o.open(); Query query = con.createQuery(sql); executeQuery(query, params); List> t = query.executeAndFetchTable().asList(); con.close(); return t; } public static List getList(String sql, Class clazz, Map params){ Connection con = sql2o.open(); Query query = con.createQuery(sql); executeQuery(query, params); List list = query.executeAndFetch(clazz); con.close(); return list; } private static void executeQuery(Query query, Map params){ if (null != params && params.size() > 0) { Set keys = params.keySet(); for(String key : keys){ query.addParameter(key, params.get(key)); } } } } ``` 设计MVC框架部分已经完成,下一节是一个增删改查的例子 ## links * [目录]() * 上一节: [视图设计](<5.view.md>) * 下一节: [增删改查](<7.crud.md>)