• 老邓的day21


    编程软件IntelliJ IDEA 2018.3 x64

    应用环境:JDK1.8

    人生名言:每一件事都要用多方面的角度来看它。

    技术总结:

    1. 概念:Java DataBase Connectivity  Java 数据库连接, Java语言操作数据库
            * JDBC本质:其实是官方(sun公司)定义的一套操作所有关系型数据库的规则,即接口。各个数据库厂商去实现这套接口,提供数据库驱动jar包。
            我们可以使用这套接口(JDBC)编程,真正执行的代码是驱动jar包中的实现类。
        
        2. 快速入门:
            * 步骤:
                1. 导入驱动jar包 mysql-connector-java-5.1.37-bin.jar
                    1.复制mysql-connector-java-5.1.37-bin.jar到项目的libs目录下
                    2.右键-->Add As Library
                2. 注册驱动
                 3. 获取数据库连接对象 Connection
                4. 定义sql
                5. 获取执行sql语句的对象 Statement
                6. 执行sql,接受返回结果
                7. 处理结果
                8. 释放资源
        
            * 代码实现:
                  //1. 导入驱动jar包
                //2.注册驱动
                Class.forName("com.mysql.jdbc.Driver");
                //3.获取数据库连接对象
                Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/db3", "root", "root");
                //4.定义sql语句
                String sql = "update account set balance = 500 where id = 1";
                //5.获取执行sql的对象 Statement
                Statement stmt = conn.createStatement();
                //6.执行sql
                int count = stmt.executeUpdate(sql);
                //7.处理结果
                System.out.println(count);
                //8.释放资源
                stmt.close();
                conn.close();
        
        3. 详解各个对象:
            1. DriverManager:驱动管理对象
                * 功能:
                    1. 注册驱动:告诉程序该使用哪一个数据库驱动jar
                        static void registerDriver(Driver driver) :注册与给定的驱动程序 DriverManager 。 
                        写代码使用:  Class.forName("com.mysql.jdbc.Driver");
                        通过查看源码发现:在com.mysql.jdbc.Driver类中存在静态代码块
                         static {
                                try {
                                    java.sql.DriverManager.registerDriver(new Driver());
                                } catch (SQLException E) {
                                    throw new RuntimeException("Can't register driver!");
                                }
                            }
        
                        注意:mysql5之后的驱动jar包可以省略注册驱动的步骤。
                    2. 获取数据库连接:
                        * 方法:static Connection getConnection(String url, String user, String password) 
                        * 参数:
                            * url:指定连接的路径
                                * 语法:jdbc:mysql://ip地址(域名):端口号/数据库名称
                                * 例子:jdbc:mysql://localhost:3306/db3
                                * 细节:如果连接的是本机mysql服务器,并且mysql服务默认端口是3306,则url可以简写为:jdbc:mysql:///数据库名称
                            * user:用户名
                            * password:密码 
            2. Connection:数据库连接对象
                1. 功能:
                    1. 获取执行sql 的对象
                        * Statement createStatement()
                        * PreparedStatement prepareStatement(String sql)  
                    2. 管理事务:
                        * 开启事务:setAutoCommit(boolean autoCommit) :调用该方法设置参数为false,即开启事务
                        * 提交事务:commit() 
                        * 回滚事务:rollback() 
            3. Statement:执行sql的对象
                1. 执行sql
                    1. boolean execute(String sql) :可以执行任意的sql 了解 
                    2. int executeUpdate(String sql) :执行DML(insert、update、delete)语句、DDL(create,alter、drop)语句
                        * 返回值:影响的行数,可以通过这个影响的行数判断DML语句是否执行成功 返回值>0的则执行成功,反之,则失败。
                    3. ResultSet executeQuery(String sql)  :执行DQL(select)语句

    代码展示:

    Statement stmt = null;
                        Connection conn = null;
                        try {
                            //1. 注册驱动
                            Class.forName("com.mysql.jdbc.Driver");
                            //2. 定义sql
                            String sql = "insert into account values(null,'王五',3000)";
                            //3.获取Connection对象
                            conn = DriverManager.getConnection("jdbc:mysql:///db3", "root", "root");
                            //4.获取执行sql的对象 Statement
                            stmt = conn.createStatement();
                            //5.执行sql
                            int count = stmt.executeUpdate(sql);//影响的行数
                            //6.处理结果
                            System.out.println(count);
                            if(count > 0){
                                System.out.println("添加成功!");
                            }else{
                                System.out.println("添加失败!");
                            }
                
                        } catch (ClassNotFoundException e) {
                            e.printStackTrace();
                        } catch (SQLException e) {
                            e.printStackTrace();
                        }finally {
                            //stmt.close();
                            //7. 释放资源
                            //避免空指针异常
                            if(stmt != null){
                                try {
                                    stmt.close();
                                } catch (SQLException e) {
                                    e.printStackTrace();
                                }
                            }
                
                            if(conn != null){
                                try {
                                    conn.close();
                                } catch (SQLException e) {
                                    e.printStackTrace();
                                }
                            }
                        }
    
    public class JDBCUtils {
            private static String url;
            private static String user;
            private static String password;
            private static String driver;
            /**
             * 文件的读取,只需要读取一次即可拿到这些值。使用静态代码块
             */
            static{
                //读取资源文件,获取值。
        
                try {
                    //1. 创建Properties集合类。
                    Properties pro = new Properties();
        
                    //获取src路径下的文件的方式--->ClassLoader 类加载器
                    ClassLoader classLoader = JDBCUtils.class.getClassLoader();
                    URL res  = classLoader.getResource("jdbc.properties");
                    String path = res.getPath();
                    System.out.println(path);///D:/IdeaProjects/guigu/out/production/day04_jdbc/jdbc.properties
                    //2. 加载文件
                   // pro.load(new FileReader("D:\IdeaProjects\guigu\day04_jdbc\src\jdbc.properties"));
                    pro.load(new FileReader(path));
        
                    //3. 获取数据,赋值
                    url = pro.getProperty("url");
                    user = pro.getProperty("user");
                    password = pro.getProperty("password");
                    driver = pro.getProperty("driver");
                    //4. 注册驱动
                    Class.forName(driver);
                } catch (IOException e) {
                    e.printStackTrace();
                } catch (ClassNotFoundException e) {
                    e.printStackTrace();
                }
            }

    心得没有什么事是一蹴而就的,得循序渐进,一步一脚脚印。

  • 相关阅读:
    编写Excel文件的Golang库
    Go多组Raft库
    Go GraphQL初学者教程
    简洁架构的思想,基于go实现
    gometalinter代码质量检查分析工具(golang)
    用go实现一个redis-cli
    Sublime text —— 自定义主题Soda
    Sublime text —— 自定义Color theme
    Sublime Text增加Build system类型,打造一个全能IDE
    一个简单的增强型PHP curl函数
  • 原文地址:https://www.cnblogs.com/www-dzsblogs-com/p/13640430.html
Copyright © 2020-2023  润新知