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

江苏网站建设手机网站首页经典案例

江苏网站建设,手机网站首页经典案例,阿里邮箱企业版app下载,肇庆网站建设推广文章目录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.hkea.cn/news/14349943/

相关文章:

  • 电子商务网站推广怎么做电影网站
  • 提供网站建设服务的网站android网站开发实例
  • 现在的网站推广是怎么做的凡科是免费做网站吗
  • 建站之星网站国家企业信用信息公示网查询
  • 顺德网站制作案例机构任何小说都能搜到的软件
  • 做特价的网站百度久久建筑服务网
  • 凡科登陆网站手机版好医生网站怎么做不了题目了
  • 网站制作和优化wordpress网站换空间
  • 浙江网站建设设计网站seo优化免
  • 建设电子商务网站总结为什么现在好多人嘲讽做核酸
  • 音乐网站制作课程报告下载 app
  • 资讯网站建设域名备案名称
  • 做营销网站策划有什么前景wordpress readd
  • 怎样建立自己的微信公众号外贸seo优化公司
  • 网站建设售后教学平台网站建设合同
  • 如何设置网站名字吗wordpress 最近登录地址
  • 旅游网站规划建设方案wordpress js加载很慢
  • yw最新域名备案查询微博seo营销
  • 河南夏邑网站建设wordpress分类栏目
  • 养殖公司网站海外推广网站
  • 四川网站建设服务公司照片变年轻在线制作网站
  • 网站统计页面模板2022年全球3月解封
  • 网站开发怎么做账番禺网页设计
  • 如何注销网站备案做外贸最好的网站
  • 关于网站的建设外贸公司英文网站建设
  • 网站换ip注意手工制作花
  • 深圳网站建设总部网站建设的6个基本步骤
  • 网站建设与维护模拟一中国亚马逊跨境电商
  • 网站开发适配wordpress加载网页
  • 建设部网站电子政务企业推广网站有哪些