Java进阶(二十六)公司项目开发知识点回顾
公司项目开发知识点回顾
前言
“拿来主义”在某些时候并不是最佳选择,尤其是当自己遇到问题的时候,毫无头绪。
在一次实验过程中,需要实现数据库的CRUD操作。由于之前项目开发过程中,自己就曾进行过此操作。故选择“走捷径”,直接使用前面的操作。其实之前的数据库操作方法是别人封装好的,当时自己只是拿来就用而已。这次自己就按照前面的方法配置了相关参数,在写数据时,却出现了意想不到的情况,数据只能读不能写。曾经一度怀疑过是不是所建数据库有问题,设置为了“只读”属性。经过一番检查,并未发现此问题。重新建立数据库,还是出现了上面的情况。让自己很是汗颜!
苦思冥想,自己最终还是选择回到前面的项目中去看看问题到底出在哪里。经过阅读“立马送药”中数据库操作的有关代码,自己还是发现了一些端倪。MyDatabase.commit();这句意味深长。在操作之后添加这句后,居然就可以往数据库中写数据了。
数据库连接使用了基本的jdbc操作。
知识点
JDBC
尽管在实际开发过程中,我们一般使用ORM框架来代替传统的JDBC,例如Hibernate或者iBatis(或者是MyBatis),但JDBC是Java用来实现数据访问的基础,掌握它对于我们理解Java的数据操作流程很有帮助。
JDBC的全称是Java Database Connectivity。
JDBC对数据库进行操作的流程:
•连接数据库
•发送数据请求,即传统的CRUD指令
•返回操作结果集
JDBC中常用的对象包括:
•ConnectionManager
•Connection
•Statement
•CallableStatement
•PreparedStatement
•ResultSet
•SavePoint
数据库事务
谈到数据库开发,事务是一个不可回避的话题,JDBC默认情况下,是每一步都自动提交的,我们可以通过设置connection.setAutoCommit(false)的方式来强制关闭自动提交,然后通过connection.commit()和connection.rollback()来实现事务提交和回滚。
语法 commit()
示例 下面的代码利用commit方法提交当前事务。
Connection conn = …… //省略部分代码
conn.setAutoCommit(false); //先将事务设为手动提交
Statement st = conn.createStatement();
String sql = "INSERT INTO users VALUES ('xiaoli','123456')";
st.execute(sql);
conn.commit(); //提交事务
该方法用于使当前事务中的数据更改成为持久的模式,并释放Connection对象当前持有的所有数据库锁。此方法只有在手动事务的模式下才可以用。
自己有时间还是要恶补一下有关JDBC的知识点。
拓展
在“立马送药”项目中,客户端与服务端通信的大致思路自己还是清楚的。
客户端主要通过以下代码实现与服务端的通信。可见通信方式为http请求中的post方法,doupdate方式。有关http请求的知识,自己还需要进一步的学习。数据包传送方式为json形式。
/** * param1:http 请求地址 * param2:tx_code 交易代码 * param3:data 请求数据 * param4:succFun 成功处理方法 * param5:errFun 错误处理方法 */ appCallServer = function(http,tx_code,data,succFun,errFun) { var outdata={result:"9999",errtext:"未知错误"}; try{ var content = { method: 'POST', url: "/lmapp/DoUpdate?pkgtype=json", "data": data }; // 固定报文 content.data.version="1.0"; if (!content.data.uid) { if (localStorage.getItem('uid')) { content.data.uid = localStorage.getItem('uid'); } else { content.data.uid = "$tempuser"; } } // 设置前台sessionid content.data.fore_time = getNowFormatDate(); // 设置前台请求ID if(localStorage.sessionid){ content.data.sessionid = localStorage.sessionid; }else{ content.data.sessionid = ""; } content.data.tx_code = tx_code; showProgressBar(); //alert(JSON.stringify(content.data)); //采用链式调用 http(content) //成功处理函数 .success(function(data) { //参数data为服务端返回的数据对象 hideProgressBar(); if(data.result=="0000"){ console.log("typeof(succFun):" + typeof(succFun)); if(typeof(succFun)!="undefined"){ succFun(data); //方法回调 } }else{ if(typeof(errFun)!="undefined"){ if(data.result=="9998"){ if(confirm(data.errtext)){ // 若为管理端操作,则路由至管理端登陆界面 if (checkTrade(tx_code)) { window.location.href='index_sys.html'; }else{ // 否则路由至药店端登陆界面 window.location.href='index_shop.html'; } } } errFun(data); }else{ //alert(data.errtext); if(confirm(data.errtext) && data.result == "9998"){ // 若为管理端操作,则路由至管理端登陆界面 if (checkTrade(tx_code)) { window.location.href='index_sys.html'; }else{ // 否则路由至药店端登陆界面 window.location.href='index_shop.html'; } } } } }) //失败处理函数 .error(function(data){ hideProgressBar(); outdata.errtext="交易发送成功,但未能正常收到应答"; if(typeof(errFun) != "undefined"){ errFun(outdata); }else{ if(confirm(outdata.errtext) && data.result=="9998"){ // 若为管理端操作,则路由至管理端登陆界面 if (checkTrade(tx_code)) { window.location.href='index_sys.html'; }else{ // 否则路由至药店端登陆界面 window.location.href='index_shop.html'; } } } }); }catch(error){ hideProgressBar(); outdata.errtext = error.message; if(typeof(errFun) != "undefined"){ errFun(outdata); }else{ alert(outdata.errtext); //alert("调用交易"+tx_code+"失败4:"+outdata.errtext); } } };
反思
之所以会出现前面遇到的问题,归根到底,还是自己的“拿来主义”、“不求甚解”造成的。身为“程序猿”,遇到自己不明白的问题,还是需要静下心来把问题搞明白,把原理搞清楚,这样自己心里才有数。
参考文献
1.http://www.jb51.net/article/36866.htm
2.《疯狂JAVA讲义》李刚
美文美图
Java进阶(二十六)公司项目开发知识点回顾的更多相关文章
- AngularJS进阶(二十九)AngularJS项目开发技巧之localStorage存储
AngularJS项目开发技巧之localStorage存储 注: localStorage深度学习 绪 项目开发完毕,测试阶段发现后台管理端二维码生成有问题,问题在于localStora ...
- AngularJS进阶(三十六)AngularJS项目开发技巧之利用Service&Promise&Resolve解决图片预加载问题(后记)
AngularJS项目开发技巧之利用Service&Promise&Resolve解决图片预加载问题(后记) 前言 在"AngularJS项目开发技巧之图片预加载" ...
- Java进阶(二十五)Java连接mysql数据库(底层实现)
Java进阶(二十五)Java连接mysql数据库(底层实现) 前言 很长时间没有系统的使用java做项目了.现在需要使用java完成一个实验,其中涉及到java连接数据库.让自己来写,记忆中已无从搜 ...
- mysql进阶(二十六)MySQL 索引类型(初学者必看)
mysql进阶(二十六)MySQL 索引类型(初学者必看) 索引是快速搜索的关键.MySQL 索引的建立对于 MySQL 的高效运行是很重要的.下面介绍几种常见的 MySQL 索引类型. 在数 ...
- Java进阶(三十六)深入理解Java的接口和抽象类
Java进阶(三十六)深入理解Java的接口和抽象类 前言 对于面向对象编程来说,抽象是它的一大特征之一.在Java中,可以通过两种形式来体现OOP的抽象:接口和抽象类.这两者有太多相似的地方,又有太 ...
- 网站开发进阶(二十六)js刷新页面方法大全
js刷新页面方法大全 在项目开发过程中,需要实现刷新页面.经过学习,发现下面这条语句就可以轻松实现. location.reload(); // 刷新页面 有关刷新页面的其它方法,具体学习内容如下,有 ...
- Java进阶(二十九)Could not create the view: An unexpected exception was thrown
Could not create the view: An unexpected exception was thrown 在将web项目部署到tomcat时,控制台输出以下内容: 这个问题的出现是在 ...
- Java进阶专题(十六) 数据结构与算法的应用(上)
前言 学习算法,我们不需要死记硬背那些冗长复杂的背景知识.底层原理.指令语法--需要做的是领悟算法思想.理解算法对内存空间和性能的影响,以及开动脑筋去寻求解决问题的最佳方案.相比编程领域的其他技术 ...
- Java笔记(二十六)……IO流上 字节流与字符流
概述 IO流用来处理设备之间的数据传输 Java对数据的操作时通过流的方式 Java用于操作流的对象都在IO包中 流按操作的数据分为:字节流和字符流 流按流向不同分为:输入流和输出流 IO流常用基类 ...
随机推荐
- java.lang.NoSuchMethodException: org.apache.catalina.deploy.WebXml addServlet
解决此异常的方法是: 删除您添加在Referenced Libraries 下的catalina.jar包, 然后删除Webapp下的部署程序,重新部署后一切正常. ? --------------- ...
- Git-gitblit-Tortoisegit 搭建Windows Git本地服务器
1.Gitblit安装 1.1.Gitblit简介 Git在版本控制领域可谓是深受程序员喜爱.对于开源的项目,可以免费托管到GitHub上面,相当的方便.但是私有项目托管到GitHub会收取相当昂贵的 ...
- MySQL EXTRACT() 函数
定义和用法 EXTRACT() 函数用于返回日期/时间的单独部分,比如年.月.日.小时.分钟等等. 语法 EXTRACT(unit FROM date) date 参数是合法的日期表达式.unit 参 ...
- webpack4.x配置详解,多页面,多入口,多出口,新特性新坑!!
花了差不多一天多的时间,重新撸了一遍webpack4.x的常用配置. 基本上常用的配置都熟悉了一遍,总体上来讲,为了对parcel进行反击,webpack从4.x开始,正在朝着尽可能的简化配置文件的方 ...
- 初识Spring Boot框架(二)之DIY一个Spring Boot的自动配置
在上篇博客初识Spring Boot框架中我们初步见识了SpringBoot的方便之处,很多小伙伴可能也会好奇这个Spring Boot是怎么实现自动配置的,那么今天我就带小伙伴我们自己来实现一个简单 ...
- 安卓高级8 SurfaceView案例三 结合mediaplay播放视频
我们知道mediaplay无法直接播放视频所以我们结合Surface package qianfeng.com.mediaplayerdemo; import android.media.MediaP ...
- Mongo DB 初识
前言 2016年伊始,开始研究NoSql.看了couchdb,cloudant,cassandra,redis.却一直没有看过排行榜第一的mongo,实属不该.近期会花时间研究下mongo.本文是初识 ...
- linux找不到动态链接库 .so文件的解决方法(转自:http://www.cnblogs.com/xudong-bupt/p/3698294.html)
linux找不到动态链接库 .so文件的解决方法 如果使用自己手动生成的动态链接库.so文件,但是这个.so文件,没有加入库文件搜索路劲中,程序运行时可能会出现找不到动态链接库的情形. 可以通过ldd ...
- Dynamics CRM2016 Web API之通过实体的primary key查询记录(二)
继续接上篇,还是通过primary key来查询数据,本篇介绍两个我个人比较喜欢的查询方式,一个是查询单个字段,一个是查询lookup关联实体中的属性字段. 先来看如何查询单个字段,只需要在url的最 ...
- 详解EBS接口开发之应收款处理
参考实例参考:杜春阳 R12应收模块收款API研究 (一)应收款常用标准表简介 1.1 常用标准表 如下表中列出了与应收款处理相关的表和说明: 表名 说明 其他信息 AR_BATCHES_ALL ...