当前位置: 首页 > news >正文

网站建设方案内容个人网站建设基础与实例

网站建设方案内容,个人网站建设基础与实例,个人网站怎么建设,重庆网站制作的网站文章目录JDBC1.概念2.原理3. 如何使用JDBC编程1. 下载mysql的jdbc驱动2. 项目中引入驱动4. JDBC使用1. 和数据库建立连接2.获取连接3. Statement对象4. 释放资源JDBC 1.概念 JDBC,即Java Database Connectivity#xff0c;java数据库连接。是Java提供的API用来执行SQL语句java数据库连接。是Java提供的API用来执行SQL语句它是Java中的数据库连接规范这个API由java.sql.*,javax.sql.*包中的一些类和接口构成它为Java开发人员操作数据库提供了一个标准的API提供了多种关系的数据空提供访问。 2.原理 JDBC为多种关系数据库提供了统一访问方式数据库的种类有很多每个数据库提供的接口都各不同Java就能够使用一套代码就能操作各种不同种类的数据库。 Java开发者只需呀关注怎么使用就可以了JDBC的API是Java标准库里提供好的类驱动程序往往是一个jar包访问的是数据库服务器。 3. 如何使用JDBC编程 1. 下载mysql的jdbc驱动 MySQL官网下载从MySQL的githup下载Maven中央仓库下载 需要注意的是,如果MySQL的服务器是5.7话,那么驱动包也得是5系列的,8就用8系列的驱动包. 下载后的jar包里其实就是包含了很多.class文件,安装特定的目录结构组织,能够被Java识别. 2. 项目中引入驱动 创建一个目录把jar包拷贝进来由键这个目录,add as libray然后确定即可 4. JDBC使用 1. 和数据库建立连接 这个URL是和数据库建立连接时必备的它的基本格式为 String URL jdbc:mysql://127.0.0.1:3306/system_book?characterEncodingutf8useSSLfalse;jdbc:mysql协议名对于JDBC来说是固定的127.0.0.1数据库服务器ip(这里表示本机Ip)3306MySQL默认端口号system_book数据库名characterEncodingutf8当前成员以utf8字符集解析数据useSSLfalse传输是否加密 创建连接代码 private static final String URL jdbc:mysql://127.0.0.1:3306/system_book?characterEncodingutf8useSSLfalse;private static final String USER root;private static final String PASSWORD root;private static DataSource dataSource new MysqlDataSource();static {((MysqlDataSource)dataSource).setURL(URL);((MysqlDataSource)dataSource).setUser(USER);((MysqlDataSource)dataSource).setPassword(PASSWORD);}USER数据库用户名 PASSWORD数据库密码 DataSource是JDBC提供的一个接口 MysqlDataSource是一个类实现了DataSource接口用于MySQL操作数据库 这里的setURL、setUser、setPassword都是MysqlDataSource的方法 为啥上述方法不是DataSource接口的原因就是并不是所有数据都能设置者几个东西 这里的代码为啥要先向上转型再向下转型呢其实可以写成这样 MysqlDataSource mysqlDataSource new MysqlDataSource();mysqlDataSource.setURL(URL);mysqlDataSource.setUser(USER);mysqlDataSource.setPassword(PASSWORD);使用DataSource的好处就是我们持有的是DataSource示例它可以接受实现了它的其它类假设如果后续要更换数据库只需要修改这几行代码即可。如果使用MysqlDataSource就要修改大量代码 2.获取连接 DataSource dataSource new MysqlDataSource(); ((MysqlDataSource)dataSource).setURL(URL);((MysqlDataSource)dataSource).setUser(USER);((MysqlDataSource)dataSource).setPassword(PASSWORD); Connection connection dataSource.getConnection();还有一种获取连接的方式通过DriverManager驱动管理类的静态方法获取 Class.forName(com.mysql.jdbc.Driver);Connection connection DriverManager.getConnection(URL);以上两种方式的区别是 DriverManager类来获取的Connection连接是无法重复利用的每次使用完以后释放资源 时通过connection.close()都是关闭物理连接DataSource提供连接池的支持。连接池在初始化时将创建一定数量的数据库连接这些连接 是可以复用的每次使用完数据库连接释放资源调用connection.close()都是将 Conncetion连接对象回收 3. Statement对象 Statement对象主要是将SQL语句发送到数据库中。JDBC API中主要提供了三种Statement对象 PreparedStatement 用于执行带或不带参数的SQL语句SQL语句会预编译再数据库系统执行速度快于Statement对象 Statement 用于执行不带参数的简单SQL语句 CallableStatement 用于执行数据库存储过程的调用 当然PreparedStatement是最常用的主要有executeQuery() 方法和executeUpdate()方法 executeQuery() 方法执行后返回单个结果集的通常用于select语句executeUpdate()方法返回值是一个整数指示受影响的行数通常用于update、insert、delete 语句 带有参数的SQL执行 public boolean add(Book book) {Connection connection null;PreparedStatement statement null;try {// 和数据库建立连接connection DBUtil.getConnection();// 拼装sqlString sql insert into book values (null,?,?,?,?,?);statement connection.prepareStatement(sql);statement.setString(1,book.getName());statement.setString(2,book.getAuthor());statement.setString(3,book.getType());statement.setBigDecimal(4,book.getPrice());statement.setString(5,未借出);// 执行sqlint ret statement.executeUpdate();if (ret 0) {return true;}} catch (SQLException throwables) {throwables.printStackTrace();} finally {DBUtil.close(connection,statement,null);}return false;}不带参数的SQL执行 ResultSet对象ResultSet是一个结果集 它代表符合SQL语句条件的所有行并且它通过一套getXXX方法提供 了对这些行中数据的访问 我们如果想要取得某一条记录就要使用ResultSet的next()方法 ,如果我们想要得到ResultSet里的所有记录就应该使用while循环 。 public ListBook getAll() {Connection connection null;PreparedStatement statement null;ResultSet resultSet null;ListBook bookList new ArrayList();try {// 和数据库建立连接connection DBUtil.getConnection();// 拼装sqlString sql select * from book;statement connection.prepareStatement(sql);// 执行sqlresultSet statement.executeQuery();while (resultSet.next()) {String bookName resultSet.getString(name);String auth resultSet.getString(author);String type resultSet.getString(type);BigDecimal price resultSet.getBigDecimal(price);String status resultSet.getString(status);Book book new Book(bookName,auth,type,price);book.setLoanOut((未借出.equals(status) ? false : true));bookList.add(book);}} catch (SQLException throwables) {throwables.printStackTrace();} finally {DBUtil.close(connection,statement,resultSet);}return bookList;}4. 释放资源 建立连接后使用完毕后一定要记得释放这个连接如果不一直不释放可能就会造成资源泄露的情况。 注意释放的顺序一定是先创建的后释放。 try {// 先创建的额后释放if (resultSet ! null) {resultSet.close();}if (statement ! null) {statement.close();}if (connection ! null) {connection.close();}} catch (SQLException throwables) {throwables.printStackTrace();}
http://www.w-s-a.com/news/610601/

相关文章:

  • 金华建站模板目前国内有哪些网站做家具回收
  • 个人做网站还是公众号赚钱好部门网站建设和维护
  • 系列图标设计网站推荐建商城网站
  • 中牟建设工程信息网站黑龙江 哈尔滨
  • 网站设计基本结构wap自助建论坛网站
  • 专业番禺网站建设爱做网站外国
  • 深圳罗湖网站设计公司价格制作网站的公司办什么营业执照
  • 长清网站建设价格群辉NAS搭建wordpress
  • 变更股东怎样在工商网站做公示网站建设和网站优化哪个更重要
  • 西安手机网站python网站开发效率
  • 深圳建站的公司羽毛球赛事2022直播
  • j2ee网站开发搜索推广的流程
  • 网站目录结构图虚拟主机如何安装WordPress
  • 信产部网站备案保定软件开发网站制作
  • 东莞网站设计定做东莞网站建设最牛
  • 网站开发的软件天猫的网站导航怎么做的
  • 做链接哪个网站好网站建设平台方案设计
  • 资质升级业绩备案在哪个网站做网站建设方案费用预算
  • 做网站找哪个平台好wordpress 3.9 性能
  • 大兴模版网站建设公司企业网站备案案例
  • h5建站是什么wordpress客户端 接口
  • 济南自适应网站建设制作软件下载
  • 望都网站建设抖音广告投放收费标准
  • 网站制作软件排行榜上海市网站建设公司58
  • 什么是网站风格中国工商网企业查询官网
  • 专业建设专题网站wordpress lnmp wamp
  • 环保网站 下载页网站
  • 开源小程序模板江门关键词优化排名
  • 网站开发 知乎房地产型网站建设
  • 买完域名网站怎么设计wordpress 纯代码