java 程序升级之mysql Invalid column name 和 思考
对于一般的猿媛来说,升级原来的程序绝对是一件痛苦的事情,而更痛苦的是:除了一个 projcet ,其他什么都没有,就连数据库字段的描述都没有,更不用说是设计文档,数据库设计文档,需求文档等等的。 最近大boss让对一个6年前的项目进行升级,不仅要把程序升
对于一般的猿媛来说,升级原来的程序绝对是一件痛苦的事情,而更痛苦的是:除了一个 projcet ,其他什么都没有,就连数据库字段的描述都没有,更不用说是设计文档,数据库设计文档,需求文档等等的。
最近大boss让对一个6年前的项目进行升级,不仅要把程序升级,界面更换,而且还要从sql server 数据库迁移到mysql 上来,可是当拿到项目的那一刻,真是头大。因为除了项目本身,其他什么都没有,而且项目开发人员早已经离职,任何文档都没有,就连各个表的字段描述都没有,只能凭借程序猿的第六感来猜测各个字段是什么意思... ...
废话不说了,直接说问题,在修改到某一个查询时候,报错:java.sql.SQLException: Invalid column name 。第一眼一看,我靠这以前都能好好运行的项目,没有做任何的改动,怎么能这样呐,有点晕了,语句如下:
SELECT distinct s.id AS id, s.name AS name, s.url AS url,s.siteMap as siteMap,s.isFlag as isFlag, s.stat AS stat, t.id as tmpl_id, t.description as tmDescription FROM bbs_site1 s LEFT JOIN bbs_tmpl1 t ON s.tmpl_id = t.id where 1=1
自从棱角之后,谷爸算是彻底赶出了神州大地,哎,咋说呐,猿媛们不还得生活,不还得赚money吗,好歹也要想办法找到谷爸吧,不是难事,可难 的是:怎么着也没有找到我想要的答案,为啥这个语句就会报错?
本猿百思不得其解,尝试使用索引获取,不行,使用sql的resultset 获取字符串,也不OK ,气死我了,
好在天无绝人之路,哥哥终于找到原因了,因为程序底层使用的是rowset (继承之resultset),对于红色部分的id颇有不满,不知道取那个,它不会按照as 后边的别名来取值,之后按照id来取值,真的是很不知所以,不过,找到问题之后,解决方案也就来了。第一个使用id (rs.getInt("id")),第二个id就使用索引来取值(rs.getInt(index)),这样一切都OK 了。真的是不知道原来还有这么大的一个坑呀,受教了哦,故记录在此。
改完之后,一想,真的是觉得以前的思路,方式欠妥,也算是给自己提点意见:
1. 程序设计时候,字段的意思一定要给出描述,即便是不描述,也要在文档中做出明确的说明。
2,每个字段符合通俗,易用原则,一看字段就知道是什么意思,比如name ,人有name,物品有name ,如果都定位name,就不好了,而应该界定好:per_name, pro_name 这样是否会好多了呐?
3.文档说明,没有文档说明,让被人改动codes,真的是很犯晕。
4. 注释,这个也是很头痛的事情,在本项目中,他没有给注释,我卡卡卡卡,一个函数写几十行,而且还是乱换行,哥真的是脾气好,不然真得发怒了。
5,可扩展性,着点很多时候都没有考虑到,尤其是在程序升级或者是添加新功能的时候,所以这个应该是一个共性,值得好好思索。
6.公共的,通用的方法,类,函数等的一定要提出来,千万不要遇到一次写一次,太麻烦了。
以上这六点算是本猿提出的小小建议,确实值得思考、、、 、、、
知易行难,都知道这些,再次说出来,无非是引起重视,可是究竟自己做的怎么样,那只有自己之道了。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

PHP是一种广泛应用于服务器端的脚本语言,特别适合web开发。1.PHP可以嵌入HTML,处理HTTP请求和响应,支持多种数据库。2.PHP用于生成动态网页内容,处理表单数据,访问数据库等,具有强大的社区支持和开源资源。3.PHP是解释型语言,执行过程包括词法分析、语法分析、编译和执行。4.PHP可以与MySQL结合用于用户注册系统等高级应用。5.调试PHP时,可使用error_reporting()和var_dump()等函数。6.优化PHP代码可通过缓存机制、优化数据库查询和使用内置函数。7

MySQL是一种开源的关系型数据库管理系统,主要用于快速、可靠地存储和检索数据。其工作原理包括客户端请求、查询解析、执行查询和返回结果。使用示例包括创建表、插入和查询数据,以及高级功能如JOIN操作。常见错误涉及SQL语法、数据类型和权限问题,优化建议包括使用索引、优化查询和分表分区。

PHP适合web开发,特别是在快速开发和处理动态内容方面表现出色,但不擅长数据科学和企业级应用。与Python相比,PHP在web开发中更具优势,但在数据科学领域不如Python;与Java相比,PHP在企业级应用中表现较差,但在web开发中更灵活;与JavaScript相比,PHP在后端开发中更简洁,但在前端开发中不如JavaScript。

选择MySQL的原因是其性能、可靠性、易用性和社区支持。1.MySQL提供高效的数据存储和检索功能,支持多种数据类型和高级查询操作。2.采用客户端-服务器架构和多种存储引擎,支持事务和查询优化。3.易于使用,支持多种操作系统和编程语言。4.拥有强大的社区支持,提供丰富的资源和解决方案。

MySQL在数据库和编程中的地位非常重要,它是一个开源的关系型数据库管理系统,广泛应用于各种应用场景。1)MySQL提供高效的数据存储、组织和检索功能,支持Web、移动和企业级系统。2)它使用客户端-服务器架构,支持多种存储引擎和索引优化。3)基本用法包括创建表和插入数据,高级用法涉及多表JOIN和复杂查询。4)常见问题如SQL语法错误和性能问题可以通过EXPLAIN命令和慢查询日志调试。5)性能优化方法包括合理使用索引、优化查询和使用缓存,最佳实践包括使用事务和PreparedStatemen

PHP和Python各有优势,适合不同场景。1.PHP适用于web开发,提供内置web服务器和丰富函数库。2.Python适合数据科学和机器学习,语法简洁且有强大标准库。选择时应根据项目需求决定。

Apache 连接数据库需要以下步骤:安装数据库驱动程序。配置 web.xml 文件以创建连接池。创建 JDBC 数据源,指定连接设置。从 Java 代码中使用 JDBC API 访问数据库,包括获取连接、创建语句、绑定参数、执行查询或更新以及处理结果。

PHP成为许多网站首选技术栈的原因包括其易用性、强大社区支持和广泛应用。1)易于学习和使用,适合初学者。2)拥有庞大的开发者社区,资源丰富。3)广泛应用于WordPress、Drupal等平台。4)与Web服务器紧密集成,简化开发部署。
