@[toc] 关于 MySQL 中的索引,松哥前面已经和小伙伴们聊了不少了,不过在索引使用的时候,还是有一些需要注意的细节,如果忽略了这些细节,可能会让索引的使用效果大打折扣。
1. 冗余索引
注意我这里使用了冗余索引,没有使用重复索引,因为我觉得在小伙伴们使用索引的过程中,创建重复索引的概率应该还是比较小,同一个字段上创建多个一模一样的索引,应该很少有人会犯这种错误。但是,会有一些容易被大家忽略的冗余索引,我们来捋一捋。
1.1 联合索引左边列
例如我创建了一个联合索引 (A,B,C),按照我们之前跟大家讲的最左匹配原则,当我们使用 A、(A、B)或者 (A、B、C)去查询数据的时候,都会用到这个联合索引,所以我们就没有必要再去单独针对 A 字段创建一个索引,或者针对 A、B 字段创建一个联合索引。
1.2 索引中加入主键
假设我有一张表,该表有如下字段 (ID、A、B、C),其中 ID 是主键,现在又针对 A 和 ID 两个字段创建了联合索引(A、ID)。
根据松哥前面的介绍,小伙伴们知道,在二级索引中,叶子结点上存储的数据就是 ID,所以,这个联合索引中的 ID 字段显然是多余的。
大部分情况下我们都不需要冗余索引,但是也有一些特殊情况可能让我们不得不创建一些冗余索引,这个小伙伴们还是要具体问题具体分析。
另外需要注意一点,针对相同的字段,如果索引类型不同,则不能算是重复索引,例如一个普通索引和一个全文索引,同一个字段上同时有这两个索引,不算重复索引。
2. 隐藏的索引排序
上篇文章松哥刚刚和大家聊了索引排序的问题。
结合上篇文章的内容,小伙伴们思考这样一个问题:假设我有一张表,表中包含如下字段(ID、A、B),其中 ID 是主键,现在我针对 A 字段建立一个索引,如果我有如下查询 SQL:
select ... from table where A=xxx order by ID
由于在 A 这个二级索引中就包含了 ID 字段,所以上面这个查询是可以使用到索引排序的。此时,如果由于其他需求,我们将 A 这个索引扩展成联合索引(A、B)了,那么很明显,再执行上面的查询的时候就用不了索引排序了,只能 filesort 了。这样的问题小伙伴们在创建或者修改索引的时候很容易忽略,所以一定要仔细。
3. 删除不使用的索引
有的索引可能是由于过度考虑创建了,创建成功之后就没用过,这样的索引也应该删除掉。
小伙伴们知道,索引虽然可以提高查询速度,但是却会降低插入和修改速度。
在 MySQL 的元数据库 sys 中有一个名为 schema\_unused\_indexes 的视图,该视图中就保存了各种创建了但是未使用的索引:
4. 手动更新索引统计信息
当我们想要查看一条 SQL 的执行计划时,这个执行计划中会展示出来这个 SQL 执行过程中大概会扫描多少行数据,如下:
这个预估的扫描行数非常重要,这是 MySQL 优化器在执行 SQL 的时候一个重要的参考指标,如果表没有这个统计信息,或者统计信息不准确,那么就有可能导致优化器做出错误的决定。
当满足如下条件的时候,这个统计信息会自动生成或者更新:
首次打开表。
表大小发生变化。
执行 SHOW TABLE STATUS
执行 SHOW INDEX
MySQL 客户端开启自动补全功能
打开 infomation\_schema 库中一些相关的表
这些行为都会触发统计信息的自动更新,如果表中数据量比较大,担心以上行为降低表的性能,那么也可以修改 innodb\_stats\_on\_metadata 参数来关闭以上行为。
当然,我们也可以手动执行 analyze table
命令来更新索引的统计信息。
5. 适时优化表
InnoDB 中的索引是一个 B+Tree,这个我们在之前的文章中就和小伙伴们聊过了。B+Tree 通过一个多路平衡查找树将数据组织在一起,然而这个树中的各个结点在存储的时候在物理分布上却并不一定连续,如果是连续的,则在数据操作的时候就会快很多,如果不需连续,数据操作性能必然会有下降,一般来说,存在这样几种不同的碎片形式:
行碎片:数据行分布在不同的地方,读取数据行的时候涉及到多次随机 IO。
行间碎片:逻辑上应该是连续的行或者数据页,在磁盘上存储时并不连续。原本全表扫描的时候是顺序 IO,现在变成了随机 IO。
剩余空间碎片:小伙伴们知道,InnoDB 操作数据表最基本单位是页,一页是 16KB,也就是 InnoDB 从磁盘上读、往磁盘上写,最低单位都是 16KB,有时候这 16KB 中,有效数据很少,其他地方都是剩余空间,就会让 InnoDB 在读写数据的时候造成很大浪费。
对于以上情况,我们可以通过执行 optimize table 来重新整理数据,如果存储引擎不支持 optimize table 命令,那么我们也可以通过执行 alter table engine=xxx 命令来实现数据的重整(命令中的 xxx 就是表原本的引擎)。
当然,optimize table 命令在执行的过程中还有一些细节问题,这个松哥后面再整文章和小伙伴们分享。
你可能感兴趣的:(mysql数据库数据库性能优化)
Mac OSX 下的mysql数据库文件存放位置
Bruuuces
mysql mac osx 位置 存放
之前我的mysql的系统数据库里的表被我玩坏了,万般无奈之下只得删除所有mysql的东西重新构建数据库。按照网上搜到的内容删除后重装发现数据库没有什么变化。于是自己在每个可能存放数据库文件的目录查找,最终确认目录位置如下:使用HomeBrew安装为/usr/local/var/mysql使用官方下载的dmg镜像安装为/usr/local/mysql删除这个目录再重新安装mysql就会重新生成系统数
mac升级mysql_Mac OSX下的MySQL数据库升级
weixin_39801714
mac升级mysql
MacOSX下的数据库升级最麻烦的不过权限的问题.本文的MySQL的安装方式为OSX下DMG磁盘镜像的安装方式,MacPorts/Homebrew的方式大同小异.从5.6.17升级到5.7.18安装目录信息ls-al/usr/local|grepmysqllrwxr-xr-x1rootwheel30B52100:39mysql@->mysql-5.6.17-osx10.7-x86_64drwxr-
【MySQL】MySQL数据库如何改名
武昌库里写JAVA
面试题汇总与解析 spring boot vue.js sql java 学习
MySQL建库授权语句https://www.jianshu.com/p/2237a9649ceeMySQL数据库改名的三种方法https://www.cnblogs.com/gomysql/p/3584881.htmlMySQL安全修改数据库名几种方法https://blog.csdn.net/haiross/article/details/51282417MySQL重命名数据库https://
大学社团管理系统(11831)
codercode2022
java spring boot spring echarts spring cloud sentinel java-rocketmq
有需要的同学,源代码和配套文档领取,加文章最下方的名片哦一、项目演示项目演示视频二、资料介绍完整源代码(前后端源代码+SQL脚本)配套文档(LW+PPT+开题报告)远程调试控屏包运行三、技术介绍Java语言SSM框架SpringBoot框架Vue框架JSP页面Mysql数据库IDEA/Eclipse开发四、项目截图有需要的同学,源代码和配套文档领取,加文章最下方的名片哦!
MySQL数据类型详解
永远是少年啊
MySQL mysql 数据库 database
今天继续给大家介绍MySQL相关内容,本文主要内容是MySQL数据类型。MySQL数据库支持多种数据类型,这些数据类型大致可以分为三类:数值型、字符型和时间型。下面将MySQL的具体数据类型介绍如下:一、数值型类型大小(单位:字节)数值范围(有符号)数值范围(无符号)用途TINYINT1(-128,127)(0,255)微整数型SMALLINT2(-32768,32767)(0,65535)小整数
python3中,pycharm中怎么连接数据库
weixin_33736832
数据库 python 开发工具
因为python3现在还不能直接连接数据库,所有如果想连接,就只能通过以下方法:在APP中的,__init__.py中,添加以下代码就可以:importpymysqlpymysql.install_as_MySQLdb()当然前提是,那就的在setting.py中连接数据库添加所连接的mysql数据库的详细信息,如下:DATABASES={'default':{'ENGINE':'django.d
mysql一张表最多多少索引_关于MySQL的表最多能建多少个索引
众先运
mysql一张表最多多少索引
在某个网站上,忽然看到了个简短的问答“在MySQL数据库单个普通表上,最多可以创建多少个索引?”老实说,看到这个问题的瞬间我是有点懵的状态,我原本只只知道Innodb引擎的表,最多只有1017列(至于为什么不是1024,可以百度一下),下意识地就觉得索引最多可以创建1017个,但是仔细一想,不对啊,索引可以是复合索引啊,那绝对不止1017,难道索引的数量会是1个很大的数据吗?再仔细想想,以Inno
一个MySQL的数据表最多能够存多少的数据?
MySQL底层的存储结构是怎么样的?MySQL的数据在磁盘上是以文件形式存储的,其组织方式由表空间决定。表空间是InnoDB存储引擎的核心概念,理解它对数据库性能优化和运维管理至关重要。独立表空间独立表空间是MySQL5.6.6及以后版本的默认配置,每个表都有独立的.ibd数据文件。SHOWVARIABLESLIKE"innodbfilepertable%'如果关闭,那么每个表都不会是一个独立的表
Java+Vue 地下停车场管理系统的设计与实现
不若浮生一梦
计算机毕设 java vue.js 开发语言
一、项目简介本项目是一款基于SpringBoot+Vue开发的地下停车场管理系统,采用前后端分离架构,后端使用MyBatis操作MySQL数据库,前端使用Vue进行页面展示和用户交互。系统涵盖车位监控、车辆登记、订单生成与结算、在线支付、公告通知、留言反馈、用户积分管理等模块,支持用户端和管理员端的全流程停车管理,适用于中小型停车场数字化转型。项目定位:提升停车场管理效率与用户体验,实现“高效停车
【面试】面试官:MySQL数据库发生死锁,如何快速解决呢?
小冷coding
java常见的面试题和回答思路 数据库 面试 mysql
文章目录MySQL死锁的定位、排查与解决指南1.什么是死锁?2.如何快速定位死锁?3.如何排查死锁?4.如何解决死锁?5.总结与面试准备MySQL死锁的定位、排查与解决指南在Java面试中,数据库死锁问题是一个高频考点。面试官常问如何快速定位、排查和解决MySQL死锁,这考察你对数据库并发控制的理解和实操能力。本文将基于MySQLInnoDB引擎(最常用的事务引擎),逐步解析死锁的应对策略。先定义
三面华为BD,根据录音整理的软件测试面试真题
杰克瑟
面试 职场和发展 压力测试
1、自我介绍2、离职原因3、公司人员组成4、在工作中你认为自己是强势的人还是随和的人5、了解公司6、接受加班吗7、软件测试流程8、上线验收是谁验收9、Linux命令10、MySQL数据库11、编写测试用例会用到哪些方法12、怎样测试一个杯子/桌子/电梯13、开发不认为是缺陷,该怎么办14、如何做接口测试15、web测试和app测试的区别16、xxx模块的测试用例是怎么设计17、monkey测试18
JAVA知识点(六):性能调优与线上问题排查
程序员码龙
Java面试 java
文章目录服务间通信超时问题怎么解决?高并发线程安全问题如何排查慢SQL问题如何排查频繁FullGC问题如何排查文件导入导出导致内存溢出如何排查线上大规模故障时如何处理与恢复线上大量错误日志如何排查线上偶发性问题如何处理和跟踪线上问题的排查思路线上系统接口响应很慢如何排查线上系统突然响应缓慢如何排查CPU飙高问题如何排查Java进程突然挂了如何排查Java死锁问题如何排查MySQL数据库连接池爆满如
Ubuntu服务器安装与运维手册——操作纯享版
夏天里的肥宅水
LINUX SQL 服务器 服务器 运维 ubuntu
本手册汇总了从硬件预配置、Ubuntu安装、网络与服务配置,到Windows/macOS访问共享、MySQL初始化的完整流程,便于今后运维参考。目录环境与硬件概览BIOS/UEFI设置制作与启动安装介质Ubuntu24.04LTS安装流程静态IP配置(netplan)SSH远程登录配置Samba文件共享配置MySQL数据库初始化FTPvsSamba对比常见问题&解决环境与硬件概览机型:DellXP
探索 MySQL 缓存机制:提升数据库读取性能的有效策略
you的日常
#MySQL MySQL 数据库优化 数据库 mysql 缓存 后端 java database
在现代应用中,数据库的读取性能是影响用户体验和系统响应速度的关键因素。当应用程序面临高并发读请求时,直接访问磁盘的开销会成为瓶颈。为了应对这一挑战,MySQL引入了多种缓存机制,旨在减少磁盘I/O,加快数据检索速度。理解并合理利用这些缓存机制,是提升MySQL数据库读取性能的有效策略。本文将带你深入探索MySQL内部的各种缓存组件,包括它们的原理、作用以及如何在实际应用中进行配置和优化,助你全面提
MySQL 数据库调优指南:提升性能的全面策略
ruanjiananquan99
数据库 mysql oracle
在当今数据驱动的时代,MySQL作为一款广泛应用的开源关系型数据库,其性能的优劣直接影响到各类应用系统的运行效率与用户体验。无论是小型企业的内部管理系统,还是大型互联网公司的核心业务平台,优化MySQL数据库性能都至关重要。以下将从多个维度深入探讨MySQL数据库的调优方法。一、SQL语句优化(一)查询语句优化减少不必要的JOIN操作:JOIN操作在关联多个表数据时非常有用,但过多或不合理的JOI
MySql数据库基础
数据库相关概念•数据库是按数据结构组织、存储和管理数据的仓库,本质是文件系统;数据库管理系统是操纵和管理数据库的大型软件,用户和管理员通过它访问和维护数据库。•介绍了关系型数据库管理系统(如MySQL、Oracle等)和NoSQL数据库(如Redis、MongoDB等),前者基于关系模型用表格存储数据,后者非关系型,有键值、列族等多种类型。MySQL简介与安装配置•MySQL是开源的关系型数据库管
MySQL 数据库 SQL 语句全面解析与实战总结
锈铁与酒
数据库
在本学期的《MySQL数据库技术》课程中,我们系统学习了各类SQL语句,它们是操作数据库的核心工具。为了加深理解、总结经验,本文将对所有SQL语句进行全面的知识性整理,涵盖使用规范、应用规则、易错点、应用实战等内容。一、数据定义语言(DDL)1.CREATE语句使用规范创建数据库:CREATEDATABASEdatabase_name[CHARACTERSETcharset_name][COLLA
mysql数据库不生效配置文件报错: mysqld: [Warning] World-writable config file ‘/etc/mysql/conf.d/my.cnf‘ is i
一叶知秋96
mysql 数据库
mysqld:[Warning]World-writableconfigfile'/etc/mysql/conf.d/my.cnf'isi这个问题:mysql不能使用配置文件,原因是:权限不对,mysql认为不安全,如果是docker配置的那就配个docker用户的权限给my.cnf文件就行了。配置用户:chown-Rlxd:dockermy.cnf(需要重新生效的mysql配置就先删除数据库,谨
【计算机毕业设计】基于Springboot的智能推荐卫生健康系统【源码+lw+部署文档】
FOUR_A
计算机组成原理 课程设计 spring boot 后端 毕业设计 microsoft 学习
包含论文源码的压缩包较大,请私信或者加我的绿色小软件获取免责声明:资料部分来源于合法的互联网渠道收集和整理,部分自己学习积累成果,供大家学习参考与交流。收取的费用仅用于收集和整理资料耗费时间的酬劳。本人尊重原创作者或出版方,资料版权归原作者或出版方所有,本人不对所涉及的版权问题或内容负法律责任。如有侵权,请举报或通知本人删除。目录1系统概述1.3系统设计思想2相关技术2.1MYSQL数据库2.2B
Leetcode力扣 MySQL数据库 1532 最近三笔订单
ziko-1101
Leetcode 数据库 mysql leetcode
1532最近三笔订单SQL架构CreatetableIfNotExistsCustomers_1532(customer_idint,namevarchar(10));CreatetableIfNotExistsOrders_1532(order_idint,order_datedate,customer_idint,costint);TruncatetableCustomers_1532;ins
Leetcode力扣 MySQL数据库 1393 股票的资本损益
ziko-1101
Leetcode 数据库 leetcode mysql
1393股票的资本损益SQL架构CreateTableIfNotExistsStocks_1393(stock_namevarchar(15),operationENUM('Sell','Buy'),operation_dayint,priceint);TruncatetableStocks_1393;insertintoStocks_1393(stock_name,operation,opera
Leetcode力扣 MySQL数据库 1440 计算布尔表达式的值
ziko-1101
Leetcode 数据库 mysql leetcode
1440计算布尔表达式的值SQL架构CreateTableIfNotExistsVariables_1440(namevarchar(3),valueint);CreateTableIfNotExistsExpressions_1440(left_operandvarchar(3),operatorENUM('>','','y');insertintoExpressions_1440(left_o
第72讲:MySQL数据库锁机制剖析:行级锁、间隙锁与临键锁详解及应用指南
Jiangxl~
《MySQL DBA封神打怪之路》 # 《Python基础语法入门篇》 数据库 mysql 云计算 运维 数据结构 链表
文章目录1.行级锁的概念2.行锁的概念以及基本使用2.1.行锁的概念2.2.常见的SQL语句所对应的行锁类别2.3.行锁的基本使用3.间隙锁和临键锁的概念以及基本使用3.1.间隙锁和临键锁的概念3.2.间隙锁和临键锁的基本使用1.行级锁的概念行级锁指的是,每次操作锁住的是表中一行的数据,锁的力度最小,发生锁冲突的概率也是最低的,并且并发度也是最高的,行级锁主要应用于InnoDB存储引擎中。在Inn
MySQL(159)MySQL的逻辑架构是什么?
MySQL逻辑架构是理解MySQL数据库管理系统如何处理SQL语句及其性能优化的基础。MySQL的逻辑架构主要分为三个层次:连接层、服务层和存储引擎层。一、MySQL的逻辑架构概览连接层服务层存储引擎层二、详细描述每一层1.连接层连接层负责处理MySQL客户端与服务器之间的连接。它管理连接认证、安全检查和权限验证。连接管理和安全性:负责建立和管理客户端连接,进行用户验证和权限检查。连接缓存和线程管
【Python练习】 062. 编写一个函数,实现简单的数据库连接和操作
视睿
从零开始学习机器人 数据库 python jvm
目录062.编写一个函数,实现简单的数据库连接和操作示例1:使用SQLite示例代码示例2:使用MySQL示例代码代码说明注意事项应用场景使用Python连接和操作数据库连接SQLite数据库插入数据查询数据更新数据删除数据关闭连接使用Python连接MySQL数据库使用ORM(SQLAlchemy)应用场景062.编写一个函数,实现简单的数据库连接和操作在Python中,可以使用多种数据库连接库
3步掌握JMeter与Jenkins自动化性能测试!
爱吃 香菜
软件测试 自动化测试 职场经验 jmeter jenkins 自动化测试 职场经验 软件测试 程序员 深度学习
面试求职:「面试试题小程序」,内容涵盖测试基础、Linux操作系统、MySQL数据库、Web功能测试、接口测试、APPium移动端测试、Python知识、Selenium自动化测试相关、性能测试、性能测试、计算机网络知识、Jmeter、HR面试,命中率杠杠的。(大家刷起来…)职场经验干货:软件测试工程师简历上如何编写个人信息(一周8个面试)软件测试工程师简历上如何编写专业技能(一周8个面试)软件测
ARM46+KylinOS 环境下 MySQL 数据库安装与迁移适配深度实践指南
kobai159
adb ARM46架构 KylinOS MySQL 安装 数据库安装
一、ARM46+KylinOS环境与MySQL适配原理概述ARM46架构基于精简指令集(RISC)设计,具有低功耗、高性能等特点,在嵌入式、边缘计算等场景广泛应用;KylinOS作为国产操作系统,有着较高的安全性和稳定性。MySQL数据库在不同架构和操作系统上的迁移适配,本质是解决指令集兼容性、系统库依赖、文件权限管理等问题。ARM架构与常见的x86架构指令集不同,因此MySQL安装包需要专门适配
Redis--缓存雪崩-缓存穿透-缓存击穿
一年之后会更好
缓存雪崩:缓存在redis数据库中的数据大面积失效,请求落到了例如mysql数据库中,由于mysql不支持大量的请求操作,所以导致mysql数据库崩溃;解决方案:①缓存失效后加锁②队列控制③key设置不同过期时间缓存穿透:大量数据请求根本不存在redis缓存中的数据,导致没有走缓存,直接跑去访问数据库;解决方案:①先把请求的数据缓存起来,然后设置过期时间②使用布隆过滤器;缓存击穿:热点数据被频繁访
MySQL数据库优化之SQL优化终极指南
AAEllisonPang
Mysql 数仓 大数据 数据库 mysql sql
目录SQL性能分析基础1.1慢查询日志配置1.2EXPLAIN执行计划解读1.3实时性能诊断工具索引优化实战2.1最左前缀原则的陷阱2.2联合索引设计案例2.3索引失效的7种场景高效查询编写技巧3.1避免全表扫描的秘诀3.2Join优化黄金法则3.3分页查询深度优化高级优化策略4.1隐式类型转换灾难4.2子查询重构方案4.3大数据量更新技巧企业级监控方案5.1慢SQL自动化分析5.2SQL审核平台
springboot基于Web手工艺品销售系统的开发与实现(11786)
codercode2022
spring boot 后端 java 开发语言 rabbitmq spring spring cloud
有需要的同学,源代码和配套文档领取,加文章最下方的名片哦一、项目演示项目演示视频二、资料介绍完整源代码(前后端源代码+SQL脚本)配套文档(LW+PPT+开题报告)远程调试控屏包运行三、技术介绍Java语言SSM框架SpringBoot框架Vue框架JSP页面Mysql数据库IDEA/Eclipse开发四、项目截图有需要的同学,源代码和配套文档领取,加文章最下方的名片哦!
scala的option和some
矮蛋蛋
编程 scala
原文地址:
http://blog.sina.com.cn/s/blog_68af3f090100qkt8.html
对于学习 Scala 的 Java™ 开发人员来说,对象是一个比较自然、简单的入口点。在 本系列 前几期文章中,我介绍了 Scala 中一些面向对象的编程方法,这些方法实际上与 Java 编程的区别不是很大。我还向您展示了 Scala 如何重新应用传统的面向对象概念,找到其缺点
NullPointerException
Cb123456
android BaseAdapter
java.lang.NullPointerException: Attempt to invoke virtual method 'int android.view.View.getImportantForAccessibility()' on a null object reference
出现以上异常.然后就在baidu上
PHP使用文件和目录
天子之骄
php文件和目录 读取和写入 php验证文件 php锁定文件
PHP使用文件和目录
1.使用include()包含文件
(1):使用include()从一个被包含文档返回一个值
(2):在控制结构中使用include()
include_once()函数需要一个包含文件的路径,此外,第一次调用它的情况和include()一样,如果在脚本执行中再次对同一个文件调用,那么这个文件不会再次包含。
在php.ini文件中设置
SQL SELECT DISTINCT 语句
何必如此
sql
SELECT DISTINCT 语句用于返回唯一不同的值。
SQL SELECT DISTINCT 语句
在表中,一个列可能会包含多个重复值,有时您也许希望仅仅列出不同(distinct)的值。
DISTINCT 关键词用于返回唯一不同的值。
SQL SELECT DISTINCT 语法
SELECT DISTINCT column_name,column_name
F
java冒泡排序
3213213333332132
java 冒泡排序
package com.algorithm;
/**
* @Description 冒泡
* @author FuJianyong
* 2015-1-22上午09:58:39
*/
public class MaoPao {
public static void main(String[] args) {
int[] mao = {17,50,26,18,9,10
struts2.18 +json,struts2-json-plugin-2.1.8.1.jar配置及问题!
7454103
DAO spring Ajax json qq
struts2.18 出来有段时间了! (貌似是 稳定版)
闲时研究下下! 貌似 sruts2 搭配 json 做 ajax 很吃香!
实践了下下! 不当之处请绕过! 呵呵
网上一大堆 struts2+json 不过大多的json 插件 都是 jsonplugin.34.jar
strut
struts2 数据标签说明
darkranger
jsp bean struts servlet Scheme
数据标签主要用于提供各种数据访问相关的功能,包括显示一个Action里的属性,以及生成国际化输出等功能
数据标签主要包括:
action :该标签用于在JSP页面中直接调用一个Action,通过指定executeResult参数,还可将该Action的处理结果包含到本页面来。
bean :该标签用于创建一个javabean实例。如果指定了id属性,则可以将创建的javabean实例放入Sta
链表.简单的链表节点构建
aijuans
编程技巧
/*编程环境WIN-TC*/ #include "stdio.h" #include "conio.h"
#define NODE(name, key_word, help) \ Node name[1]={{NULL, NULL, NULL, key_word, help}}
typedef struct node { &nbs
tomcat下jndi的三种配置方式
avords
tomcat
jndi(Java Naming and Directory Interface,Java命名和目录接口)是一组在Java应用中访问命名和目录服务的API。命名服务将名称和对象联系起来,使得我们可以用名称
访问对象。目录服务是一种命名服务,在这种服务里,对象不但有名称,还有属性。
tomcat配置
关于敏捷的一些想法
houxinyou
敏捷
从网上看到这样一句话:“敏捷开发的最重要目标就是:满足用户多变的需求,说白了就是最大程度的让客户满意。”
感觉表达的不太清楚。
感觉容易被人误解的地方主要在“用户多变的需求”上。
第一种多变,实际上就是没有从根本上了解了用户的需求。用户的需求实际是稳定的,只是比较多,也比较混乱,用户一般只能了解自己的那一小部分,所以没有用户能清楚的表达出整体需求。而由于各种条件的,用户表达自己那一部分时也有
富养还是穷养,决定孩子的一生
bijian1013
教育 人生
是什么决定孩子未来物质能否丰盛?为什么说寒门很难出贵子,三代才能出贵族?真的是父母必须有钱,才能大概率保证孩子未来富有吗?-----作者:@李雪爱与自由
事实并非由物质决定,而是由心灵决定。一朋友富有而且修养气质很好,兄弟姐妹也都如此。她的童年时代,物质上大家都很贫乏,但妈妈总是保持生活中的美感,时不时给孩子们带回一些美好小玩意,从来不对孩子传递生活艰辛、金钱来之不易、要懂得珍惜
oracle 日期时间格式转化
征客丶
oracle
oracle 系统时间有 SYSDATE 与 SYSTIMESTAMP;
SYSDATE:不支持毫秒,取的是系统时间;
SYSTIMESTAMP:支持毫秒,日期,时间是给时区转换的,秒和毫秒是取的系统的。
日期转字符窜:
一、不取毫秒:
TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS')
简要说明,
YYYY 年
MM 月
【Scala六】分析Spark源代码总结的Scala语法四
bit1129
scala
1. apply语法
FileShuffleBlockManager中定义的类ShuffleFileGroup,定义:
private class ShuffleFileGroup(val shuffleId: Int, val fileId: Int, val files: Array[File]) {
...
def apply(bucketId
Erlang中有意思的bug
bookjovi
erlang
代码中常有一些很搞笑的bug,如下面的一行代码被调用两次(Erlang beam)
commit f667e4a47b07b07ed035073b94d699ff5fe0ba9b
Author: Jovi Zhang <
[email protected] >
Date: Fri Dec 2 16:19:22 2011 +0100
erts:
移位打印10进制数转16进制-2008-08-18
ljy325
java 基础
/**
* Description 移位打印10进制的16进制形式
* Creation Date 15-08-2008 9:00
* @author 卢俊宇
* @version 1.0
*
*/
public class PrintHex {
// 备选字符
static final char di
读《研磨设计模式》-代码笔记-组合模式
bylijinnan
java 设计模式
声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/
import java.util.ArrayList;
import java.util.List;
abstract class Component {
public abstract void printStruct(Str
利用cmd命令将.class文件打包成jar
chenyu19891124
cmd jar
cmd命令打jar是如下实现:
在运行里输入cmd,利用cmd命令进入到本地的工作盘符。(如我的是D盘下的文件有此路径 D:\workspace\prpall\WEB-INF\classes)
现在是想把D:\workspace\prpall\WEB-INF\classes路径下所有的文件打包成prpall.jar。然后继续如下操作:
cd D: 回车
cd workspace/prpal
[原创]JWFD v0.96 工作流系统二次开发包 for Eclipse 简要说明
comsci
eclipse 设计模式 算法 工作 swing
JWFD v0.96 工作流系统二次开发包 for Eclipse 简要说明
&nb
SecureCRT右键粘贴的设置
daizj
secureCRT 右键 粘贴
一般都习惯鼠标右键自动粘贴的功能,对于SecureCRT6.7.5 ,这个功能也已经是默认配置了。
老版本的SecureCRT其实也有这个功能,只是不是默认设置,很多人不知道罢了。
菜单:
Options->Global Options ...->Terminal
右边有个Mouse的选项块。
Copy on Select
Paste on Right/Middle
Linux 软链接和硬链接
dongwei_6688
linux
1.Linux链接概念Linux链接分两种,一种被称为硬链接(Hard Link),另一种被称为符号链接(Symbolic Link)。默认情况下,ln命令产生硬链接。
【硬连接】硬连接指通过索引节点来进行连接。在Linux的文件系统中,保存在磁盘分区中的文件不管是什么类型都给它分配一个编号,称为索引节点号(Inode Index)。在Linux中,多个文件名指向同一索引节点是存在的。一般这种连
DIV底部自适应
dcj3sjt126com
JavaScript
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml&q
Centos6.5使用yum安装mysql——快速上手必备
dcj3sjt126com
mysql
第1步、yum安装mysql
[root@stonex ~]# yum -y install mysql-server
安装结果:
Installed:
mysql-server.x86_64 0:5.1.73-3.el6_5 &nb
如何调试JDK源码
frank1234
jdk
相信各位小伙伴们跟我一样,想通过JDK源码来学习Java,比如collections包,java.util.concurrent包。
可惜的是sun提供的jdk并不能查看运行中的局部变量,需要重新编译一下rt.jar。
下面是编译jdk的具体步骤:
1.把C:\java\jdk1.6.0_26\sr
Maximal Rectangle
hcx2013
max
Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing all ones and return its area.
public class Solution {
public int maximalRectangle(char[][] matrix)
Spring MVC测试框架详解——服务端测试
jinnianshilongnian
spring mvc test
随着RESTful Web Service的流行,测试对外的Service是否满足期望也变的必要的。从Spring 3.2开始Spring了Spring Web测试框架,如果版本低于3.2,请使用spring-test-mvc项目(合并到spring3.2中了)。
Spring MVC测试框架提供了对服务器端和客户端(基于RestTemplate的客户端)提供了支持。
&nbs
Linux64位操作系统(CentOS6.6)上如何编译hadoop2.4.0
liyong0802
hadoop
一、准备编译软件
1.在官网下载jdk1.7、maven3.2.1、ant1.9.4,解压设置好环境变量就可以用。
环境变量设置如下:
(1)执行vim /etc/profile
(2)在文件尾部加入:
export JAVA_HOME=/home/spark/jdk1.7
export MAVEN_HOME=/ho
StatusBar 字体白色
pangyulei
status
[[UIApplication sharedApplication] setStatusBarStyle:UIStatusBarStyleLightContent];
/*you'll also need to set UIViewControllerBasedStatusBarAppearance to NO in the plist file if you use this method
如何分析Java虚拟机死锁
sesame
java thread oracle 虚拟机 jdbc
英文资料:
Thread Dump and Concurrency Locks
Thread dumps are very useful for diagnosing synchronization related problems such as deadlocks on object monitors. Ctrl-\ on Solaris/Linux or Ctrl-B
位运算简介及实用技巧(一):基础篇
tw_wangzhengquan
位运算
http://www.matrix67.com/blog/archives/263
去年年底写的关于位运算的日志是这个Blog里少数大受欢迎的文章之一,很多人都希望我能不断完善那篇文章。后来我看到了不少其它的资料,学习到了更多关于位运算的知识,有了重新整理位运算技巧的想法。从今天起我就开始写这一系列位运算讲解文章,与其说是原来那篇文章的follow-up,不如说是一个r
jsearch的索引文件结构
yangshangchuan
搜索引擎 jsearch 全文检索 信息检索 word分词
jsearch是一个高性能的全文检索工具包,基于倒排索引,基于java8,类似于lucene,但更轻量级。
jsearch的索引文件结构定义如下:
1、一个词的索引由=分割的三部分组成: 第一部分是词 第二部分是这个词在多少