由错误ora-911引发的思考

    最近做的项目使用的是oracle数据库,前天在调用自己的sql语句时,控制台出现了题目所示的错误(其实就是sql语句结束多了分号)。

    对于这个错误,用过oralce的人都会知道这个错误,我想每一个人在刚开始使用oralce的时候,都经历过这个错误(当然,某些天才除外由错误ora-911引发的思考)。其实,这是个习惯问题,说的大一点,就是座位一个程序员做工作的时候,有没有一套编码规范。看下面的demo:

StringBuffer sql = new StringBuffer(20);
sql.append(" select * from t")
    .append("where id = ").append(id);

发现上面的代码有问题吗?是的,上面的代码没问题,但是程序在运行的时候就会报错,准确的说的sql语句错误。这就是平时编码没有规范造成的。正确的写法是在次使用append添加时,字符串前面和后面都留一个空格。

    总结:要写出既正确有优雅的代码,要提高自己的编码水平,都的按照某套规范来做。简单点说就是要形成自己的编码风格。(好吧,好久没写文章了,感觉由错误ora-911引发的思考,就这样吧,欢迎吐槽!)