博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java版sqlhelper(转)
阅读量:6681 次
发布时间:2019-06-25

本文共 16382 字,大约阅读时间需要 54 分钟。

package Sql;import java.sql.*;import java.util.logging.*;/** *  SQL 基本操作 * 通过它,可以很轻松的使用 JDBC 来操纵数据库*/public class SQLHelper{    /**     * 驱动     */    public static String driver = "com.microsoft.sqlserver.jdbc.SQLServerDriver";    /**     * 连接字符串     */    public static String url = "jdbc:sqlserver://192.168.1.88:1433;DatabaseName=Test";    /**     * 用户名     */    public static String user = "sa";    /**     * 密码     */    public static String password = "sa";    /**     * 不允许实例化该类     */    private SQLHelper()    {    }    /**     * 获取一个数据库连接     * 通过设置类的  driver / url / user / password 这四个静态变量来 设置数据库连接属性     * @return 数据库连接     */    public static Connection getConnection()    {        try        {            // 获取驱动,这里使用的是 sqljdbc_1.2.2828.100_chs.exe,不同版本的驱动,语句有所不同            Class.forName(driver);        } catch (ClassNotFoundException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);        }        try        {            return DriverManager.getConnection(url, user, password);        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);            return null;        }    }    /**     * 获取一个 Statement     * 该 Statement 已经设置数据集 可以滚动,可以更新     * @return 如果获取失败将返回 null,调用时记得检查返回值     */    public static Statement getStatement()    {        Connection conn = getConnection();        if (conn == null)        {            return null;        }        try        {            return conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,                    ResultSet.CONCUR_UPDATABLE);        // 设置数据集可以滚动,可以更新        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);            close(conn);        }        return null;    }    /**     * 获取一个 Statement     * 该 Statement 已经设置数据集 可以滚动,可以更新     * @param conn 数据库连接     * @return 如果获取失败将返回 null,调用时记得检查返回值     */    public static Statement getStatement(Connection conn)    {        if (conn == null)        {            return null;        }        try        {            return conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);        // 设置数据集可以滚动,可以更新        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);            return null;        }    }    /**     * 获取一个带参数的 PreparedStatement     * 该 PreparedStatement 已经设置数据集 可以滚动,可以更新     * @param cmdText 需要 ? 参数的 SQL 语句     * @param cmdParams SQL 语句的参数表     * @return 如果获取失败将返回 null,调用时记得检查返回值     */    public static PreparedStatement getPreparedStatement(String cmdText, Object... cmdParams)    {        Connection conn = getConnection();        if (conn == null)        {            return null;        }        PreparedStatement pstmt = null;        try        {            pstmt = conn.prepareStatement(cmdText, ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);            int i = 1;            for (Object item : cmdParams)            {                pstmt.setObject(i, item);                i++;            }        } catch (SQLException e)        {            e.printStackTrace();            close(conn);        }        return pstmt;    }    /**     *  获取一个带参数的 PreparedStatement     * 该 PreparedStatement 已经设置数据集 可以滚动,可以更新     * @param conn 数据库连接     * @param cmdText 需要 ? 参数的 SQL 语句     * @param cmdParams SQL 语句的参数表     * @return 如果获取失败将返回 null,调用时记得检查返回值     */    public static PreparedStatement getPreparedStatement(Connection conn, String cmdText, Object... cmdParams)    {        if (conn == null)        {            return null;        }        PreparedStatement pstmt = null;        try        {            pstmt = conn.prepareStatement(cmdText, ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);            int i = 1;            for (Object item : cmdParams)            {                pstmt.setObject(i, item);                i++;            }        } catch (SQLException e)        {            e.printStackTrace();            close(pstmt);        }        return pstmt;    }    /**     * 执行 SQL 语句,返回结果为整型     * 主要用于执行非查询语句     * @param cmdText SQL 语句     * @return 非负数:正常执行; -1:执行错误; -2:连接错误     */    public static int ExecSql(String cmdText)    {        Statement stmt = getStatement();        if (stmt == null)        {            return -2;        }        int i;        try        {            i = stmt.executeUpdate(cmdText);        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null,                    ex);            i = -1;        }        closeConnection(stmt);        return i;    }    /**     * 执行 SQL 语句,返回结果为整型     * 主要用于执行非查询语句     * @param cmdText SQL 语句     * @return 非负数:正常执行; -1:执行错误; -2:连接错误     */    public static int ExecSql(Connection conn, String cmdText)    {        Statement stmt = getStatement(conn);        if (stmt == null)        {            return -2;        }        int i;        try        {            i = stmt.executeUpdate(cmdText);        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null,                    ex);            i = -1;        }        close(stmt);        return i;    }    /**     * 执行 SQL 语句,返回结果为整型     * 主要用于执行非查询语句     * @param cmdText 需要 ? 参数的 SQL 语句     * @param cmdParams SQL 语句的参数表     * @return 非负数:正常执行; -1:执行错误; -2:连接错误     */    public static int ExecSql(String cmdText, Object... cmdParams)    {        PreparedStatement pstmt = getPreparedStatement(cmdText, cmdParams);        if (pstmt == null)        {            return -2;        }        int i;        try        {            i = pstmt.executeUpdate();        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null,                    ex);            i = -1;        }        closeConnection(pstmt);        return i;    }    /**     * 执行 SQL 语句,返回结果为整型     * 主要用于执行非查询语句     * @param conn 数据库连接     * @param cmdText 需要 ? 参数的 SQL 语句     * @param cmdParams SQL 语句的参数表     * @return 非负数:正常执行; -1:执行错误; -2:连接错误     */    public static int ExecSql(Connection conn, String cmdText, Object... cmdParams)    {        PreparedStatement pstmt = getPreparedStatement(conn, cmdText, cmdParams);        if (pstmt == null)        {            return -2;        }        int i;        try        {            i = pstmt.executeUpdate();        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);            i = -1;        }        close(pstmt);        return i;    }    /**     * 返回结果集的第一行的一列的值,其他忽略     * @param cmdText SQL 语句     * @return     */    public static Object ExecScalar(String cmdText)    {        ResultSet rs = getResultSet(cmdText);        Object obj = buildScalar(rs);        closeConnection(rs);        return obj;    }    /**     * 返回结果集的第一行的一列的值,其他忽略     * @param conn 数据库连接     * @param cmdText SQL 语句     * @return     */    public static Object ExecScalar(Connection conn, String cmdText)    {        ResultSet rs = getResultSet(conn, cmdText);        Object obj = buildScalar(rs);        closeEx(rs);        return obj;    }    /**     * 返回结果集的第一行的一列的值,其他忽略     * @param cmdText 需要 ? 参数的 SQL 语句     * @param cmdParams SQL 语句的参数表     * @return     */    public static Object ExecScalar(String cmdText, Object... cmdParams)    {        ResultSet rs = getResultSet(cmdText, cmdParams);        Object obj = buildScalar(rs);        closeConnection(rs);        return obj;    }    /**     * 返回结果集的第一行的一列的值,其他忽略     * @param conn 数据库连接     * @param cmdText 需要 ? 参数的 SQL 语句     * @param cmdParams SQL 语句的参数表     * @return     */    public static Object ExecScalar(Connection conn, String cmdText, Object... cmdParams)    {        ResultSet rs = getResultSet(conn, cmdText, cmdParams);        Object obj = buildScalar(rs);        closeEx(rs);        return obj;    }    /**     * 返回一个 ResultSet     * @param cmdText SQL 语句     * @return     */    public static ResultSet getResultSet(String cmdText)    {        Statement stmt = getStatement();        if (stmt == null)        {            return null;        }        try        {            return stmt.executeQuery(cmdText);        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);            closeConnection(stmt);        }        return null;    }    /**     * 返回一个 ResultSet     * @param conn     * @param cmdText SQL 语句     * @return     */    public static ResultSet getResultSet(Connection conn, String cmdText)    {        Statement stmt = getStatement(conn);        if (stmt == null)        {            return null;        }        try        {            return stmt.executeQuery(cmdText);        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);            close(stmt);        }        return null;    }    /**     * 返回一个 ResultSet     * @param cmdText 需要 ? 参数的 SQL 语句     * @param cmdParams SQL 语句的参数表     * @return     */    public static ResultSet getResultSet(String cmdText, Object... cmdParams)    {        PreparedStatement pstmt = getPreparedStatement(cmdText, cmdParams);        if (pstmt == null)        {            return null;        }        try        {            return pstmt.executeQuery();        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);            closeConnection(pstmt);        }        return null;    }    /**     * 返回一个 ResultSet     * @param conn 数据库连接     * @param cmdText 需要 ? 参数的 SQL 语句     * @param cmdParams SQL 语句的参数表     * @return     */    public static ResultSet getResultSet(Connection conn, String cmdText, Object... cmdParams)    {        PreparedStatement pstmt = getPreparedStatement(conn, cmdText, cmdParams);        if (pstmt == null)        {            return null;        }        try        {            return pstmt.executeQuery();        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);            close(pstmt);        }        return null;    }    public static Object buildScalar(ResultSet rs)    {        if (rs == null)        {            return null;        }        Object obj = null;        try        {            if (rs.next())            {                obj = rs.getObject(1);            }        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);        }        return obj;    }          /**     * 获取一个具有更新功能的数据模型 如果只要读取数据,就不要用它了     * @param cmdText 能返回一个数据集的查询SQL 语句     * @return 表格数据模型     *      *      * DataSet 没有找到在哪个包中,因为暂时用不到所以省略此方法         public static DataSet getDataSet(String cmdText)    {        Statement stmt = getStatement();        DataSet dbc = new DataSet();        if (stmt == null)        {            dbc.code = -2;            return dbc;        }        try        {            // 查询语句            dbc.rs = stmt.executeQuery(cmdText);            dbc.model = buildTableModel(dbc.rs);            dbc.code = dbc.model.getRowCount();        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);            dbc.code = -1;        }        return dbc;    }    */        /**     * 获取一个具有更新功能的数据模型 如果只要读取数据,就不要用它了     * @param conn 数据库连接     * @param cmdText 能返回一个数据集的查询SQL 语句     * @return 表格数据模型     *      * 同上一个方法         public static DataSet getDataSet(Connection conn, String cmdText)    {        Statement stmt = getStatement(conn);        DataSet dbc = new DataSet();        if (stmt == null)        {            dbc.code = -2;            return dbc;        }        try        {            // 查询语句            dbc.rs = stmt.executeQuery(cmdText);            dbc.model = buildTableModel(dbc.rs);            dbc.code = dbc.model.getRowCount();        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);            dbc.code = -1;        }        return dbc;    }    */    /**     * 获取一个具有更新功能的数据模型 如果只要读取数据,就不要用它了     * @param cmdText 需要 ? 参数的 SQL 语句     * @param cmdParams SQL 语句的参数表     * @return 表格数据模型     *      *      * 同上一个方法     *      *         public static DataSet getDataSet(String cmdText, Object... cmdParams)    {        PreparedStatement pstmt = getPreparedStatement(cmdText, cmdParams);        DataSet dbc = new DataSet();        if (pstmt == null)        {            dbc.code = -2;            return dbc;        }        try        {            // 查询语句            dbc.rs = pstmt.executeQuery();            dbc.model = buildTableModel(dbc.rs);            dbc.code = dbc.model.getRowCount();        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);            dbc.code = -1;        }        return dbc;    }         */    /**     * 获取一个具有更新功能的数据模型 如果只要读取数据,就不要用它了     * @param conn 数据库连接     * @param cmdText 需要 ? 参数的 SQL 语句     * @param cmdParams SQL 语句的参数表     * @return 表格数据模型     *      *      * 同上     *          public static DataSet getDataSet(Connection conn, String cmdText, Object... cmdParams)    {        PreparedStatement pstmt = getPreparedStatement(conn, cmdText, cmdParams);        DataSet dbc = new DataSet();        if (pstmt == null)        {            dbc.code = -2;            return dbc;        }        try        {            // 查询语句            dbc.rs = pstmt.executeQuery();            dbc.model = buildTableModel(dbc.rs);            dbc.code = dbc.model.getRowCount();        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);            dbc.code = -1;        }        return dbc;    }    */    private static void close(Object obj)    {        if (obj == null)        {            return;        }        try        {            if (obj instanceof Statement)            {                ((Statement) obj).close();            } else if (obj instanceof PreparedStatement)            {                ((PreparedStatement) obj).close();            } else if (obj instanceof ResultSet)            {                ((ResultSet) obj).close();            } else if (obj instanceof Connection)            {                ((Connection) obj).close();            }        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);        }    }    private static void closeEx(Object obj)    {        if (obj == null)        {            return;        }        try        {            if (obj instanceof Statement)            {                ((Statement) obj).close();            } else if (obj instanceof PreparedStatement)            {                ((PreparedStatement) obj).close();            } else if (obj instanceof ResultSet)            {                ((ResultSet) obj).getStatement().close();            } else if (obj instanceof Connection)            {                ((Connection) obj).close();            }        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);        }    }    private static void closeConnection(Object obj)    {        if (obj == null)        {            return;        }        try        {            if (obj instanceof Statement)            {                ((Statement) obj).getConnection().close();            } else if (obj instanceof PreparedStatement)            {                ((PreparedStatement) obj).getConnection().close();            } else if (obj instanceof ResultSet)            {                ((ResultSet) obj).getStatement().getConnection().close();            } else if (obj instanceof Connection)            {                ((Connection) obj).close();            }        } catch (SQLException ex)        {            Logger.getLogger(SQLHelper.class.getName()).log(Level.SEVERE, null, ex);        }    }}

 

支持MSSQL2005以上,以前的自己改

public static String url = "jdbc:sqlserver://192.168.1.88:1433;DatabaseName=Test"; 为:
public static String url = "jdbc:microsoft:sqlserver://192.168.1.88:1433;DatabaseName=Test";

转载于:https://www.cnblogs.com/pilink/p/6688574.html

你可能感兴趣的文章
WINREG.H 编译出错
查看>>
Detours的使用准备
查看>>
30+有用的CSS代码片段
查看>>
PHP新手之学习类与对象(2)
查看>>
[Big Data - Kafka] Kafka设计解析(三):Kafka High Availability (下)
查看>>
Hibernate核心配置文件
查看>>
SpringBoot学习之一 Unable to find a single main class from the following candidates
查看>>
SpringCloud学习成长 四 断路器(Hystrix)
查看>>
Inventory Pro 装备拾取的实现
查看>>
Using SQL Server 2012 T-SQL New Features(转载)
查看>>
hihocoder [Offer收割]编程练习赛8
查看>>
colpick-jQuery颜色选择器使用说明
查看>>
python基础之socket编程
查看>>
fastdfs_nginx整合
查看>>
winform中键盘和鼠标事件的捕捉和重写
查看>>
C#中IEnumerable、ICollection、IList、List之间的区别
查看>>
UIAlertView
查看>>
博客园美化资源网站链接
查看>>
xfs 文件系统损坏修复 fscheck
查看>>
区块链开发_以太坊多重签名
查看>>