黑马程序员技术交流社区

标题: [云计算之大数据] Java面试题之数据库优化方面的经验 [打印本页]

作者: 播妞    时间: 2017-8-17 15:45
标题: [云计算之大数据] Java面试题之数据库优化方面的经验
目前部分开发人员面对一个很尴尬的境地:技术到了,但是语言表达能力没到!很多东西在实践操作中能够手到擒来,但是面试过程中却处处卡壳!很严重~
本帖隐藏的内容  
用PreparedStatement 一般来说比Statement性能高:一个sql 发给服务器去执行,涉及步骤:语法检查、语义分析,编译,缓存
 
  • “inert into user values(1,1,1)”---二进制
  • “inert into user values(2,2,2)”---二进制
  • “inert into user values(?,?,?)”---二进制

[color=rgb(51, 51, 51) !important]复制代码


  有外键约束会影响插入和删除性能,如果程序能够保证数据的完整性,那在设计数据库时就去掉外键。(比喻:就好比免检产品,就是为了提高效率,充分相信产品的制造商)

  (对于hibernate来说,就应该有一个变化:empleyee->Deptment对象,现在设计时就成了employeeàdeptid)

  看mysql帮助文档子查询章节的最后部分,例如,根据扫描的原理,下面的子查询语句要比第二条关联查询的效率高:

  1. select e.name,e.salary where e.managerid=(select id from employee where name='itcast');

  2. select e.name,e.salary,m.name,m.salary from employees e,employees m where

  e.managerid = m.id and m.name='itcast';

  表中允许适当冗余,譬如,主题帖的回复数量和最后回复时间等

  将姓名和密码单独从用户表中独立出来。这可以是非常好的一对一的案例哟!

  sql语句全部大写,特别是列名和表名都大写。特别是sql命令的缓存功能,更加需要统一大小写,sql语句à发给oracle服务器à语法检查和编译成为内部指令à缓存和执行指令。根据缓存的特点,不要拼凑条件,而是用?和PreparedStatment

  还有索引对查询性能的改进也是值得关注的。

  备注:下面是关于性能的讨论举例

  4航班 3个城市


[color=rgb(51, 51, 51) !important]复制代码








欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2