• java jdbc连接mysql


    JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。JDBC为数据库开发人员提供了一个标准的API,使数据库开发人员能够用纯 Java API 编写数据库应用程序,并且可跨平台运行,并且不受数据库供应商的限制。其优点:

    • 操作便捷:开发人员不需要再使用复杂的驱动器调用命令和函数;
    • 可移植性强:JDBC支持不同的关系数据库
    • 通用性好:JDBC-ODBC桥接驱动器将JDBC函数换成ODBC;
    • 面向对象:可以将常用的JDBC数据库连接封装成一个类,在使用的时候直接调用即可
    package DAO;
    
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.ResultSetMetaData;
    import java.sql.SQLException;
    import java.util.ArrayList;
    import java.util.Collections;
    import java.util.HashMap;
    import java.util.List;
    import java.util.Map;
    
    import com.mysql.jdbc.Statement;
    
    public class JDBC {
        protected  Connection conn;
        protected  Statement statement;
    
        public static Connection getConnection() throws Exception {
            Connection connection = null; // 创建用于连接数据库的Connection对象
            try {
                Class.forName("com.mysql.jdbc.Driver");// 加载Mysql数据驱动
                /**
                 * 127.0.0.1指本机,若是链接远程服务机器,则填写远程机器的ip 3306 mysql默认的端口号 test 数据库名称
                 * user 数据库用户名称 password 密码
                 */
                connection = DriverManager.getConnection(
                        "jdbc:mysql://127.0.0.1:3306/test", "user", "password");// 创建数据连接
    
            } catch (Exception e) {
                e.printStackTrace();
                throw new Exception("链接mysql数据失败");
            }
            return connection; // 返回所建立的数据库连接
        }
    
        /**
         * 向mysql插入数据记录 返回插入数据的个数
         * 
         * @param sql
         *            要插入的sql语句
         * @return count 插入数据的个数
         * @throws Exception
         */
        public  int insert(String sql) throws Exception {
            conn = getConnection(); // 连接到数据库
            try {
                statement = (Statement) conn.createStatement(); // 创建用于执行静态sql语句的Statement对象
                int count = statement.executeUpdate(sql); // 执行插入操作的sql语句
                conn.close(); // 关闭数据库连接
                return count;// 返回插入数据的个数
            } catch (SQLException e) {
                e.printStackTrace();
                throw new Exception("插入数据失败");
            }
        }
    
        /**
         * 更新符合要求的记录 返回更新的记录数目
         * 
         * @param sql
         *            更新数据的sql语句
         * @return count 更新数据的个数
         * @throws Exception
         */
        public  int update(String sql) throws Exception {
            conn = getConnection(); // 连接到数据库
            try {
                // 创建用于执行静态sql语句的Statement对象,
                statement = (Statement) conn.createStatement();
                int count = statement.executeUpdate(sql);// 执行更新操作的sql语句,
                conn.close(); // 关闭数据库连接
                return count; // 返回更新数据的个数
            } catch (SQLException e) {
                e.printStackTrace();
                throw new Exception("更新数据失败");
            }
        }
    
        /**
         * 查询数据库,返回符合要求的记录的数据
         * 
         * @param sql 查询数据的sql语句
         * @throws Exception
         * @return list 
         */
        public  List<Object> query(String sql) throws Exception {
    
            conn = getConnection(); // 连接到数据库
            try {
                statement = (Statement) conn.createStatement(); // 创建用于执行静态sql语句的Statement对象
                ResultSet rs = statement.executeQuery(sql); // 执行sql查询语句,返回查询数据的结果集
                List<Object> list=ResultSetToList(rs);
                conn.close(); // 关闭数据库连接
                return list;
    
            } catch (SQLException e) {
                e.printStackTrace();
                throw new Exception("查询数据失败");
            }
        }
        /* 删除符合要求的记录,输出情况*/  
        /**
         * 
         * @param sql 删除数据的sql语句
         * @return count 返回删除数据的数量
         * @throws Exception
         */
        public  int delete(String sql) throws Exception {  
            conn = getConnection(); //连接到数据库  
            try {  
                statement = (Statement) conn.createStatement();    //创建用于执行静态sql语句的Statement对象
                int count = statement.executeUpdate(sql);// 执行sql删除语句  
                conn.close();   //关闭数据库连接  
                  return count;//返回删除数据的数量
            } catch (SQLException e) {  
                e.printStackTrace();
                throw new Exception("删除数据失败");
            }  
              
        }
        /**
         * 分页查找
         * @param sql 要查找的sql语句
         * @param page 页数
         * @param count 数据条数
         * @return List<Object>
         * @throws Exception
         */
        public  List<Object> findByPage(String sql,  
                int page,int count) throws Exception {  
              conn = getConnection(); //连接到数据库  
            PreparedStatement pre = conn.prepareStatement(sql);  
            pre.setMaxRows(count);  
            ResultSet rs = pre.executeQuery();  
            if(page<1){
                rs.absolute(0);  
            }else{
                page=page*count-1;
                rs.absolute(page);  
            }
            List<Object> list=ResultSetToList(rs);
            return list;  
        }  
        /**
         * ResultSet 转换成List
         */
        public  List<Object> ResultSetToList(ResultSet rs) throws SQLException{
            if (rs == null)
                return Collections.emptyList();
            ResultSetMetaData md = rs.getMetaData(); // 得到结果集(rs)的结构信息
            int columnCount = md.getColumnCount(); // 返回此 ResultSet 对象中的列数
            List<Object> list = new ArrayList<Object>();
            Map<Object, Object> rowData = new HashMap<Object, Object>();
            while (rs.next()) {
                rowData = new HashMap<Object, Object>(columnCount);
                for (int i = 1; i <= columnCount; i++) {
                    rowData.put(md.getColumnName(i), rs.getObject(i));
                }
                list.add(rowData);
            }
            return list;
        }
    
    
    }
  • 相关阅读:
    Linux-第一天
    Hadoop学习10--常用命令记录帖
    C# asp.net repeater实现排序功能,自动排序,点击头部排序,点击列排序
    图片与字符之间的转换
    兼容浏览器 div固定浏览器窗口底部 浮动div
    解决QQ未启用状态,QQ留言图标未启用
    C#Cookie操作类,删除Cookie,给Cookie赋值
    vs2008bin下Debug bll Release文件 obj下的Debug bll Release文件区别
    asp.net限制了上传文件大小为..M,解决方法
    多文件上传ajax jquery
  • 原文地址:https://www.cnblogs.com/wuweidu/p/3847837.html
Copyright © 2020-2023  润新知