• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

数据库jdbc封装

mysql 搞代码 4年前 (2022-01-09) 28次浏览 已收录 0个评论
文章目录[隐藏]

经过几天的努力终于搞好了,这个类可以不用管数据库字段,不用写dao类,直接map添加,添加删除和修改,jdbc链接,分享给大家,用的话记得加上连接池,尊重原创,转载请注明

package jdbc;import java.sql.Connection;import java.sql.DriverManager;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;/** * 操作数据库工具类 * * */public class domain {    /**     * 连接数据     *     * @return conn     */    public static Connection getConnection(String url, String username, String password) {        Connection conn = null;                try {            Class.forName("com.mysql.jdbc.Driver");            conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/" + url, username, password);        } catch (Exception e) {            e.printStackTrace();        }        return conn;    }    /**     * 关闭连接对象     *     * @param conn     *            连接对象     * @param pstmt     *            预编译对象     * @param rs     *            结果集     */    public static void closeAll(Connection conn, PreparedStatement pstmt, ResultSet rs) {            try {                if (rs != null) {                rs.close();            }                        if (pstmt != null) {                pstmt.close();            }                        if (conn != null) {                conn.close();            }        } catch (Exception e) {            e.printStackTrace();        }    }    /**     * 增删改操作     *     * @param sql     *            SQL命令     * @param param     *            参数     * @return     */    public static int executUpdate(Connection conn, String sql, Object[] param) {            int result = 0;        PreparedStatement pstmt = null;                try {            System.out.println(sql);            pstmt = conn.prepareStatement(sql);                        if (param != null) {                            for (int i = 0; i < param.length; i++) {                    pstmt.setObject(i + 1, param[i]);                }            }            result = pstmt.executeUpdate();        } catch (Exception e) {            e.printStackTrace();        } finally {            closeAll(conn, pstmt, null);        }        return result;    }    /**     * 查询     *     * @return int     * @date 2015-7-25 上午11:10:06     */    public static ResultSet executQuery(Connection conn, String sql, String[] param) {        PreparedStatement pstmt = null;        ResultSet result = null;                try {            pstmt = conn.prepareStatement(sql);                        if (param != null) {                            for (int i = 0; i < param.length; i++) {                    pstmt.setString(i + 1, param[i]);                }            }            result = pstmt.executeQuery();        } catch (Exception e) {            e.printStackTrace();        }        return result;    }    /**     * 简单增删改SQL语句执行,复杂sql执行executUpdate方法     * 字符串类型需要加单引号     * @param url     *            数据库     * @param username     *            数据库用户名     * @param password     *            数据库密码     * @param map     *       <div>本文来源gaodai^.ma#com搞#代!码网</div>     参数列,值     * @param tableName     *            表名     * @param typeSql     *            SQL类型 insert,dell,update     * @param oldLine     *            删除时为要删除的列名,更新的时候为where前的条件列名(仅当且使用dell和update时填写,insert时不作用)     * @param newLine     *            更新时where候的条件列名(仅当且使用update时填写,dell,insert时不作用)     * @param oldCondition     *            删除时为要删除的条件,更新的时候为where前的条件(仅当且使用dell和update时填写,insert时不作用)     * @param newCondition     *            更新的时候为where后的条件(仅当且使用update时填写,dell,insert时不作用)     */    public static void sql(String url, String username, String password, Map<String, Object> map, String tableName,            String typeSql, String oldLine, String oldCondition, String newLine, String newCondition) {        String sql = "";        Connection conn = getConnection(url, username, password);        Object[] valueArray = null;        if (typeSql.equals("insert")) {            List<Object> key = new ArrayList<Object>();            List<Object> value = new ArrayList<Object>();            StringBuffer sb = new StringBuffer();            StringBuffer wen = new StringBuffer();            for (Object string : map.keySet()) {                key.add(string);                value.add(map.get(string));            }            Object[] keyArray = key.toArray();            valueArray = value.toArray();            for (int i = 0; i < keyArray.length; i++) {                sb.append(keyArray[i] + ",");                wen.append("?,");            }            String string = sb.toString();            string = string.substring(0, string.length() - 1);            String wenStr = wen.toString();            wenStr = wenStr.substring(0, wenStr.length() - 1);            sql = "INSERT INTO " + tableName + "(" + string + ") VALUES (" + wenStr + ")";        } else if (typeSql.equals("dell")) {            sql = "DELETE FROM " + tableName + " WHERE " + oldLine + " = " + oldCondition;        } else if (typeSql.equals("update")) {            sql = "UPDATE " + tableName + " SET " + oldLine + "= " + oldCondition + " WHERE " + newLine + " = "                    + newCondition;        }        int executUpdate = executUpdate(conn, sql + ";", valueArray);        System.out.println(executUpdate);    }//测试    public static void main(String[] args) {        Map<String, Object> map = new HashMap<String, Object>();        map.put("appid", "lisi");         for (int i = 0; i < 100; i++) {         System.out.println(i);         map.put("id",i);         // 增加          sql("test", "root", "", map, "user", "insert", "", "", "", "");          // 删除          sql("test", "root", "", map, "user", "dell", "id", i+"","", "");          // 修改//                  sql("test", "root", "", map, "user", "update", "appid", "'zhang'", "id", "0");         }        // map.put("password", "123");    }}

以上就是数据库jdbc封装的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:数据库jdbc封装
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址