Java开发规范记录

这篇具有很好参考价值的文章主要介绍了Java开发规范记录。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

  1. 不要使用 count(column)count(1)来替代 count(*)count(*)是 SQL92 定义的 标准统计行数的语法,跟数据库无关,跟 NULL 和非 NULL 无关。

注意:count(*)会统计值为 NULL 的行,而 count(列名)不会统计此列为 NULL 值的行。文章来源地址https://www.toymoban.com/news/detail-722208.html

  1. 当某一列的值全是 NULL 时,count(column)的返回结果为 0,但 sum(column)的返回结果为 NULL,因此使用 sum() 时需注意 NPE 问题
    • 正例:可以使用如下方式来避免 sumNPE 问题:
    • SELECT IF(ISNULL(SUM(g)), 0, SUM(g)) FROM table;
  2. 使用 ISNULL()来判断是否为 NULL 值。 说明:NULL 与任何值的直接比较都为 NULL。
    • NULL <> NULL 的返回结果是 NULL,而不是 false
    • NULL = NULL 的返回结果是 NULL,而不是 true
    • NULL <> 1 的返回结果是 NULL,而不是 true
  3. 如果有全球化需要,所有的字符存储与表示,均以 utf-8 编码,注意字符统计函数 的区别。
    • SELECT LENGTH("轻松工作"); 返回为 12
    • SELECT CHARACTER_LENGTH("轻松工作"); 返回为 4
    • 如果需要存储表情,那么选择 utf8mb4 来进行存储,注意它与 utf-8 编码的区别。
  4. TRUNCATE TABLEDELETE 速度快,且使用的系统和事务日志资源少,但 TRUNCATE 无事务且不触发 trigger,有可能造成事故,故不建议在开发代码中使用此语句。
    • 说明:TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同
  5. 页面搜索严禁左模糊或者全模糊,如果需要请走搜索引擎来解决。
    • 说明:索引文件具有 B-Tree 的最左前缀匹配特性,如果左边的值未确定,那么无法使用此索引
  6. 表达是与否概念的字段,必须使用 is_xxx 的方式命名,数据类型是 unsigned tinyint ( 1 表示是,0 表示否)
    • 说明:任何字段如果为非负数,必须是 unsigned
    • 正例:表达逻辑删除的字段名 is_deleted,1 表示删除,0 表示未删除。
  7. 表名、字段名必须使用小写字母或数字,禁止出现数字开头,禁止两个下划线中间只 出现数字。数据库字段名的修改代价很大,因为无法进行预发布,所以字段名称需要慎重考虑。
    • 说明:MySQLWindows 下不区分大小写,但在 Linux 下默认是区分大小写。因此,数据库名、表名、字段名,都不允许出现任何大写字母,避免节外生枝.
    • 正例:sys_admin,rdc_config,level3_name
    • 反例:SysAdmin,rdcConfig,level_3_name
  8. 单表行数超过 500 万行或者单表容量超过 2GB,才推荐进行分库分表。
    • 说明:如果预计三年后的数据量根本达不到这个级别,请不要在创建表时就分库分表
  9. 合适的字符存储长度,不但节约数据库表空间、节约索引存储,更重要的是提升检 索速度。
  10. 表单、AJAX 提交必须执行 CSRF 安全过滤。
    • 说明:CSRF(Cross-site request forgery)跨站请求伪造是一类常见编程漏洞。对于存在 CSRF 漏洞的应用/网站,攻击者可以事先构造好 URL,只要受害者用户一访问,后台便在用户 不知情情况下对数据库中用户参数进行相应修改。
  11. 泛型通配符<? extends T>来接收返回的数据,此写法的泛型集合不能使用 add() 方法,而<? super T>不能使用 get() 方法,做为接口调用赋值时易出错。
  • 说明:扩展说一下 PECS(Producer Extends Consumer Super)原则:
  • 第一、频繁往外读取内 容的,适合用<? extends T>
  • 第二、经常往里插入的,适合用<? super T>
  1. 使用工具类 Arrays.asList()把数组转换成集合时,不能使用其修改集合相关的方 法,它的 add/remove/clear 方法会抛出 UnsupportedOperationException 异常。
  • 说明:asList 的返回对象是一个 Arrays 内部类,并没有实现集合的修改方法。Arrays.asList 体现的是适配器模式,只是转换接口,后台的数据仍是数组。

到了这里,关于Java开发规范记录的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 阿里巴巴_java开发规范手册详解

    反例: _name, $name, __name 说明:正确的英文拼写和语法可以让阅读者易于理解,避免歧义。注意,纯拼音命名方式更要避免采用。 正例:renminbi / alibaba / taobao / youku / hangzhou 等国际通用的名称,可视同英文。 反例:DaZhePromotion [打折] / getPingfenByName() [评分] / int 某变量 = 3 正例:

    2024年02月06日
    浏览(43)
  • Java开发工作问题整理与记录

        首先 类加@Component注解,使当前类成为bean     然后 定义statis类成员     然后 创建 init()方法,用@PostConstruct注解修饰     最后init()方法中,把需要加载的类复制给static类 导入commons-lang3的jar包 dependency groupIdorg.apache.commons/groupId artifactIdcommons-lang3/artifactId version3.8.1/version

    2024年02月11日
    浏览(42)
  • MySQL Ruler mysql 日常开发规范

    MySQL View MySQL truncate table 与 delete 清空表的区别和坑 MySQL Ruler mysql 日常开发规范 MySQL datetime timestamp 以及如何自动更新,如何实现范围查询 MySQL 06 mysql 如何实现类似 oracle 的 merge into MySQL 05 MySQL入门教程(MySQL tutorial book) MySQL 04- EMOJI 表情与 UTF8MB4 的故事 MySQL Expression 1 of ORDE

    2024年04月10日
    浏览(37)
  • MySQL 开发规范

    优质博文:IT-BLOG-CN 原则: SQL 开发规范制定是基于良好的编码习惯和可读性; 目的: 消除冗余,数据简约,提高效率,提高安全; 【1】禁止在线上生产环境做数据库压力测试,全链路压测可以支持,但是一定不要在业务高峰期搞压力测试。 【2】禁止在数据库中明文存储密

    2024年04月10日
    浏览(37)
  • JAVA开发环境的搭建与配置(Windows 11)详细记录

            搜索“Oracle JDK8”,选择Oracle官网进入         根据自己设备的操作系统选择对应版本         点击下载弹出Oracle登录界面,无Oracle账号注册登录,有账号登录即可下载         查看电脑操作系统的方式:         运行下载好的JDK安装文件      

    2024年02月07日
    浏览(48)
  • [报错]记录IDEA远程开发报错:java: Cannot run program.....

    IDEA在进行远程开发的时候报错,内容如下: 表现如下: 在IDEA设置 Build,Execution,Deployment -- Compiler 中的 Shared build process VM options 加入如下内容: 如下图所示: 项目当前使用的 JDK 版本过低,Jetbrains Gateway 的 IDE 默认构建启动过程中,使用到了 JDK 包中的 jspawnhelper 可执行文件。

    2024年02月04日
    浏览(48)
  • Java编程规范(代码规范)--精选

    说明 本文介绍精选的Java编程规范(代码规范)。遵守这些规范,代码的bug数将会大幅减少,代码可维护性、可读性、扩展性会大幅上升。(本文持续更新) 为什么要有编程规范? 编程规范有如下作用: 提高代码可读性、维护性、扩展性 提高开发速度、减少bug 有助于留住人

    2024年02月05日
    浏览(36)
  • java判断当前日期时间大于指定日期时间 记录日常开发中的小搜索

    可以使用Java中的 Calendar 类来获取当前时间和所需的指定时间并将它们进行比较。这是一个示例代码: 在上面的示例中,我们首先使用 Calendar.getInstance() 方法获取当前时间和指定时间的 Calendar 对象。然后,我们将指定时间设置为2022年1月1日下午3:30,并使用 after() 方法比较当

    2024年02月07日
    浏览(52)
  • Java开发 - MySQL主从复制初体验

    前面已经学到了很多知识,大部分也都是偏向于应用方面,在应用实战这条路上,博主一直觉得只有实战才是学习中最快的方式。今天带来主从复制给大家,在刚刚开始动手写的时候,才想到似乎忽略了一些重要的东西,不过还好,既然想到了,就会在本文中体现出来,争取

    2023年04月13日
    浏览(30)
  • 基于java,jsp,mysql开发蛋糕商城

    一、请简述你设计的商品列表功能。 1. 该功能创建了几张表,每个表的功能是什么,并介绍下主要字段和作用? recommend 表对应商品自动滑动的,表里包含自身的id和蛋糕goods的id,蛋糕所属类别的id; type 表对应蛋糕所属类别的id和名称; goods 表对应所有商品的内容,包含商

    2024年02月04日
    浏览(33)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包