首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏张善友的专栏

    SQL Server 在RAID 10 vs. RAID 5性能

    RAID 5 Performance 上给出了使用SQLIO.EXE 产生8KB 随机读和写的一个性能数据图,相差接近一倍的性能差距。 1) 读操作方面的性能差异 RAID10可供读取有效数据的磁盘个数为4,RAID5可供读取有效数据的磁盘个数也为4个(校验信息分布在所有的盘上),所以两者在读方面的性能应该是基本一致的。 3) 离散写方面的性能差异 例如SQL Server数据库每次写一个数据块的数据,如4KB或8KB,由于每次写入的量不是很大,而且写入的次数非常频繁,因此联机日志看起来会像是连续写。 RAID 5 Performance SQL Server之RAID简介 SQL Server IO 子系统浅究 II SQLIO测试 SAN 服务器IO测试利器--SQLIO Raid5 Raid10 性能测试 SQL Server Performace on Solid State Drives (SSD)

    2.8K100发布于 2018-01-29
  • 来自专栏程序员奇点

    SQL 性能优化

    ,在FROM 子句中包含多个表的情况下,你必须选择记录条数最小的表作为基础表, 如果有3个以上的表连接查,选择交叉表(Insertection table)作为基础表,交叉表指的是被其他表锁引用的表 性能优化 SQL语句中IN包含的值不应过多 MySQL对于IN做了相应的优化,即将IN中的常量全部存储在一个数组里面,而且这个数组是排好序的。但是如果数值较多,产生的消耗也是比较大的。 等价于 select * from 表A where exists(select * from 表B where 表B.id=表A.id) 区分in和exists主要是造成了驱动顺序的改变(这是性能变化的关键 如何高效的写出一个替代not exists的sql语句?

    1.1K40发布于 2019-08-30
  • 来自专栏用户8907256的专栏

    SQL性能优化以及性能测试

    SQL性能优化以及性能测试 博主介绍 笛卡尔连接 分页limit的sql优化的几种方法 笛卡尔连接 例1: 没有携带on的条件字句,此条slq查询的结构集等价于,a表包含的条数*b表包含的乘积: select b on a.id=b.id; 分页limit的sql优化的几种方法 规则;表包含的数据较少的数据量,作为驱动表(小表驱动大表,一般mysql的优化器会做出相应的优化的,但是为了防止一些抽风现象可以用 information_schema.TABLES where TABLE_SCHEMA='数据库名称' and TABLE_NAME ='表的名称'; 实例5: 通过explain 查看sql性能如果Extra的值为null时,说明是可以通过索引避免排序的.如果Extra的值是Using filesort 是不可以进行索引排序的 select * from table first_name,emp_no; 索引失效的场景: 1: join 字段的类型不一致 2: 在=号的左边,进行加减操作 3: 4: 需要添加索引的几种场景: 1: 2: 3: 4: 5:

    1K30编辑于 2022-04-14
  • 来自专栏JAVA高级架构

    SQL性能优化梳理

    第一层:客户端通过连接服务,将要执行的sql指令传输过来 第二层:服务器解析并优化sql,生成最终的执行计划并执行 第三层:存储引擎,负责数据的储存和提取 1.2 锁 数据库通过锁机制来解决并发场景-共享锁 被用来设计处理大量短期事务,具有高性能和自动奔溃恢复的特性。 MyISAM引擎,不支持事务和行级锁,奔溃后无法安全恢复。 Char,定长,适合存储固定长度的字符串,如MD5值。 Blob,Text 为了存储很大的数据而设计的。分别采用二进制和字符的方式。 时间类型 DateTime,保存大范围的值,占8个字节。 age WHERE student s1 INNER JOIN ( SELECT id FROM student ORDER BY age LIMIT 50,5 "value2"}'); SELECT * FROM json_test WHERE JSON_CONTAINS(name, '$.name1'); ---->来自JVM专家-达 关注explain在性能分析中的使用

    1.3K70发布于 2018-04-19
  • 来自专栏辰远

    SQL电脑性能测试

    循环添加10w行数据,测试索引效果 USE myschool; #创建测试表 DROP TABLE IF EXISTS Test; CREATE TABLE Test( id INT, NAME VARCHAR(50) ); # 循环添加10W条数据数据 DROP PROCEDURE IF EXISTS usp_initial_data; DELIMITER // CREATE PROCEDURE usp_initial_data() BEGIN DECLARE i INT; SET

    3.1K40编辑于 2022-11-21
  • 来自专栏电光石火

    SQL 性能调优

    阅读目录 (1)选择最有效率的表名顺序(只在基于规则的优化器中有效) (2)WHERE子句中的连接顺序 (3)SELECT子句中避免使用 ‘ * ‘ (4)减少访问数据库的次数 (5)在SQL*Plus ,还要做到写出性能优良的SQL,以下为笔者学习、摘录、并汇总部分资料与大家分享! 语句, 估算索引的利用率, 绑定变量 , 读数据块等; 回到顶部 (5)在SQL*Plus , SQL*Forms和Pro*C中重新设置ARRAYSIZE参数, 可以增加每次数据库访问的检索数据量 ,建议值为 性能上的差异,关键看你的from和where子句。比如说如果你的where条件中可以通过索引,那显然 select 1 from ... 的性能比 select * from ... 好。 仔细检查order by语句以找出非索引项或者表达式,它们会降低性能

    4.7K10发布于 2019-12-13
  • 来自专栏JMCui

    SQL优化二(SQL性能调优)

    )负责将更改的buffer 从db buffer cache中写到datafile中去,通过一个dbwn进程(dbw0)就足够了,但是也可以配置更多额外的dbwr进程,它可以提升频繁更改的数据库系统的性能 因为分离了更改数据库buffer的任务:dbwn散列写buffer到disk中,执行快速的顺序写到redo,所以数据库提升了性能。 1.用户提交了一个事务。 从上一次lgwr写操作开始已经过去了3秒 4. redo log buffer 三分之一满或者已经存储了1mb的数据量 5. dbwn必须写更改的数据到磁盘上面。 优化技巧5:避免使用select * from 减少物理读,逻辑读(* 要走系统字典表,查看这张表有哪些字段),最好制定需要返回的字段。 deptno from dept; 优化技巧18:Order By语句中的非索引列会降低性能,可以通过添加索引的方式处理。

    1.9K61发布于 2018-03-15
  • 来自专栏全栈程序员必看

    编写高性能SQL

    在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图的编写,刚开始不会体会出SQL语句各种写法的性能优劣,但是如果将应用系统提交实际应用后,随着数据库中数据的增加,系统的响应速度就成为目前系统需要解决的最主要的问题之一 在多数情况下,Oracle使用索引来更快的遍历表,优化器主要根据定义的索引来提高性能。 在编写SQL语句时我们应清楚优化器根据何种原则来删除索引,这有助于写出高性能SQL语句。    下面就某些SQL语句的where子句编写中需要注意的问题作详细介绍。 仔细检查order by语句以找出非索引项或者表达式,它们会降低性能5. NOT    我们在查询时经常在where子句使用一些逻辑表达式,如大于、小于、等于以及不等于等等,也可以使用and(与)、or(或)以及not(非)。

    3.1K20编辑于 2021-12-27
  • 来自专栏Python数据科学

    SQL 性能优化梳理

    第一层:客户端通过连接服务,将要执行的sql指令传输过来 第二层:服务器解析并优化sql,生成最终的执行计划并执行 第三层:存储引擎,负责数据的储存和提取 1.2 锁 数据库通过锁机制来解决并发场景-共享锁 被用来设计处理大量短期事务,具有高性能和自动崩溃恢复的特性。 MyISAM引擎,不支持事务和行级锁,崩溃后无法安全恢复。 Char,定长,适合存储固定长度的字符串,如MD5值。 Blob,Text 为了存储很大的数据而设计的。分别采用二进制和字符的方式。 时间类型 DateTime,保存大范围的值,占8个字节。 age WHERE student s1 INNER JOIN ( SELECT id FROM student ORDER BY age LIMIT 50,5 name2": "value2"}'); SELECT * FROM json_test WHERE JSON_CONTAINS(name, '$.name1'); 来自JVM专家-达 关注explain在性能分析中的使用

    1K20发布于 2019-11-21
  • 来自专栏电光石火

    SQL 性能调优

    我们要做到不但会写SQL,还要做到写出性能优良的SQL,以下为笔者学习、摘录、并汇总部分资料与大家分享! 语句, 估算索引的利用率, 绑定变量 , 读数据块等; (5)在SQL*Plus , SQL*Forms和Pro*C中重新设置ARRAYSIZE参数, 可以增加每次数据库访问的检索数据量 ,建议值为 这意味着每条记录的INSERT , DELETE , UPDATE将为此多付出4 , 5 次的磁盘I/O . 因为索引需要额外的存储空间和处理,那些不必要的索引反而会使查询反应时间变慢.。 性能上的差异,关键看你的from和where子句。比如说如果你的where条件中可以通过索引,那显然 select 1 from ... 的性能比 select * from ... 好。 仔细检查order by语句以找出非索引项或者表达式,它们会降低性能

    3.7K60发布于 2018-01-18
  • 来自专栏猿人谷

    Oracle SQL性能优化

    语句, 估算索引的利用率, 绑定变量 , 读数据块等; (5)      在SQL*Plus , SQL*Forms和Pro*C中重新设置ARRAYSIZE参数, 可以增加每次数据库访问的检索数据量 (译者按: TRUNCATE只在删除全表适用,TRUNCATE是DDL不是DML) (10) 尽量多使用COMMIT: 只要有可能,在程序中尽量多使用COMMIT, 这样程序的性能得到提高,需求也会因为 效率.: 复杂的SQL往往牺牲了执行效率. 这意味着每条记录的INSERT , DELETE , UPDATE将为此多付出4 , 5 次的磁盘I/O . 因为索引需要额外的存储空间和处理,那些不必要的索引反而会使查询反应时间变慢.。 (33) 避免使用耗费资源的操作: 带有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL语句会启动SQL引擎 执行耗费资源的排序(SORT)功能.

    3.6K70发布于 2018-01-17
  • 来自专栏.NET企业级解决方案应用与咨询

    SQL 性能优化 总结

    SQL 性能优化 总结 (1)选择最有效率的表名顺序(只在基于规则的优化器中有效): ORACLE的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表(基础表 (5)在SQL*Plus , SQL*Forms和Pro*C 中重新设置ARRAYSIZE 参数, 可以增加每次数据库访问的检索数据量 ,建议值为200。 (10)尽量多使用COMMIT: 只要有可能,在程序中尽量多使用 COMMIT, 这样程序的性能得到提高,需求也会因为 COMMIT所释放的资源而减少: COMMIT所释放的资源: 语句:目前各种关于SQL优化的图形化工具层出不穷,大家自己搜索。 这意味着每条记录的 INSERT , DELETE , UPDATE将为此多付出4 , 5 次的磁盘I/O . 因为索引需要额外的存储空间和处理,那些不必要的索引反而会使查询反应时 间变慢.。

    2.5K20发布于 2019-09-17
  • 来自专栏程序员的成长之路

    SQL 性能优化梳理

    第一层:客户端通过连接服务,将要执行的sql指令传输过来 第二层:服务器解析并优化sql,生成最终的执行计划并执行 第三层:存储引擎,负责数据的储存和提取 1.2 锁 数据库通过锁机制来解决并发场景-共享锁 被用来设计处理大量短期事务,具有高性能和自动崩溃恢复的特性。 MyISAM引擎,不支持事务和行级锁,崩溃后无法安全恢复。 Char,定长,适合存储固定长度的字符串,如MD5值。 Blob,Text 为了存储很大的数据而设计的。分别采用二进制和字符的方式。 时间类型 DateTime,保存大范围的值,占8个字节。 age WHERE student s1 INNER JOIN ( SELECT id FROM student ORDER BY age LIMIT 50,5 name2": "value2"}'); SELECT * FROM json_test WHERE JSON_CONTAINS(name, '$.name1'); 来自JVM专家-达 关注explain在性能分析中的使用

    87020发布于 2019-11-23
  • 来自专栏Java项目实战

    Java 优化的5个方面是:架构、SQL性能、接口和 JVM

    Java 优化的5个方面是:架构、SQL性能、接口和 JVM。这些方面的优化对于提高 Java 程序的性能至关重要。 通过使用链表,可以减少数组中指针的移动,从而提高程序的性能SQL优化 SQL 优化是指通过优化数据库查询来提高程序的性能。例如,可以使用索引、优化查询语句、使用分页查询等方法来提高查询性能。 下面是一个使用索引来优化数据库查询的示例代码: // SELECT * FROM employees WHERE department_id = 10 String sql = "SELECT * 通过创建一个索引,可以优化查询性能,提高查询速度。 性能优化 性能优化是指通过优化程序的算法和数据结构来提高程序的性能。例如,可以使用缓存技术、减少不必要的计算、使用并行计算等方法来优化程序的性能。 JVM优化 JVM优化是指通过优化 JVM 的内部实现来提高程序的性能。例如,可以使用 JVM 的调优技术来提高 JVM 的性能、使用 JVM 的并行化技术来提高 JVM 的性能等。

    69000编辑于 2023-04-09
  • 来自专栏架构驿站

    性能优化】MySQL之SQL剖析(SQL profile)

    分析SQL执行带来的开销是优化SQL的重要手段。在MySQL数据库中,可以通过配置profiling参数来启用SQL剖析。该参数可以在全局和session级别来设置。 该参数开启后,后续执行的SQL语句都将记录其资源开销,诸如IO,上下文切换,CPU,Memory等等。根据这些开销进一步分析当前SQL瓶颈从而进行优化与调整。 --------------------------------------------------------------------------------------------+ 3、获取SQL 语句的开销信息 --可以直接使用show profile来查看上一条SQL语句的开销信息 --注,show profile之类的语句不会被profiling,即自身不会产生Profiling - **************** 1. row *************************** QUERY_ID: 1 SEQ: 5

    83740编辑于 2022-03-25
  • 来自专栏技术杂记

    SQL 精编(5

    where to_days(the_date) >= to_days(date_sub(now(),interval 60 day)) group by user_id having ct >= 5

    36410发布于 2021-10-19
  • 来自专栏全栈程序员必看

    Mysql性能优化一:SQL语句性能优化

    18,一些SQL查询语句应加上nolock,读、写是会相互阻塞的,为了提高并发性能,对于一些查询,可以加上nolock,这样读的时候可以允许写,但缺点是可能读到未提交的脏数据。 24,当服务器的内存够多时,配制线程数量 = 最大连接数+5,这样能发挥最大的效率;否则使用 配制线程数量<最大连接数启用SQL SERVER的线程池来解决,如果还是数量 = 最大连接数+5,严重的损害服务器的性能 的问题,对于记录数小于5的索引字段,在UNION的时候使用LIMIT不是是用OR。  47,EXPLAIN SELECT 查询用来跟踪查看效果  使用 EXPLAIN 关键字可以让你知道MySQL是如何处理你的SQL语句的。这可以帮你分析你的查询语句或是表结构的性能瓶颈。 可以在执行sql前调用begin,多条sql形成一个事物(即使autocommit打开也可以),将大大提高性能

    2.5K21发布于 2021-11-10
  • 来自专栏hml_知识记录

    SQL性能优化简介

    SQL性能优化简介InterSystems SQL支持几个特性来优化InterSystems IRIS®数据平台的SQL性能。表定义优化SQL性能从根本上取决于良好的数据架构。 查询优化在几乎所有情况下,用嵌入式SQL编写的查询的执行速度都比用动态SQL编写的查询快。还要注意,由于存在缓存查询,对于嵌入式SQL和动态SQL,重新执行查询的速度都比初始执行快得多。 这些查询优化使用现有的表定义和表数据优化:运行时统计:用于衡量系统上查询执行的性能。显示计划显示查询的执行计划。缓存查询和文字替换:维护最近动态查询的缓存,允许重新执行查询,而不会重复准备查询的开销。 SQL语句和冻结计划允许保留查询执行计划,从而允许在不降低现有查询性能的情况下更改表。索引配置和使用:用于指定如何使用现有索引。 分片环境中的最佳性能通常是通过组合使用分片表(通常非常大的表)和非分片表来实现的快速命令InterSystems SQL支持快速选择、快速插入和快速截断表。

    96120编辑于 2022-06-07
  • 来自专栏前端记录笔记

    Oracle sql 性能优化(一)

    这是我参与「掘金日新计划 · 8 月更文挑战」的第16天,点击查看活动详情 >> 性能优化 2.1【推荐】尽量减少数据库负担 说明: 当执行每条 SQL 语句时, ORACLE 在内部执行了许多工作 :解析 SQL 语句、估算索引 的利用率、绑定变量、读数据块等。 减少访问数据库的次数,就能实际上减少 ORACLE 的工作量 \ 2.2【推荐】避免大表关联,大表关联可能存在性能问题 \ 2.4【强制】禁止使用“SELECT *”这样的语句,特别是在程序代码内部 说明 SQL 应尽量简化,查询类语句只查询 业务所需的数据,不查询无关数据表。 特别需要关注数据量巨大的表关联操作,使用不当会引发系统故障。 排序操作 说明: 大量的排序操作影响系统性能,如必须使用排序操作,尽量建立在有索引的列上。

    1.2K30编辑于 2022-11-02
  • 来自专栏前端记录笔记

    Oracle sql 性能优化(三)

    这是我参与「掘金日新计划 · 8 月更文挑战」的第16天,点击查看活动详情 >> 性能优化 2.19 【推荐】查询分页场景,建议如下分页格式,先查询过滤出一部分数据,再做下一层过滤查询 举例: Demo \ 2.21【参考】并行度使用需谨慎 说明: 并行技术的使用需要考虑 CPU 核数,系统负载等情况,并行执行的 SQL 会对其它语 句的性能产生影响,一般常用在报表分析任务和 OLAP 系统中。 建议修改成外连接方式,这样可以走 HASH JOIN,避免 FILTER,提升性能。 ,需要进行执行计划分析 说明: SQL语句的执行效率对于系统非常重要,一个效率很低的SQL会降低系统吞吐 量,严重时可导致系统宕机。 所以,对于SQL语句的执行计划分析显得相当重要,下图是使 用PL/SQL Developer分析SQL执行计划的示例。这里仅给出示例,不给出具体如何分析的方 法,相关技能请自学或参加培训。

    80970编辑于 2022-11-02
领券