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

江苏网站建设wordpress支付免签约插件

江苏网站建设,wordpress支付免签约插件,网络营销的概念与特点,济南企业建设网站文章目录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.ho-use.cn/article/10814378.html

相关文章:

  • 制作网站制作公司直播平台如何搭建
  • 申请网站建设经费同城分类信息网站
  • 涉县专业做网站塘厦在哪里
  • 网站域名授权怎么做怎样做的英文网站
  • 花卉网站建设规划书做网站买那种服务器好
  • 怎样搭建网站怎么弄微信小程序卖东西
  • 找合伙做网站的做电影电视剧网站推广
  • 重庆网站建设模板服务邢台网站制作的地方
  • 湖南省建设银行网站6广州美容网站建设
  • 跨国网站重庆永川网站建设公司
  • 什么是企业营销型网站?怎么学室内装修设计软件
  • 滨州网站建设 远洋科技网页设计模板图片html
  • 广东建设官方网站wordpress编辑文章
  • wordpress改网站地址电子商务网站推广策略论文
  • 防城港网站设计楼市最新消息:2023年房价走势
  • 手机版网站做一下多少钱wordpress 视频网站
  • 自贡建设投资有限公司网站国家企业网官网查询
  • 网站后台分模块有个人做网站的吗
  • 专业做模具钢的网站电商企业营销推广
  • 石家庄百度推广家庄网站建设企业网站制作正规公司
  • 网站开发项目报价单个人中心页面设计html
  • 信息化建设网站建设网站教程
  • 中型网站 收益如何做直接打开网站的二维码
  • 手机网站登陆模板常用网站字体
  • 公建设计网站宁波seo公司哪家好
  • 中国建设银行遵义市分行网站推广方法
  • c2c网站的功能seo赚钱方法大揭秘
  • 小型网站开发成本哈尔滨电子政务网站建设
  • 关于com的网站小说网站自动采集
  • 网站建设在哪里可以筹集素材慈溪专业做网站公司