今天突然想多说两句,刚刚在知乎看到一个人说,在当今世界,没有技术型驱动的公司,全都是业务型。即便是表面上看似技术型公司,其本质还是为了服务业务。这段话推翻了我以前关于编程的所有看法,觉得颇有道理。下面也来说说web应用的本质。

1.什么是web应用?就是用户通过浏览器,访问服务器,进行一系列操作,保存数据,修改数据的应用。其核心,就是对数据的操作。不管什么框架、什么UI,其目的还是对数据进行操作。所以,对于数据库的操作,是web应用的重中之重。而jdbc又是数据库操作中最为重要的基石。

2.jdbc的基本操作,看如下代码及注释:

首先加载数据库驱动程序,然后用驱动管理器获取数据库连接

private static final String URL="jdbc:mysql://127.0.0.1:3306/xiao";
private static final String NAME="root";
private static final String PASSWORD="13720994358lhp";
static Connection connection=null;
static {
try {
//1.加载数据库驱动程序
Class.forName("com.mysql.jdbc.Driver"); //2.获取数据库连接
connection = DriverManager.getConnection(URL, NAME, PASSWORD);
}catch (ClassNotFoundException e){
System.err.println("未找到数据库加载程序");
}catch (SQLException e){
System.err.println("数据库错误" +e);
}
}

然后用获取到的连接connection获取一个数据库操作对象,该对象可以执行sql

    Statement statement=connection.createStatement();
statement.execute("sql语句");

还有另一种执行sql的对象,叫做预处理。什么意思呢?就是先把sql的模板放进去,然后执行的时候再把具体的参数一一带入,这样做可以减少连接数据库的次数。代码如下:

PreparedStatement preparedStatement=connection.prepareStatement(sql);
preparedStatement.setString(1,goddess.getUserName());
preparedStatement.setInt(2,goddess.getSex());
preparedStatement.setInt(3,goddess.getAge());
preparedStatement.setDate(4,new Date(goddess.getBirthday().getTime()));
preparedStatement.setString(5,goddess.getEmail());
preparedStatement.setString(6,goddess.getMobile());
preparedStatement.setString(7,goddess.getCreateUser());
preparedStatement.setString(8,goddess.getUpdateUser());
preparedStatement.setInt(9,goddess.getIsdel());

增删改查基本上操作都一样,区别在于,增加删除修改,最后statement调用执行sql的方法有所不同查询是preparedStatement.executeQuery(),修改是preparedStatement.executeUpdate()等等

3.jdbc调用无参存储过程。存储过程怎么写在此不做说明,只说java代码如何调用存储过程。

        //1.获得连接
Connection connection= DBUtil.getConnection(); //2.要获得执行存储过程的对象
CallableStatement callableStatement=connection.prepareCall("call sp_select_nofilter()"); //3.执行存储过程
callableStatement.execute(); //4.获得结果集对象
ResultSet rs=callableStatement.getResultSet();

4.JDBC调用带入参的存储过程,相比于不带参数就多了一点变化:先用?代替sql中的参数,再在后面设置参数的具体值。

        Connection connection=DBUtil.getConnection();
CallableStatement callableStatement=connection.prepareCall("call sp_filter(?)");
callableStatement.setString("1","");
callableStatement.execute();
ResultSet resultSet=callableStatement.getResultSet();

5.JDBC调用带有出参的存储过程,相比于带有入参的又多了一点变化,请看代码:

    Connection connection=DBUtil.getConnection();
CallableStatement callableStatement=connection.prepareCall("call sp_select_count(?)"); //与入参存储过程不同的是,出参不能提前设置,而需要注册,第一个参数是索引,第二个参数是数据库字段类型
callableStatement.registerOutParameter(1, Types.INTEGER);
callableStatement.execute();
int count=callableStatement.getInt("1");
return count;

6.JDBC的事务操作。具体什么是事务操作,在这里不做详细说明,网上百度一大把,很详细。简而言之就是一句话,要一次完成一系列对数据库的操作,如果中间某个环节出现问题,则需要将所有操作回退。举个最简单的例子:银行转账,先在A的账户扣一百块,再给B的账户加一百块,这样完成了从A到B的转账,假如在A已经扣钱而B没有加钱的情况下,程序突然出错了,那怎么办?A的钱已经扣了,而B的钱还没加,钱去哪了??这就是事务操作的重要性。请看代码:

    public static business(){
Connection connection=DBUtil.getConnection(); //本来数据库默认自动提交数据,现在关掉
connection.setAutoCommit(false);
try{
//进行数据库操作之后,手动提交数据,在提交完成后才生效
connection.commit();
}catch (Exception e){
//当陈程序发生异常,首先要把所有对数据库的操作回退
connection.rollback();
}
}

7.数据库连接池。上文讲到,当程序需要对数据库进行操作的时候,第一步请求连接数据库,第二步进行数据库操作,第三步关闭数据库连接。加入一个项目很大,每一次请求都会走这三步,将非常消耗资源。不如创造一个池子,专门管理一些常态连接,当需要的时候从池子里拿,不需要的时候再放回去。这样可以节约资源。比较常用的有dbcp连接池和c3p0连接池,使用方法如下:

##首先设置配置文件,将连接数据库需要的相关参数放进来统一管理
c3p0.driverClass=com.mysql.jdbc.Driver
c3p0.jdbcURL=jdbc\:mysql\://127.0.0.1\:3306/xiao
c3p0.user=root
c3p0.password=13720994358lhp

上面是一个properties文件,里面有一些连接数据库需要的常量。

然后当程序启动的时候会自动加载这个配置文件,获得数据库连接,代码如下:

private static ComboPooledDataSource dataSource=new ComboPooledDataSource();
public static Connection getConnection()throws SQLException {
return dataSource.getConnection();
}

JDBC编程,从入门到精通的更多相关文章

  1. 《Linux.Shell编程从入门到精通》读书笔记

    第一章 第一个Shell程序 以 #!解析器名称 开头,表示选择哪个解释器解释shell脚本 source命令 export命令 env命令 unset命令 第二章 shell编程基础 函数传递 标准 ...

  2. Java并发编程从入门到精通 张振华.Jack --我的书

    [当当.京东.天猫.亚马逊.新华书店等均有销售] 目 录 第一部分:线程并发基础 第1章 概念部分   1 1.1 CPU核心数.线程数 (主流cpu.线程数的大体情况说一下) 1 1.2 CPU时间 ...

  3. Java网络编程从入门到精通(27):关闭服务端连接

    在客户端和服务端的数据交互完成后,一般需要关闭网络连接.对于服务端来说,需要关闭Socket和ServerSocket. 在关闭Socket后,客户端并不会马上感知自已的Socket已经关闭,也就是说 ...

  4. (升级版)Spark从入门到精通(Scala编程、案例实战、高级特性、Spark内核源码剖析、Hadoop高端)

    本课程主要讲解目前大数据领域最热门.最火爆.最有前景的技术——Spark.在本课程中,会从浅入深,基于大量案例实战,深度剖析和讲解Spark,并且会包含完全从企业真实复杂业务需求中抽取出的案例实战.课 ...

  5. 2015某编程网易语言vip课堂全套教程 包含post,hook入门到精通等

    2015某编程网易语言vip课堂全套教程 包含post,hook入门到精通等  官方论坛弄来的  如果在官方下载需要权限的  挺不错教程 想学习易语言入门到精通 post hook  js改写的可以看 ...

  6. GPU 编程入门到精通(五)之 GPU 程序优化进阶

    博主因为工作其中的须要,開始学习 GPU 上面的编程,主要涉及到的是基于 GPU 的深度学习方面的知识.鉴于之前没有接触过 GPU 编程.因此在这里特地学习一下 GPU 上面的编程. 有志同道合的小伙 ...

  7. GPU 编程入门到精通(四)之 GPU 程序优化

    博主因为工作其中的须要,開始学习 GPU 上面的编程,主要涉及到的是基于 GPU 的深度学习方面的知识,鉴于之前没有接触过 GPU 编程.因此在这里特地学习一下 GPU 上面的编程.有志同道合的小伙伴 ...

  8. 微博,and java 多线程编程 入门到精通 将cpu 的那个 张振华

    http://down.51cto.com/data/2263476  java 多线程编程 入门到精通  将cpu 的那个 张振华 多个用户可以同时用一个 vhost,但是vhost之间是隔离的. ...

  9. GPU 编程入门到精通(三)之 第一个 GPU 程序

    博主因为工作其中的须要.開始学习 GPU 上面的编程,主要涉及到的是基于 GPU 的深度学习方面的知识,鉴于之前没有接触过 GPU 编程,因此在这里特地学习一下 GPU 上面的编程.有志同道合的小伙伴 ...

  10. 1Mybatis入门--1.1单独使用jdbc编程问题总结

    1.1.1 jdbc程序 Public static void main(String[] args) { Connection connection = null; PreparedStatemen ...

随机推荐

  1. 微信域名检测的C#实现

     背景:最近公司的公众号域名被封了,原因是公司网站被黑后上传了一个不符合微信规范的网页.所以...就进入了微信域名解封的流程. 百度微信域名解封发现很多微信域名检测的网站,还有Api:但是本人做微信公 ...

  2. UOJ#374. 【ZJOI2018】历史 贪心,LCT

    原文链接https://www.cnblogs.com/zhouzhendong/p/UOJ374.html 题解 想出正解有点小激动. 不过因为傻逼错误调到自闭.不如贺题 首先我们考虑如何 $O(n ...

  3. mybatis常用类起别名

    在mybatis的配置文件中添加如下配置 <settings> <setting name="cacheEnabled" value="true&quo ...

  4. 20175305张天钰《java程序设计》第五周学习总结

    <java程序设计>第五周学习总结 接口与实现 知识小点: (1)用Arrays.sort方法对所有实现Comparable接口的对象进行排序 (2)接口体现了has-a关系,继承体现了i ...

  5. Paxos协议超级详细解释+简单实例

    转载自:  https://blog.csdn.net/cnh294141800/article/details/53768464 Paxos协议超级详细解释+简单实例   Basic-Paxos算法 ...

  6. ImCash:韩国最大交易所遭遇至暗时刻:2018年亏损1.8亿美元

    Bithumb上个月遭到黑客攻击,随后要求用户小心存款,该公司报告称损失1.8亿美元(合2050亿韩元). 据<韩国时报>(Korea Times)报道:受到熊市影响,数字货币交易所实际交 ...

  7. RSP小组——团队冲刺博客一——(领航)

    RSP小组--团队冲刺博客一--领航 冲刺日期:2018年12月10日 团队目标 经过团队讨论,我们最新确定的α版本所需实现内容如下: 1.实现游戏代码的实现 2.在Android Studio上实现 ...

  8. W3C的标准到底是啥?

    1.图片的alt="" 属性必须每张图片都加上,而且对齐属性用CSS来定义.不加不能通过XHTML 1.0的验证. 2.每个文档必须加上DTD声明. a) !DOCTYPE htm ...

  9. VB洗牌算法产生随机数组

    算法图示: 运行效果: 详细代码: Option Explicit '洗16张牌(0-15),方便用十六进制显示 Dim Card() As Long Private Sub 洗牌() Dim i&a ...

  10. xlrd模块

    import xlrdbook = xlrd.open_workbook('app_student.xls')sheet = book.sheet_by_index(0)# sheet2 = book ...