原先都是做数据开发的,换了公司之后,做回了Java后台开发。从svn到git,终究会有一个趟坑的经历。
git具体的命令技能就不说了,会开新的帖子。下面就说下这次小白经历吧。
项目背景:从调用oracle 提供的webService 转到调用 接口服务(接口直接调用oracle的函数、存储过程等)。由此可见,项目可简单,现阶段就提供一个接口就可以。
代码很简单,趟坑很重要!
1.mybatis 调用存储过程
平常用mybatis,就是搞搞select,delete,update,insert等。没有调用过存储过程。
那么mybatis的mapper里怎么调用存储过程等呢?
//这个带返回的
//也可以,out在后面
{call queryTeacher(#{fid,mode=IN,jdbcType=INTEGER},#{type,mode=IN,jdbcType=VARCHAR},#{name,mode=OUT,jdbcType=VARCHAR})}
然后在对应的Service,调用相应的方法,执行存储过程后,可以获取到相应的结果。思路是一致的
从select可以看出,主要声明 statementType="CALLABLE"
,在代码体中 call 某某名称
参考:http://blog.csdn.net/walkcode/article/details/9318039
2.json转换
原本已经是返回的json格式的东东,而为了符合接口规范,需要参数重新组织,返回code,message,data.
针对数据库返回的格式,建立对应的result实体进行解析,填充到接口定义的返回字段中。
主要用的(fastjson):
- JSON.parseObject():解析成对象
- 根据需要转换成相应的状态码
- 分字段,填充到新的返回中
3.上传git
之前知道项目是上传到git,然后自动部署的。没想到自己还是躺了。
运维搞得自动部署会去读取一级目录下的pom.xml,而我的pom.xml在二级目录下。(部署打印日志,找不到pom.xml)
坑,又重新把项目搭建了。
4.各种报错
DruidDataSource配置
错误描述:
(1)部署后,在配置文件中DruidDataSource下配置的变量不能读取。(未解决,怀疑是运维的坑)
直接把配置换成了死代码。
(2)catalina.sh 自动部署的坑:
启动参数的问题
JAVA_OPTS="$JAVA_OPTS -Duser.language=en -Duser.country=US"
(3)
Cannot resolve reference to bean 'sqlSessionFactory' while setting bean property 'sqlSessionFactory';
nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [spring/applicationContext-dao.xml]:
Cannot resolve reference to bean 'dataSource' while setting bean property 'dataSource'; nested exception is org.springframework.beans.factory.BeanCreationException:
Error creating bean with name 'dataSource' defined in class path resource [spring/applicationContext-datasource.xml]: Invocation of init method failed; nested exception is java.sql.SQLException:
The Network Adapter could not establish the connection
主要看最后这句话The Network Adapter could not establish the connection
,因为datasourse配置的db ip 是一个域名,so 没有被解析。
因此找到/etc/hosts文件加上映射即可。
Hosts是一个没有扩展名的系统文件,可以用记事本等工具打开,其作用就是将一些常用的网址域名与其对应的IP地址建立一个关联“数据库”,当用户在浏览器中输入一个需要登录的网址时,系统会首先自动从Hosts文件中寻找对应的IP地址,一旦找到,系统会立即打开对应网页,如果没有找到,则系统会再将网址提交DNS域名解析服务器进行IP地址的解析。