JDBC

一:初始JDBC

DBA通过DBMS来操作DB=====DBS

1.1JDBC的定义

  01.Java DataBase  Connectivity,java数据库连接技术

02.java.sql包下有一组用java语言来编写的类和接口(API)

03.不同的数据库厂商,提供了不同的数据库驱动包

1.2JDBCODBC

   JDBC:

   01.java语言编写

   02.性能高,跨平台

   03.访问不同的数据库,需要下载不同的驱动包

   ODBC

   01.不需要下载不同的驱动包

   02.性能低,而且只能在windows系统中运行

1.3:常用的JDBC API

1. 数据库连接的四要素

    01.驱动包     driver

    02.连接数据库的地址  url

    03.连接数据库的用户名

    04.连接数据库的密码

2. Driver

   在程序运行期间,动态的加载指定的驱动类

      Mysql   com.mysql.jdbc.Driver

      Oracle  oracle.jdbc.driver.OracleDriver

3. DriverManager

    真正连接数据库需要的类

    对象有一个getConncetion(url,userName,password),返回一个Conncetion对象!

    Url==》需要连接的数据库地址

    jdbc:mysql://ip地址:3306/数据库名称

    userName:用户名

    Password:密码

4. Connection

    生成用来操作数据库的statement对象

    createStatement()===》Statement对象

    preparedStatement()===>PreparedStatement对象

5. PreparedStatement   Statement  

    真正执行数据库的增删改查操作!

    executeQuery()===>所有的查询使用,返回ResultSet对象

    executeUpdate()===》增删改使用,返回int类型的数值

6. ResultSet

    获取查询的返回结果集

1.4:使用JDBC 连接数据库的步骤

    01.下载对应的驱动包并放在项目中

    02.通过反射机制加载驱动类   Class.forName(“com.mysql.jdbc.Driver”)

    03.通过DriverManager创建Connection对象

    04.创建sql语句,通过statement对象来执行

    05.处理结果集

    06.释放资源

1.5:PreparedStatement 和Statement 的区别

    01.创建statement对象的时候不需要sql语句

        创建preparedStatement对象的时候需要sql语句

    02.preparedStatement有预编译sql的功能,执行效率高

    03.preparedStatement可以防止sql注入

    04.preparedStatement可以使用占位符的方式给参数赋值,方便我们操作

二:第一个JDBC小案例

2.1:主菜单

 

// 让所有的方法中 使用 输入流对象

private static Scanner input = new Scanner(System.in);

// 主函数

public static void main(String[] args) {

        // 默认显示一级菜单

        showFirstMenu();

}

2.21级菜单

private static void showFirstMenu() {

    System.out.println("=============欢迎您进入学生管理系统=============");

    System.out.println("1:登录");

    System.out.println("2:注册");

    System.out.println("3:退出系统");

    System.out.println("===================》请选择");

    int choose = input.nextInt(); // 获取用户的输入

    switch (choose) {

        case 1: // 登录

        login();

        break;

        case 2: // 注册

        register();

        break;

        case 3: // 退出系统

            System.out.println("欢迎您下次光临!");

            System.exit(0);

        break;

    }

}

2.3:登录

private static void login() {

    Connection connection = null; // 便于我们释放资源

    Statement statement = null;

    ResultSet rs = null;

    try {

    // 通过反射机制获取数据库驱动包

    Class.forName("com.mysql.jdbc.Driver");

    // 通过DriverManager获取Conncetion连接对象

    connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/t19", "root", "");

    // 获取用户的输入

    System.out.println("请输入用户名:");

    String name = input.next();

    System.out.println("请输入密码:");

    String pwd = input.next();

    // 通过connection对象创建statement对象

    statement = connection.createStatement();

    // 创建sql语句

    String sql = "SELECT * FROM student WHERE studentName='" + name+ "' AND LoginPwd='" + pwd + "'";

    // 通过statement对象执行sql语句

    rs = statement.executeQuery(sql);

    if (rs.next()) { // 证明有数据

        System.out.println("登录成功");

        showSecondMenu();// 2级菜单

    } else {

        System.out.println("登录失败,请您重新登录====");

        login();

    }

    } catch (ClassNotFoundException e) {

            e.printStackTrace();

    } catch (SQLException e) {

            e.printStackTrace();

    } finally { // 释放资源

        if (rs != null) {

            try {

                rs.close();

            } catch (SQLException e) {

                e.printStackTrace();

            }

        }

        if (statement != null) {

            try {

                statement.close();

            } catch (SQLException e) {

                e.printStackTrace();

            }

        }

        if (connection != null) {

            try {

                connection.close();

            } catch (SQLException e) {

                e.printStackTrace();

            }

        }

    } 

}

2.4:注册

/**

 * 注册 ===》数据的新增

 * insert into student(LoginPwd,StudentName,Phone,Address,Email)

 *  values('admin','张三','15753049998,'海淀区','501804292@qq.com')

 *

 */

private static void register() {

    Connection connection = null; // 便于我们释放资源

    Statement statement = null;

    try {

    // 通过反射机制获取数据库驱动包

    Class.forName("com.mysql.jdbc.Driver");

    // 通过DriverManager获取Conncetion连接对象

    connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/t19", "root", "");

    // 获取用户的输入

    System.out.println("请输入用户名:");

    String name = input.next();

    System.out.println("请输入密码:");

    String pwd = input.next();

    System.out.println("请输入phone:");

    String phone = input.next();

    System.out.println("请输入address:");

    String address = input.next();

    System.out.println("请输入email:");

    String email = input.next();

    // 通过connection对象创建statement对象

    statement = connection.createStatement();

    // 创建sql语句

    String sql = "INSERT INTO student(LoginPwd,StudentName,Phone,Address,Email) VALUES('"+ pwd+ "','"+ name+ "','"+ phone+ "','"+ address+ "','" + email + "')";

    // 通过statement对象执行sql语句

    int row = statement.executeUpdate(sql);

    if (row > 0) {

        System.out.println("新增成功!");

        showFirstMenu(); // 返回一级菜单

    } else {

        System.out.println("新增失败!");

        register();// 再次注册

    }

    } catch (ClassNotFoundException e) {

        e.printStackTrace();

    } catch (SQLException e) {

        e.printStackTrace();

    } finally { // 释放资源

 

        if (statement != null) {

            try {

            statement.close();

            } catch (SQLException e) {

            e.printStackTrace();

            }

        }

        if (connection != null) {

            try {

            connection.close();

            } catch (SQLException e) {

            e.printStackTrace();

            }

        }

    }

}

2.52级菜单

private static void showSecondMenu() {

        System.out.println("============进入了2级菜单============");

        System.out.println("============1:查询所有============");

        System.out.println("============2:修改信息============");

        System.out.println("============3:删除============");

        System.out.println("============4:返回1级菜单============");

        System.out.println("============(请您选择)============");

        int choose = input.nextInt(); // 获取用户的输入

        switch (choose) {

        case 1: // 查询所有

        findAllStudents();

        break;

        case 2: // 修改信息

        updateByID();

        break;

        case 3: // 删除

        deleteByID();

        break;

        case 4: // 返回1级菜单

        showFirstMenu();

        break;

    }

}

2.6:查询所有

private static void findAllStudents() {

    Connection connection = null; // 便于我们释放资源

    Statement statement = null;

    ResultSet rs = null;

    try {

    // 通过反射机制获取数据库驱动包

    Class.forName("com.mysql.jdbc.Driver");

    // 通过DriverManager获取Conncetion连接对象

    connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/t19", "root", "");

    // 通过connection对象创建statement对象

    statement = connection.createStatement();

    // 创建sql语句

    String sql = "SELECT * FROM student";

    // 通过statement对象执行sql语句

    rs = statement.executeQuery(sql);

    // 循环获取每一个student对象

    while (rs.next()) {

        int studentNo = rs.getInt("studentNo");

        String studentName = rs.getString("studentName");

        String loginPwd = rs.getString("loginPwd");

        // 获取日期

        Timestamp birthday = rs.getTimestamp("BornDate");

        System.out.println("学生编号==》" + studentNo);

        System.out.println("学生姓名==》" + studentName);

        System.out.println("登录密码==》" + loginPwd);

        System.out.println("出生日期==》" + birthday);

    }

    } catch (ClassNotFoundException e) {

        e.printStackTrace();

    } catch (SQLException e) {

            e.printStackTrace();

    } finally { // 释放资源

        if (rs != null) {

            try {

                rs.close();

            } catch (SQLException e) {

                e.printStackTrace();

            }

        }

        if (statement != null) {

            try {

                statement.close();

            } catch (SQLException e) {

                e.printStackTrace();

            }

        }

        if (connection != null) {

            try {

                connection.close();

            } catch (SQLException e) {

                e.printStackTrace();

            }

        }

    }}

 

2.7:修改

private static void updateByID() {

    Connection connection = null; // 便于我们释放资源

    Statement statement = null;

    try {

    // 通过反射机制获取数据库驱动包

    Class.forName("com.mysql.jdbc.Driver");

    // 通过DriverManager获取Conncetion连接对象

    connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/t19", "root", "");

    // 获取用户的输入

    System.out.println("请输入需要修改的用户编号:");

    int id = input.nextInt();

    System.out.println("请输入新用户名:");

    String name = input.next();

    System.out.println("请输入新密码:");

    String pwd = input.next();

    // 通过connection对象创建statement对象

    statement = connection.createStatement();

    // 创建sql语句

    String sql = "UPDATE student SET studentName='" + name+ "',LoginPwd='" + pwd + "' WHERE studentNo=" + id + "";

    // 通过statement对象执行sql语句

    int row = statement.executeUpdate(sql);

    if (row > 0) {

        System.out.println("修改成功!");

    } else {

        System.out.println("修改失败!");

    }

    showSecondMenu(); // 进入2级菜单

    } catch (ClassNotFoundException e) {

        e.printStackTrace();

    } catch (SQLException e) {

        e.printStackTrace();

    } finally { // 释放资源

        if (statement != null) {

            try {

            statement.close();

            } catch (SQLException e) {

            e.printStackTrace();

            }

        }

        if (connection != null) {

            try {

            connection.close();

            } catch (SQLException e) {

            e.printStackTrace();

            }

        }

    }

}

2.8:删除

private static void deleteByID() {

    Connection connection = null; // 便于我们释放资源

    Statement statement = null;

    try {

    // 通过反射机制获取数据库驱动包

    Class.forName("com.mysql.jdbc.Driver");

    // 通过DriverManager获取Conncetion连接对象

    connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/t19", "root", "");

    // 获取用户的输入

    System.out.println("请输入需要删除的用户编号:");

    int id = input.nextInt();

    // 通过connection对象创建statement对象

    statement = connection.createStatement();

    // 创建sql语句

    String sql = "delete from student where studentno=" + id + "";

    // 通过statement对象执行sql语句

    int row = statement.executeUpdate(sql);

    if (row > 0) {

        System.out.println("删除成功!");

    } else {

        System.out.println("删除失败!");

    }

    showSecondMenu(); // 进入2级菜单

    } catch (ClassNotFoundException e) {

    e.printStackTrace();

    } catch (SQLException e) {

    e.printStackTrace();

    } finally { // 释放资源

 

        if (statement != null) {

            try {

            statement.close();

            } catch (SQLException e) {

            e.printStackTrace();

            }

        }

        if (connection != null) {

            try {

            connection.close();

            } catch (SQLException e) {

            e.printStackTrace();

            }

        }

    }

}

2.9:出现的问题

     发现的问题:

          01.数据库的所有操作方法中有重复代码  代码冗余

     反射获取驱动包

             释放资源

     所有的增删改查都是用了相同的 JDBC API

          02.可以sql注入  因为我们使用的Statement对象

      解决办法:

         01.提取所有方法中共同的JDBC API

         02.提取所有的释放资源代码

         03.把所有的Statement对象全部换成PreparedStatement对象

         04.把所有sql语句中的参数换成占位符 ?(务必是英文状态下的)

 

 

 


        

智慧旅游解决方案利用云计算、物联网和移动互联网技术,通过便携终端设备,实现对旅游资源、经济、活动和旅游者信息的智能感知和发布。这种技术的应用旨在提升游客在旅游各个环节的体验,使他们能够轻松获取信息、规划行程、预订票务和安排食宿。智慧旅游平台为旅游管理部门、企业和游客提供服务,包括政策发布、行政管理、景区安全、游客流量统计分析、投诉反馈等。此外,平台还提供广告促销、库存信息、景点介绍、电子门票、社交互动等功能。 智慧旅游的建设规划得到了国家政策的支持,如《国家中长期科技发展规划纲要》和国务院的《关于加快发展旅游业的意见》,这些政策强调了旅游信息服务平台的建设和信息化服务的重要性。随着技术的成熟和政策环境的优化,智慧旅游的时机已经到来。 智慧旅游平台采用SaaS、PaaS和IaaS等云服务模式,提供简化的软件开发、测试和部署环境,实现资源的按需配置和快速部署。这些服务模式支持旅游企业、消费者和管理部门开发高性能、高可扩展的应用服务。平台还整合了旅游信息资源,提供了丰富的旅游产品创意平台和统一的旅游综合信息库。 智慧旅游融合应用面向游客和景区景点主管机构,提供无线城市门户、智能导游、智能门票及优惠券、景区综合安防、车辆及停车场管理等服务。这些应用通过物联网和云计算技术,实现了旅游服务的智能化、个性化和协同化,提高了旅游服务的自由度和信息共享的动态性。 智慧旅游的发展标志着旅游信息化建设的智能化和应用多样化趋势,多种技术和应用交叉渗透至旅游行业的各个方面,预示着全面的智慧旅游时代已经到来。智慧旅游不仅提升了游客的旅游体验,也为旅游管理和服务提供了高效的技术支持。
智慧旅游解决方案利用云计算、物联网和移动互联网技术,通过便携终端设备,实现对旅游资源、经济、活动和旅游者信息的智能感知和发布。这种技术的应用旨在提升游客在旅游各个环节的体验,使他们能够轻松获取信息、规划行程、预订票务和安排食宿。智慧旅游平台为旅游管理部门、企业和游客提供服务,包括政策发布、行政管理、景区安全、游客流量统计分析、投诉反馈等。此外,平台还提供广告促销、库存信息、景点介绍、电子门票、社交互动等功能。 智慧旅游的建设规划得到了国家政策的支持,如《国家中长期科技发展规划纲要》和国务院的《关于加快发展旅游业的意见》,这些政策强调了旅游信息服务平台的建设和信息化服务的重要性。随着技术的成熟和政策环境的优化,智慧旅游的时机已经到来。 智慧旅游平台采用SaaS、PaaS和IaaS等云服务模式,提供简化的软件开发、测试和部署环境,实现资源的按需配置和快速部署。这些服务模式支持旅游企业、消费者和管理部门开发高性能、高可扩展的应用服务。平台还整合了旅游信息资源,提供了丰富的旅游产品创意平台和统一的旅游综合信息库。 智慧旅游融合应用面向游客和景区景点主管机构,提供无线城市门户、智能导游、智能门票及优惠券、景区综合安防、车辆及停车场管理等服务。这些应用通过物联网和云计算技术,实现了旅游服务的智能化、个性化和协同化,提高了旅游服务的自由度和信息共享的动态性。 智慧旅游的发展标志着旅游信息化建设的智能化和应用多样化趋势,多种技术和应用交叉渗透至旅游行业的各个方面,预示着全面的智慧旅游时代已经到来。智慧旅游不仅提升了游客的旅游体验,也为旅游管理和服务提供了高效的技术支持。
深度学习是机器学习的一个子领域,它基于人工神经网络的研究,特别是利用多层次的神经网络来进行学习和模式识别。深度学习模型能够学习数据的高层次特征,这些特征对于图像和语音识别、自然语言处理、医学图像分析等应用至关重要。以下是深度学习的一些关键概念和组成部分: 1. **神经网络(Neural Networks)**:深度学习的基础是人工神经网络,它是由多个层组成的网络结构,包括输入层、隐藏层和输出层。每个层由多个神经元组成,神经元之间通过权重连接。 2. **前馈神经网络(Feedforward Neural Networks)**:这是最常见的神经网络类型,信息从输入层流向隐藏层,最终到达输出层。 3. **卷积神经网络(Convolutional Neural Networks, CNNs)**:这种网络特别适合处理具有网格结构的数据,如图像。它们使用卷积层来提取图像的特征。 4. **循环神经网络(Recurrent Neural Networks, RNNs)**:这种网络能够处理序列数据,如时间序列或自然语言,因为它们具有记忆功能,能够捕捉数据中的时间依赖性。 5. **长短期记忆网络(Long Short-Term Memory, LSTM)**:LSTM 是一种特殊的 RNN,它能够学习长期依赖关系,非常适合复杂的序列预测任务。 6. **生成对抗网络(Generative Adversarial Networks, GANs)**:由两个网络组成,一个生成器和一个判别器,它们相互竞争,生成器生成数据,判别器评估数据的真实性。 7. **深度学习框架**:如 TensorFlow、Keras、PyTorch 等,这些框架提供了构建、训练和部署深度学习模型的工具和库。 8. **激活函数(Activation Functions)**:如 ReLU、Sigmoid、Tanh 等,它们在神经网络中用于添加非线性,使得网络能够学习复杂的函数。 9. **损失函数(Loss Functions)**:用于评估模型的预测与真实值之间的差异,常见的损失函数包括均方误差(MSE)、交叉熵(Cross-Entropy)等。 10. **优化算法(Optimization Algorithms)**:如梯度下降(Gradient Descent)、随机梯度下降(SGD)、Adam 等,用于更新网络权重,以最小化损失函数。 11. **正则化(Regularization)**:技术如 Dropout、L1/L2 正则化等,用于防止模型过拟合。 12. **迁移学习(Transfer Learning)**:利用在一个任务上训练好的模型来提高另一个相关任务的性能。 深度学习在许多领域都取得了显著的成就,但它也面临着一些挑战,如对大量数据的依赖、模型的解释性差、计算资源消耗大等。研究人员正在不断探索新的方法来解决这些问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值