今日内容介绍
1、JDBC
2、DBUtils

01JDBC概念和数据库驱动程序

* A: JDBC概念和数据库驱动程序
    * a: JDBC概述
        * JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,
            可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。是Java访问数据库的标准规范
        * JDBC提供了一种基准,据此可以构建更高级的工具和接口,使数据库开发人员能够编写数据库应用程序。
        * JDBC需要连接驱动,驱动是两个设备要进行通信,满足一定通信数据格式,数据格式由设备提供商规定,
            设备提供商为设备提供驱动软件,通过软件可以与该设备进行通信。
        * 我们使用的是mysql的驱动mysql-connector-java-5.1.39-bin.jar
    * b: 总结
        * JDBC是java提供给开发人员的一套操作数据库的接口
        * 数据库驱动就是实现该接口的实现类
        

02JDBC原理

* A: JDBC原理
    * a: 描述
        * Java提供访问数据库规范称为JDBC,而生产厂商提供规范的实现类称为驱动
        * DBC是接口,驱动是接口的实现,没有驱动将无法完成数据库连接,从而不能操作数据库!
            每个数据库厂商都需要提供自己的驱动,用来连接自己公司的数据库,也就是说驱动一般都由数据库生成厂商提供。
        * 图解见day29_source/JDBC实现原理.JPG
                

03准备数据

* A: 准备数据
    * a: 创建数据库和表结构
        #创建数据库
        create database mybase;
        #使用数据库
        use mybase;
        ###创建分类表
        create table sort(
          sid int PRIMARY KEY AUTO_INCREMENT,
          sname varchar(100),
          sprice DOUBLE,
          sdesc VARCHAR(500)
        );

    * b: 向表中插入数据
        #初始化数据
        insert into sort(sname,sprice,sdesc) values('家电',2000, '优惠的促销');
        insert into sort(sname,sprice,sdesc) values('家具',8900, '家具价格上调,原材料涨价');
        insert into sort(sname,sprice,sdesc) values('儿童玩具',290, '赚家长的钱');
        insert into sort(sname,sprice,sdesc) values('生鲜',500.99, '生鲜商品');
        insert into sort(sname,sprice,sdesc) values('服装',24000, '换季销售');
        insert into sort(sname,sprice,sdesc) values('洗涤',50, '洗发水促销');
        

04JDBC的开发步骤

* A: JDBC的开发步骤
    * a: 步骤介绍
        1.注册驱动
            告知JVM使用的是哪一个数据库的驱动
        2.获得连接
            使用JDBC中的类,完成对MySQL数据库的连接
        3.获得语句执行平台
            通过连接对象获取对SQL语句的执行者对象
        4.执行sql语句
            使用执行者对象,向数据库执行SQL语句
            获取到数据库的执行后的结果
        5.处理结果
        6.释放资源  一堆close()
                    

05导入mysql数据库驱动程序jar包

* A: 导入mysql数据库驱动程序jar包
    * a: 步骤
        * 创建lib目录,用于存放当前项目需要的所有jar包
        * 选择jar包,右键执行build path / Add to Build Path

06注册数据库驱动程序

* A: 注册数据库驱动程序
    * a: 案例代码
        public class JDBCDemo {
            public static void main(String[] args)throws ClassNotFoundException,SQLException{
                //1.注册驱动 反射技术,将驱动类加入到内容
                // 使用java.sql.DriverManager类静态方法 registerDriver(Driver driver)
                // Diver是一个接口,参数传递,MySQL驱动程序中的实现类
                //DriverManager.registerDriver(new Driver());
                //驱动类源代码,注册2次驱动程序
                Class.forName("com.mysql.jdbc.Driver");
            }
        }

07获取数据库的连接对象

* A:获取数据库的连接对象
    * a: 案例代码
        public class JDBCDemo {
            public static void main(String[] args)throws ClassNotFoundException,SQLException{
                //1.注册驱动 反射技术,将驱动类加入到内容
                // 使用java.sql.DriverManager类静态方法 registerDriver(Driver driver)
                // Diver是一个接口,参数传递,MySQL驱动程序中的实现类
                //DriverManager.registerDriver(new Driver());
                //驱动类源代码,注册2次驱动程序
                Class.forName("com.mysql.jdbc.Driver");

                //2.获得数据库连接  DriverManager类中静态方法
                //static Connection getConnection(String url, String user, String password)
                //返回值是Connection接口的实现类,在mysql驱动程序
                //url: 数据库地址  jdbc:mysql://连接主机IP:端口号//数据库名字
                String url = "jdbc:mysql://localhost:3296/mybase";
                //用户名和密码用自己的
                String username="root";
                String password="123";
                Connection con = DriverManager.getConnection(url, username, password);
                System.out.println(con);
            }
        }

08获取SQL语句的执行对象对象

* A: 获取SQL语句的执行对象对象
    * a: 案例代码
        public class JDBCDemo {
            public static void main(String[] args)throws ClassNotFoundException,SQLException{
                //1.注册驱动 反射技术,将驱动类加入到内容
                // 使用java.sql.DriverManager类静态方法 registerDriver(Driver driver)
                // Diver是一个接口,参数传递,MySQL驱动程序中的实现类
                //DriverManager.registerDriver(new Driver());
                //驱动类源代码,注册2次驱动程序
                Class.forName("com.mysql.jdbc.Driver");

                //2.获得数据库连接  DriverManager类中静态方法
                //static Connection getConnection(String url, String user, String password)
                //返回值是Connection接口的实现类,在mysql驱动程序
                //url: 数据库地址  jdbc:mysql://连接主机IP:端口号//数据库名字
                String url = "jdbc:mysql://localhost:3296/mybase";
                String username="root";
                String password="123";
                Connection con = DriverManager.getConnection(url, username, password);

                //3.获得语句执行平台, 通过数据库连接对象,获取到SQL语句的执行者对象
                // con对象调用方法   Statement createStatement() 获取Statement对象,将SQL语句发送到数据库
                // 返回值是 Statement接口的实现类对象,,在mysql驱动程序
                Statement stat = con.createStatement();
                System.out.println(stat);
            }
        }

09执行insert语句获取结果集

* A: 执行insert语句获取结果集
    * a: 案例代码
        public class JDBCDemo {
            public static void main(String[] args)throws ClassNotFoundException,SQLException{
                //1.注册驱动 反射技术,将驱动类加入到内容
                // 使用java.sql.DriverManager类静态方法 registerDriver(Driver driver)
                // Diver是一个接口,参数传递,MySQL驱动程序中的实现类
                //DriverManager.registerDriver(new Driver());
                //驱动类源代码,注册2次驱动程序
                Class.forName("com.mysql.jdbc.Driver");

                //2.获得数据库连接  DriverManager类中静态方法
                //static Connection getConnection(String url, String user, String password)
                //返回值是Connection接口的实现类,在mysql驱动程序
                //url: 数据库地址  jdbc:mysql://连接主机IP:端口号//数据库名字
                String url = "jdbc:mysql://localhost:3296/mybase";
                String username="root";
                String password="123";
                Connection con = DriverManager.getConnection(url, username, password);

                //3.获得语句执行平台, 通过数据库连接对象,获取到SQL语句的执行者对象
                // con对象调用方法   Statement createStatement() 获取Statement对象,将SQL语句发送到数据库
                // 返回值是 Statement接口的实现类对象,,在mysql驱动程序
                Statement stat = con.createStatement();
                //  4.执行sql语句
                // 通过执行者对象调用方法执行SQL语句,获取结果
                // int executeUpdate(String sql)  执行数据库中的SQL语句, insert delete update
                // 返回值int,操作成功数据表多少行
                int row = stat.executeUpdate
                        ("INSERT INTO sort(sname,sprice,sdesc) VALUES('汽车用品',50000,'疯狂涨价')");
                System.out.println(row);

                //6.释放资源  一堆close()
                stat.close();
                con.close();
            }
        }
        

10执行select语句获取结果集

* A: 执行select语句获取结果集
    * a: 案例代码
        public class JDBCDemo1 {
            public static void main(String[] args) throws Exception{
                //1. 注册驱动
                Class.forName("com.mysql.jdbc.Driver");
                //2. 获取连接对象
                String url = "jdbc:mysql://localhost:3296/mybase";
                String username="root";
                String password="123";
                Connection con = DriverManager.getConnection(url, username, password);
                //3 .获取执行SQL 语句对象
                Statement stat = con.createStatement();
                // 拼写查询的SQL
                String sql = "SELECT * FROM sort";
                //4. 调用执行者对象方法,执行SQL语句获取结果集
                // ResultSet executeQuery(String sql)  执行SQL语句中的select查询
                // 返回值ResultSet接口的实现类对象,实现类在mysql驱动中
                ResultSet rs = stat.executeQuery(sql);
                //5 .处理结果集
                // ResultSet接口方法 boolean next() 返回true,有结果集,返回false没有结果集
                while(rs.next()){
                    //获取每列数据,使用是ResultSet接口的方法 getXX方法参数中,建议写String列名
                    System.out.println(rs.getInt("sid")+"   "+rs.getString("sname")+
                            "   "+rs.getDouble("sprice")+"   "+rs.getString("sdesc"));
                }

                rs.close();
                stat.close();
                con.close();
            }
        }

11SQL注入攻击

* A: SQL注入攻击
    * a: 注入问题
        * 假设有登录案例SQL语句如下:
        * SELECT * FROM 用户表 WHERE NAME = 用户输入的用户名 AND PASSWORD = 用户输的密码;
        * 此时,当用户输入正确的账号与密码后,查询到了信息则让用户登录。
            但是当用户输入的账号为XXX 密码为:XXX’  OR ‘a’=’a时,则真正执行的代码变为:
            * SELECT * FROM 用户表 WHERE NAME = ‘XXX’ AND PASSWORD =’ XXX’  OR ’a’=’a’;
        * 此时,上述查询语句时永远可以查询出结果的。那么用户就直接登录成功了,显然我们不
        * 希望看到这样的结果,这便是SQL注入问题。
    * b: 案例演示
        CREATE TABLE users(
             id INT PRIMARY KEY AUTO_INCREMENT,
             username VARCHAR(100),
             PASSWORD VARCHAR(100)
        );

        INSERT INTO users (username,PASSWORD) VALUES ('a','1'),('b','2');

        SELECT * FROM users;

        -- 登录查询
        SELECT * FROM users WHERE username='dsfsdfd' AND PASSWORD='wrethiyu'1
        OR 1=1

        SELECT * FROM users WHERE username='a' AND PASSWORD='1'OR'1=1'
        键盘录入:
        1
        1'OR' 1=1
        

12SQL注入攻击用户登录案例

* A: SQL注入攻击用户登录案例
    * a: 案例代码
        public class JDBCDemo2 {
            public static void main(String[] args)throws Exception {
                Class.forName("com.mysql.jdbc.Driver");
                String url = "jdbc:mysql://localhost:3296/mybase";
                String username = "root";
                String password = "123";
                Connection con = DriverManager.getConnection(url, username, password);
                Statement stat = con.createStatement();

                Scanner sc = new Scanner(System.in);
                String user = sc.nextLine();
                String pass = sc.nextLine();

                //执行SQL语句,数据表,查询用户名和密码,如果存在,登录成功,不存在登录失败
        //      String sql = "SELECT * FROM users WHERE username='dsfsdfd' AND PASSWORD='wrethiyu' OR 1=1";
                String sql = "SELECT * FROM users WHERE username='"+user+"' AND PASSWORD='"+pass+"'";
                System.out.println(sql);
                ResultSet rs = stat.executeQuery(sql);
                while(rs.next()){
                    System.out.println(rs.getString("username")+"   "+rs.getString("password"));
                }

                rs.close();
                stat.close();
                con.close();
            }
        }

13PrepareStatement接口预编译SQL语句

* A: PrepareStatement接口预编译SQL语句
    * a: 预处理对象
        * 使用PreparedStatement预处理对象时,建议每条sql语句所有的实际参数,都使用逗号分隔。
        * String sql = "insert into sort(sid,sname) values(?,?)";;
        * PreparedStatement预处理对象代码:
        * PreparedStatement psmt = conn.prepareStatement(sql)

    * b: 执行SQL语句的方法介绍
        * int executeUpdate(); --执行insert update delete语句.
        * ResultSet executeQuery(); --执行select语句.
        * boolean execute(); --执行select返回true 执行其他的语句返回false.
    * c: 设置实际参数
        * void setXxx(int index, Xxx xx) 将指定参数设置为给定Java的xx值。在将此值发送到数据库时,驱动程序将它转换成一个 SQL Xxx类型值。
        * 例如:
            * setString(2, "家用电器") 把SQL语句中第2个位置的占位符? 替换成实际参数 "家用电器"
    * d: 案例代码
        /*
         *  Java程序实现用户登录,用户名和密码,数据库检查
         *  防止注入攻击
         *  Statement接口实现类,作用执行SQL语句,返回结果集
         *  有一个子接口PreparedStatement  (SQL预编译存储,多次高效的执行SQL)
         *  PreparedStatement的实现类数据库的驱动中,如何获取接口的实现类
         *
         *  是Connection数据库连接对象的方法
         *  PreparedStatement prepareStatement(String sql) 

         */
        public class JDBCDemo3 {
            public static void main(String[] args)throws Exception {
                Class.forName("com.mysql.jdbc.Driver");
                String url = "jdbc:mysql://localhost:3296/mybase";
                String username = "root";
                String password = "123";
                Connection con = DriverManager.getConnection(url, username, password);
                Scanner sc = new Scanner(System.in);
                String user = sc.nextLine();
                String pass = sc.nextLine();

                //执行SQL语句,数据表,查询用户名和密码,如果存在,登录成功,不存在登录失败
                String sql = "SELECT * FROM users WHERE username=? AND PASSWORD=?";
                //调用Connection接口的方法prepareStatement,获取PrepareStatement接口的实现类
                //方法中参数,SQL语句中的参数全部采用问号占位符
                PreparedStatement pst =  con.prepareStatement(sql);
                System.out.println(pst);
                //调用pst对象set方法,设置问号占位符上的参数
                pst.setObject(1, user);
                pst.setObject(2, pass);

                //调用方法,执行SQL,获取结果集
                ResultSet rs = pst.executeQuery();
                while(rs.next()){
                    System.out.println(rs.getString("username")+"   "+rs.getString("password"));
                }

                rs.close();
                pst.close();
                con.close();
            }
        }

14PrepareStatement接口预编译SQL语句执行修改

* A: PrepareStatement接口预编译SQL语句执行修改
    * 案例代码
        /*
         *  使用PrepareStatement接口,实现数据表的更新操作
         */
        public class JDBCDemo {
            public static void main(String[] args) throws Exception{
                Class.forName("com.mysql.jdbc.Driver");
                String url = "jdbc:mysql://localhost:3296/mybase";
                String username="root";
                String password="123";
                Connection con = DriverManager.getConnection(url, username, password);  

                //拼写修改的SQL语句,参数采用?占位
                String sql = "UPDATE sort SET sname=?,sprice=? WHERE sid=?";
                //调用数据库连接对象con的方法prepareStatement获取SQL语句的预编译对象
                PreparedStatement pst = con.prepareStatement(sql);
                //调用pst的方法setXXX设置?占位
                pst.setObject(1, "汽车美容");
                pst.setObject(2, 49988);
                pst.setObject(3, 7);
                //调用pst方法执行SQL语句
                pst.executeUpdate();

                pst.close();
                con.close();
            }
        }

15PrepareStatement接口预编译SQL语句执行查询

* A: PrepareStatement接口预编译SQL语句执行查询
    * a: 案例代码
        /*
         *  PrepareStatement接口实现数据表的查询操作
         */
        public class JDBCDemo1 {
            public static void main(String[] args) throws Exception{
                Class.forName("com.mysql.jdbc.Driver");
                String url = "jdbc:mysql://localhost:3296/mybase";
                String username="root";
                String password="123";
                Connection con = DriverManager.getConnection(url, username, password);  

                String sql = "SELECT * FROM sort";

                PreparedStatement pst = con.prepareStatement(sql);

                //调用pst对象的方法,执行查询语句,Select
                ResultSet rs=pst.executeQuery();
                while(rs.next()){
                    System.out.println(rs.getString("sid")+"  "+rs.getString("sname")+"  "+rs.getString("sprice")+"  "+rs.getString("sdesc"));
                }
                rs.close();
                pst.close();
                con.close();
            }
        }

16JDBC的工具类和测试

* A: JDBC的工具类和测试
    * a: 案例代码
        //JDBCUtils工具类代码
        public class JDBCUtils {
            private JDBCUtils(){}
            private static Connection con ;

            static{
                try{
                    Class.forName("com.mysql.jdbc.Driver");
                    String url = "jdbc:mysql://localhost:3296/mybase";
                    String username="root";
                    String password="123";
                    con = DriverManager.getConnection(url, username, password);
                }catch(Exception ex){
                    throw new RuntimeException(ex+"数据库连接失败");
                }
            }

            /*
             * 定义静态方法,返回数据库的连接对象
             */
            public static Connection getConnection(){
                return con;
            }

            public static void close(Connection con,Statement stat){

                 if(stat!=null){
                     try{
                         stat.close();
                     }catch(SQLException ex){}
                 }

                 if(con!=null){
                     try{
                         con.close();
                     }catch(SQLException ex){}
                 }

            }

            public static void close(Connection con,Statement stat , ResultSet rs){
                 if(rs!=null){
                     try{
                         rs.close();
                     }catch(SQLException ex){}
                 }

                 if(stat!=null){
                     try{
                         stat.close();
                     }catch(SQLException ex){}
                 }

                 if(con!=null){
                     try{
                         con.close();
                     }catch(SQLException ex){}
                 }

            }
        }
    //测试JDBCUtils工具类的代码
    public class TestJDBCUtils {
        public static void main(String[] args)throws Exception {
            Connection con = JDBCUtils.getConnection();
            PreparedStatement pst = con.prepareStatement("SELECT sname FROM sort");
            ResultSet rs = pst.executeQuery();
            while(rs.next()){
                System.out.println(rs.getString("sname"));
            }
            JDBCUtils.close(con, pst, rs);
        }
    }
    

17数据表数据存储对象

* A: 数据表数据存储对象
    * a: 准备工作
        * 导入jar包
        * 拷贝day32定义的工具类JDBCUtils

    * b: 案例代码
        //定义实体类Sort
        public class Sort {
            private int sid;
            private String sname;
            private double sprice;
            private String sdesc;
            public Sort(int sid, String sname, double sprice, String sdesc) {
                this.sid = sid;
                this.sname = sname;
                this.sprice = sprice;
                this.sdesc = sdesc;
            }
            public Sort(){}
            public int getSid() {
                return sid;
            }
            public void setSid(int sid) {
                this.sid = sid;
            }
            public String getSname() {
                return sname;
            }
            public void setSname(String sname) {
                this.sname = sname;
            }
            public double getSprice() {
                return sprice;
            }
            public void setSprice(double sprice) {
                this.sprice = sprice;
            }
            public String getSdesc() {
                return sdesc;
            }
            public void setSdesc(String sdesc) {
                this.sdesc = sdesc;
            }
            @Override
            public String toString() {
                return "Sort [sid=" + sid + ", sname=" + sname + ", sprice=" + sprice + ", sdesc=" + sdesc + "]";
            }
        }

        /*
         *  JDBC读取数据表sort,每行数据封装到Sort类的对象中
         *  很多个Sort类对象,存储到List集合中
         */
        public class JDBCDemo {
            public static void main(String[] args) throws Exception{
                //使用JDBC工具类,直接获取数据库连接对象
                Connection con = JDBCUtils.getConnection();
                //连接获取数据库SQL语句执行者对象
                PreparedStatement pst = con.prepareStatement("SELECT * FROM sort");
                //调用查询方法,获取结果集
                ResultSet rs = pst.executeQuery();
                //创建集合对象
                List<Sort> list = new ArrayList<Sort>();
                while(rs.next()){
                    //获取到每个列数据,封装到Sort对象中
                    Sort s = new Sort(rs.getInt("sid"),rs.getString("sname"),rs.getDouble("sprice"),rs.getString("sdesc"));
                    //封装的Sort对象,存储到集合中
                    list.add(s);
                }
                JDBCUtils.close(con, pst, rs);
                //遍历List集合
                for(Sort s : list){
                    System.out.println(s);
                }
            }
        }

18properties配置文件

* A: properties配置文件
    * a: 相关介绍
        * 开发中获得连接的4个参数(驱动、URL、用户名、密码)通常都存在配置文件中,方便后期维护,程序如果需要更换数据库,
            只需要修改配置文件即可。
        * 通常情况下,我们习惯使用properties文件,此文件我们将做如下要求:
            1.  文件位置:任意,建议src下
            2.  文件名称:任意,扩展名为properties
            3.  文件内容:一行一组数据,格式是“key=value”.
                a)  key命名自定义,如果是多个单词,习惯使用点分隔。例如:jdbc.driver
                b)  value值不支持中文,如果需要使用非英文字符,将进行unicode转换。

19properties文件的创建和编写

* A: properties文件的创建和编写
    * a: properties文件的创建
        * src路径下建立database.properties(其实就是一个文本文件)
    * b: properties文件的编写(内容如下)
        driverClass=com.mysql.jdbc.Driver
        url=jdbc:mysql://localhost:3296/mybase
        username=root
        password=123        

20加载配置文件

* A: 加载配置文件
    * a: 案例代码
        /*
         *  加载properties配置文件
         *  IO读取文件,键值对存储到集合
         *  从集合中以键值对方式获取数据库的连接信息,完成数据库的连接
         */
        public class PropertiesDemo {
            public static void main(String[] args) throws Exception{
                FileInputStream fis = new FileInputStream("database.properties");
                System.out.println(fis);
                //使用类的加载器
                InputStream in = PropertiesDemo.class.getClassLoader().getResourceAsStream("database.properties");
                System.out.println(in);
                Properties pro = new Properties();
                pro.load(in);
                System.out.println(in);
            }
        }

21通过配置文件连接数据库

* A: 通过配置文件连接数据库
    * a: 案例代码
        /*
         *  加载properties配置文件
         *  IO读取文件,键值对存储到集合
         *  从集合中以键值对方式获取数据库的连接信息,完成数据库的连接
         */
        public class PropertiesDemo {
            public static void main(String[] args) throws Exception{
                FileInputStream fis = new FileInputStream("database.properties");
                System.out.println(fis);
                //使用类的加载器
                InputStream in = PropertiesDemo.class.getClassLoader().getResourceAsStream("database.properties");
                System.out.println(in);
                Properties pro = new Properties();
                pro.load(in);
                //获取集合中的键值对
                String driverClass=pro.getProperty("driverClass");
                String url = pro.getProperty("url");
                String username = pro.getProperty("username");
                String password = pro.getProperty("password");
                Class.forName(driverClass);
                Connection con = DriverManager.getConnection(url, username, password);
                System.out.println(con);

            }
        }

22读取配置文件的工具类

* A: 读取配置文件的工具类
    * a: 案例代码
        /*
         *  编写数据库连接的工具类,JDBC工具类
         *  获取连接对象采用读取配置文件方式
         *  读取文件获取连接,执行一次,static{}
         */
        public class JDBCUtilsConfig {
            private static Connection con ;
            private static String driverClass;
            private static String url;
            private static String username;
            private static String password;

            static{
                try{
                    readConfig();
                    Class.forName(driverClass);
                    con = DriverManager.getConnection(url, username, password);
                }catch(Exception ex){
                    throw new RuntimeException("数据库连接失败");
                }
            }

            private static void readConfig()throws Exception{
                InputStream in = JDBCUtilsConfig.class.getClassLoader().getResourceAsStream("database.properties");
                 Properties pro = new Properties();
                 pro.load(in);
                 driverClass=pro.getProperty("driverClass");
                 url = pro.getProperty("url");
                 username = pro.getProperty("username");
                 password = pro.getProperty("password");
            }

            public static Connection getConnection(){
                return con;
            }

        }
        

23测试工具类

* A: 测试工具类
    * a: 案例代码
        public class TestJDBCUtils {
            public static void main(String[] args) {
                Connection con = JDBCUtilsConfig.getConnection();
                System.out.println(con);
            }
        }

作业测试

必须能独立写出JDBCUtils工具类,保证用JDBCUtils工具类能完成功能,不用JDBCUtils工具类工具类也能够完成功能

1.map中有如下数据(用户名=密码)

[liuyan=123456,wangbaoqiang=123321,fangbian=abcd,miejueshitai=123abc321]
在ip为127.0.0.1数据库名为stdb,连接数据库的用户名和密码为:admin和123456中有一个userinfo表相关字段为(id,username,password)
(1)将map中的手机号码取出来打印到控制台上
    * 直接使用map集合的keySet()方法获取所有的key组成的Set集合,并遍历
(2)判断map中所有的用户名在userinfo表中是否存在存在则输出"该用户已注册",如果不存在将该用户名及对应的密码存入到userinfo表中
(map中的数据不需要修改)
    * 连接到数据库
    * 创建表
    drop database stdb;
    create database stdb;
    use stdb;
    create table userinfo(
        id int(10) primary key auto_increment,
        username varchar(200),
        password varchar(200)
    );
        

2.一个数据库stdb,用户名为admin 密码为123456 已存在一个表student中有五个学生的信息,姓名,性别,年龄,分数.

id(varchar(20))       name(varchar(20))      sex(varchar(20))     score(int(10))
 1                    李少荣                 女                   80
 2                    邵凯                   男                   75
 3                    周强                   男                   95
 4                    王晓婷                 女                   55
 5                    张秀花                 女                   68
 6                    顾会                   女                   50
 7                    赵天一                 男                   32
(1)查询女性,成绩80以上的学生数量
(2)将姓张的男同学的的成绩改为100
(3)查询成绩大于60的女性,显示姓名,性别,成绩
(4)分别统计所有男同学的平均分,所有女同学的平均分及总平均分
(5)按照分数从小到大的顺序打印分数大于总平均分的学员信息(id-name-sex-score),并将分数大于总平均分的学员信息(按照分数从小到大的顺序)(id-name-sex-score)写入到studentInfo.txt文件中(写入格式:id-name-sex-score)
(6)定义查询所有学生的方法public List<Student> getAllStudent(){}
(7)定义根据id查询学生的方法public Student getStudentById(String id){}
(8)定义根据id删除学生的方法public int deleteStudentById(String id){}//注意只有数据库中有才能删除,没有无法删除
(9)定义添加学员的方法public int addStudent(){}//注意只有数据库中没有有才能添加,有无法添加
(10)定义根据id修改学员的信息public int updateStudentById(String id){}//注意只有数据库中有才能修改,没有无法修改

29_Java_数据库_第29天(JDBC、DBUtils)_讲义的更多相关文章

  1. RAC集群数据库连库代码示例(jdbc thin方式,非oci)

    1.RAC集群数据库连库代码示例(jdbc thin方式,非oci):jdbc.driverClassName=oracle.jdbc.driver.OracleDriverjdbc.url=jdbc ...

  2. Java开发工程师(Web方向) - 03.数据库开发 - 第1章.JDBC

    第1章--JDBC JDBC基础 通过Java Database Connectivity可以实现Java程序对后端数据库的访问 一个完整的数据库部署架构,通常是由客户端和服务器端两部分组成 客户端封 ...

  3. Atitit. 数据库-----catalog与schema的设计区别以及在实际中使用 获取数据库所有库表 java jdbc php  c#.Net

    Atitit. 数据库-----catalog与schema的设计区别以及在实际中使用 获取数据库所有库表 java jdbc php  c#.Net 1. -catalog与schema的设计区别1 ...

  4. 数据库事务(1)----- JDBC事务与JTA事务

    数据库事务(一)- JDBC事务与JTA事务 本文主要对JDBC事务与JTA事务做一个简单介绍. 1. 数据库事务概念 一个数据库事务通常包含对数据库进行读或写的一个操作序列.它的存在包含有以下两个目 ...

  5. python学习两月总结_汇总大牛们的思想_值得收藏

    下面是我汇总的我学习两个月python(version:3.3.2)的所有笔记 你可以访问:http://www.python.org获取更多信息 你也可以访问:http://www.cnblogs. ...

  6. C Primer Plus_第5章_运算符、表达式和语句_编程练习

    Practice 1. 输入分钟输出对应的小时和分钟. #include #define MIN_PER_H 60 int main(void) { int mins, hours, minutes; ...

  7. java画图程序_图片用字母画出来_源码发布_版本二

    在上一个版本:java画图程序_图片用字母画出来_源码发布 基础上,增加了图片同比例缩放,使得大像素图片可以很好地显示画在Notepad++中. 项目结构: 运行效果1: 原图:http://imag ...

  8. C++框架_之Qt的开始部分_概述_安装_创建项目_快捷键等一系列注意细节

    C++框架_之Qt的开始部分_概述_安装_创建项目_快捷键等一系列注意细节 1.Qt概述 1.1 什么是Qt Qt是一个跨平台的C++图形用户界面应用程序框架.它为应用程序开发者提供建立艺术级图形界面 ...

  9. ARM核心板_迅为4418核心板_高稳定超轻薄_研发超灵感

    ARM核心板_迅为4418核心板_三星四核S5P4418处理器 4418核心板正面: 4418核心板反面:4418核心板尺寸图:详情了解:https://item.taobao.com/item.ht ...

  10. 独家专访|浙江执御:为何接受富安娜入股而不选VC?_深圳市跨境电子商务协会_新浪博客

    独家专访|浙江执御:为何接受富安娜入股而不选VC?_深圳市跨境电子商务协会_新浪博客   http://blog.sina.com.cn/s/blog_13cb5d69e0102vuvk.html

随机推荐

  1. FSCapture注册码

    企业版序列号: name:bluman serial/序列号/注册码:VPISCJULXUFGDDXYAUYF

  2. P2154 [SDOI2009]虔诚的墓主人

    略有一点点思维的题. 首先,如果一个点上,下,左,右分别有\(a,b,c,d\)棵树,那这个点的十字架方案为\(C_{a}^{k}C_{b}^{k}C_{c}^{k}C_{d}^{k}\). 按x坐标 ...

  3. cogs1799 [国家集训队2012]tree(伍一鸣)

    LCT裸题 注意打标记之间的影响就是了 这个膜数不会爆unsigned int #include<cstdio> #include<cstdlib> #include<a ...

  4. 浅谈__dict__

    类的 __dict__ 先看一个例子: > class A(object): pass > ... > A.__dict__ dict_proxy({'__dict__': < ...

  5. Spring学习(十六)----- Spring AOP实例(Pointcut(切点),Advisor)

    在上一个Spring AOP通知的例子,一个类的整个方法被自动拦截.但在大多数情况下,可能只需要一种方式来拦截一个或两个方法,这就是为什么引入'切入点'的原因.它允许你通过它的方法名来拦截方法.另外, ...

  6. APP性能测试中的几个重要概念

    转载一篇文章,关于app性能测试的几个概念,对于想要接触app测试的朋友或许有些帮助. 我们在使用各种 App 的时候基本会关注到:这款软件挺耗流量的?运行起来设备掉电有点快嘛?切换页面的时候还会有卡 ...

  7. 怎么使用Spring配置事务 ?

    Spring同时支持编程式事务策略和声明式事务策略,大部分时候都采用声明式事务策略. 声明式事务管理的配置方式,通常有以下4种: (1) 使用TransactionProxyFactoryBean为目 ...

  8. TCP/IP理解

    目录 1.概述 2.TCP/IP寻址及其协议族 3.TCP/IP 邮件 1.概述 介绍:什么是TCP/IP? TCP/IP协议是对计算机必须遵守的规则的描述,遵守了规则才能通信. 应用: 浏览器与服务 ...

  9. 【SIKIA计划】_05_Unity5.3开发2D游戏笔记

    一.界面基本操作 01.Project基本分类[Audios]音效[Material]材质[Prefabs]预制[Scenes]场景[Scripts]脚本[Sprites]精灵 02.Project丶 ...

  10. 九九乘法表的python复习

    九九开始的复习 这周复习之前的学的知识关于range函数,gormat函数,print的使用总结一下 从一个小例子开始,开始我的回顾吧, 大家都是从那个九九乘法表开始的数学之旅,从一一得一,开始了我们 ...