作者: realcp1018 原文来源: https://tidb.net/blog/2056c25c
一、背景简介
在日常使用TiDB的场景中经常会遇到此类问题:
建表时未使用分区表,导致数据删除困难。
想要快速的批量更新数据,但是每次都需要编写繁杂的跑批任务。
想要在数亿、数十亿的大表中删除几千完或几百万数据但是却总是遇到“事务大小超出限制”的错误。
为解决此类问题我编写了一个通用的删除工具,用于处理此类“事务大小超出限制”的错误。 可类比mysql的oak-chunk-update工具。 这个工具在我司生产环境运行两年以来,高效的删除了大量数据,目前已趋于完善,因此写笔记分享出来。
项目地址: https://github.com/realcp1018/tidb-toolkit
二、环境要求
git clone https://github.com/realcp1018/tidb-toolkit.git
运行 "python3 -m pip install -r requirements.txt" 安装python3库依赖.
将项目目录添加至$PYTHONPATH:
# 假设项目被clone至/data目录下:
export PYTHONPATH=$PYTHONPATH:/data/tidb-toolkit
三、使用示例
1. 使用tk_dml_byid对表执行 "delete from where ..." (表必须未设置auto_random或shard_rowid_bits,如果误在此类表上运行也关系,只是效率极底)
# 编辑 tidb.toml 的 [basic], [dml] 和 [dml.by_id] 部分,其他部分的设置不影响本次运行
db = "test"
table = "tb1kb_1"
sql = "delete from tb1kb_1 where is_active=0;"
execute = false
# 运行:
python3 scripts/tk_dml_byid.py -f conf/tidb.toml -l tb1kb_1.log
# execute = false: 设置此项表示不实际进行数据删除,仅打印一个拆分后的示例SQL,适用于比较谨慎的场景
# 确保输出的拆分SQL符合预期,然后可以修改为true实际运行
2. 使用tk_dml_by_time对表执行 "delete from where ..." (表已设置auto_random或shard_rowid_bits,或者仅仅想根据时间列删除极少部分数据)
# 编辑 tidb.toml 的 [basic], [dml] and [dml.by_time] 部分
db = "test"
table = "tb1kb_1"
sql = "delete from tb1kb_1 where is_active=0;"
# 假设 create_time 类型为 int(时间精度为ms)
split_column = "create_time"
split_column_precision = 3
split_interval = 3600
start_time = "2021-01-01 00:00:00"
end_time = "2021-12-31 00:00:00"
execute = false
# 运行:
python3 scripts/tk_dml_by_time.py -f conf/tidb.toml -l tb1kb_1.log
3. 使用tk_chunk_update对表执行 "delete from where ..." (可覆盖上述两种场景,无需考虑表是否设置auto_random或shard_rowid_bits)
# 编辑 tidb.toml 的 [basic], [dml] 和 [dml.chunk_update] 部分
db = "test"
table = "tb1kb_1"
sql = "delete from tb1kb_1 where is_active=0;"
execute = false
# 运行:
python3 scripts/tk_chunk_update.py -f conf/tidb.toml -l tb1kb_1.log
# execute = false
# 确保输出的拆分SQL符合预期,然后可以修改为true实际运行
四、常见问题
1. 支持哪些类型的SQL?
工具支持以下几种SQL类型:
1.delete from where <...>
2.update set <...> where <...>
3.insert into select <...> from where <...>
非DML类型会直接报错退出。
2. 如何在tk_chunk_update 和 tk_dml_by_id, tk_dml_by_time之间做出选择?
tk_chunk_update无需人为进行表的类型判断,适用性高,只要是tidb的表都可以使用。 相比tk_dml_by_id可以避免大量无效rowid扫描,相比tk_dml_by_time则单条SQL执行更快。
但tk_chunk_update有极底概率遇到性能衰退的情况:如果表包含大量空region(或gc缓慢),那么在执行日志中你会看到如下记录:
ConnectionPool Monitor: Size 99
以及: chunk xxx Done [split_time=0:00:00.523525] [duration=0:00:00.229860] [rows=1000] [sql=...]
可以看到 split_time 大于 duration,这意味着chunk的生产速度慢于消费速度, 而tk_chunk_update的要点之一是就是需要保证chunk的生产速度远大于消费速度。
其原理如下 , 首先ChunkSpliter.split()通过如下查询条件获取chunk的右边界:
select max(rowid) from
(select rowid from table_name where rowid > current_rowid order by rowid limit 0,chunk_size) t
并以current_rowid作为chunk左边界,然后生成拆分后的SQL,输出一个Chunk同时将current_rowid推进至chunk右边界以便下一个chunk拆分使用,而split()是一个python生成器。
然后Executor遍历split()生成的chunk,调用其execute方法并将其作为一个future放入ThreadPoolExecutor中(执行并发度为max_workers)。
这个机制要求chunk的生成速度大于消费速度,否则会衰退为单线程执行,但是为目前了规避by_id的缺点又必须采用这种动态生成的方式,因此当你遇到此类性能衰退时, 请使用 tk_dml_by_id/tk_dml_by_time.
3. 关于 tk_dml_byid.py 和 tk_dml_bytime.py的拆分方式
By id:
默认使用rowid作为拆分列(如官网所示,数字类型主键就是rowid,其他情况则有一个内置的_tidb_rowid作为rowid)
如果表设置了( SHARD_ROW_ID_BITS 或 auto_random
), 那么建议使用 tk_dml_bytime 或 tk_chunk_update.
SQL的拆分方式很简单,直接按rowid累加batch_size拆分为无数个batch(例如 rowid >= 1 and rowid < 1000
), 并发执行度为 .
By time:
与by id的拆分方式相似,但是是通过时间列拆分为无数个task,拆分单位为配置文件中的 split_interval
执行方式与by id略有不同,因为按时间列拆分后的task内部可能包含的记录数扔超出事务限制,因此实际上在task内部会以batch_size为单位顺序执行同一条分页SQL直到影响行数为0
通过 grep Finished | tail
可以看到有多少task已完成
3. 关于 tk_chunk_update.py 的执行进度查看
通过如下命令可以查看当前任务的执行进度:
tailf |grep "write savepoint"
4. 关于 savepoint 和失败重试
tk_dml_by_id.py 和 tk_chunk_update.py 在执行过程中会生产检查点(如未设置savepoint配置则会生成一个默认的检查点文件),检查点表示在这之前已经处理完毕的rowid。 无论是异常退出还是主动终止,再次运行时如果检查点文件存在则会跳过已处理的rowid.tk_dml_by_time.py 则 不会 产生检查点,如果任务失败建议查看执行日志手动设置一个start_time然后重跑,通常来说只需要选一个相对较早的时间即可。
你可能感兴趣的:(tidb)
2020年10月国产数据库排行:GoldenDB跃升异军突起 PolarDB和GaussDB云化融合
数据和云
微软 informix 分布式存储 microsoft cloudera
墨墨导读:2020年10月国产数据库流行度的前三位由TiDB、达梦数据库、GBase(南大通用)获得,其中TiDB以超过100分的优势领先第二位的达梦数据库。数据技术嘉年华,十周年盛大开启,点我立即报名!大会以“自研·智能·新基建——云和数据促创新生态融合新十年”为主题,相邀数据英雄,总结过往十年历程与成绩,展望未来十年趋势与目标!近60场演讲,大咖云集,李飞飞、苏光牛、林晓斌、黄东旭...,快来
TiDB数据库
傲雪凌霜,松柏长青
后端 tidb 数据库
TiDB是由PingCAP开发的开源分布式SQL数据库,设计初衷是为了解决传统单机关系型数据库在处理大规模数据和高并发事务时的扩展性和性能问题。它结合了传统关系型数据库(如MySQL)的易用性和分布式系统的扩展能力,属于新一代的分布式SQL数据库。TiDB的关键特性兼容MySQL协议:TiDB兼容MySQL协议,用户可以直接使用MySQL客户端或MySQL的各种生态工具(如MySQLWorkben
HTAP 深入探索指南
每天读点书学堂
大数据 数据库 数据库开发
本指南介绍如何进一步探索并使用TiDB在线事务与在线分析处理(HybridTransactionalandAnalyticalProcessing,HTAP)功能。注意如果你对TiDBHTAP功能还不太了解,希望快速试用体验,请参阅快速上手HTAP。要快速了解TiDB在HTAP场景下的体系架构与HTAP的适用场景,建议先观看下面的培训视频(时长15分钟)。注意本视频只作为学习参考,如需了解详细的H
TiDB备份与恢复简介
每天读点书学堂
大数据 数据库架构 数据库 数据库开发 运维
本文档介绍如何对Kubernetes上的TiDB集群进行数据备份和数据恢复。备份与恢复中所使用的工具有Dumpling、TiDBLightning和BR。Dumpling是一个数据导出工具,该工具可以把存储在TiDB/MySQL中的数据导出为SQL或者CSV格式,可以用于完成逻辑上的全量备份或者导出。TiDBLightning是一个数据导入工具,该工具可以把Dumpling或CSV输出格式的数据快
等保2.0--安全计算环境--TiDB数据库
魔同
等保测评 安全 tidb 数据库
在使用本博客提供的学习笔记及相关内容时,请注意以下免责声明:信息准确性:本博客的内容是基于作者的个人理解和经验,尽力确保信息的准确性和时效性,但不保证所有信息都完全正确或最新。非专业建议:博客中的内容仅供参考,不能替代专业人士的意见和建议。在做出任何重要决定之前,请咨询相关领域的专业人士。个人责任:使用本博客内容的风险由用户自行承担。作者不对因使用本博客内容而导致的任何直接或间接损失承担责任。版权
窥一斑而知全豹
薛晓刚
数据库
说几个DTCC大会的插曲由于经济形势的不好,我看参展商少了一点。可能不少都是为了生计而挣扎。2023年1月明叔主持的栏目有一期特别节目《数据库诸神之战》,请来了OB、TiDB、TDSQL和TDEngine的掌门人来讨论数据库的未来,那时候结论是3年后国内健康运营的数据库公司不超过30家。目前已经快过去2年了。现在日子的确越来越难过了。现实可能和预测差不多。从出版社少到图书劵少每次大会都有各家出版社
开源项目精选:Bookshop Demo - 您的云端书店解决方案
毛彤影
开源项目精选:BookshopDemo-您的云端书店解决方案tidb-prisma-vercel-demoVirtualonlinebookstoreapplicationdemowhichyoucanfindbooksofvariouscategoriesandratethebooks.项目地址:https://gitcode.com/gh_mirrors/ti/tidb-prisma-verc
OLAP和OLTP以及HTAP的区别
霸王龙的日常
数据库概念 数据库 数据仓库
数据处理一般可以分成两大类:OLAP和OLTP那么有没有一种情况,将OLTP和OLAP相融合,在同一个系统中同时提供这两种服务,答案是有的。即HTAP产品。在这方面,国内的数据库厂商PingCAP的TiDB就不错。还有华为的GaussDB(openGauss)也对外公布六大关键技术特性其中之一就是高度支持HTAP混合负载。什么是OLAP?联机分析处理OLAP(OnLineAnalyticalPro
【数据库】GaussDB
一起学架构
数据库 数据库
目录一、GaussDB是什么数据库?二、GaussDB与Tidb、OcceanBase数据库的差别有哪些三、GaussDB的整体架构是怎么样的?四、GaussDB的核心技术特点是什么?五、GaussDB的适用场景有哪些?六、GaussDB在不同场景的一些最佳实践案例七、GaussDB性能优化技巧八、GaussDB使用的注意事项一、GaussDB是什么数据库?Gauss数据库是基于PostgreSQ
MYSQL的读写扩展
hailang86
mysql 数据库
1.分布式数据库有很多种:采用分库分表方式将数据路由拆分到多个数据库上;以greenplum未代表的mpp数据库架构;以tidb为代表的newSQl数据库架构。2.mpp数据架构是一种处理大规模数据分析任务的分布式数据架构,大规模并行处理。当执行一条SQL语句时,会将语句发送到所有数据节点进行查询处理,利用多节点的计算能力进行计算。3.分库分表主要用于简单的业务场景,OLTP场景,onlinetr
MySQL8.3 可以给 GTID 打标签了!
mysqlgtid事务
本文介绍了MySQL8.3的一个新特性,给GTID打标签~作者:李富强,爱可生DBA团队成员,熟悉MySQL,TiDB,OceanBase等数据库。相信持续把对的事情做好一点,会有不一样的收获。爱可生开源社区出品,原创内容未经授权不得随意使用,转载请联系小编并注明来源。本文约900字,预计阅读需要3分钟。摘要MySQL8.3创新版于2024年1月16号发布,该版本扩展了MySQL复制和组复制中使用
读TiDB源码聊设计:浅析HTAP的SQL优化器
tidbgo性能优化分布式系统
版本日期备注1.02024.2.18文章首发本文的的源码分析全部基于TiDB6.5来做分析。1.引子如果让你做一个分布式数据库的优化器,面对以下的SQL,你会想到什么好的方法去执行他们呢?SELECTid,nameFROMpersonWHEREage>=18orheight>180limit100;:从条件上看,我们看到条件其实是二选一的:age>=18orheight>180。基于这种情况,我们
从 20 多套 MySQL 到 1 套 TiDB丨骏伯网络综合运营管理平台应用实践
TiDB_PingCAP
tidb 分布式 云原生 数据库 TiDB
导读骏伯网络是一家聚焦移动互联网营销服务的公司,综合运营管理平台是其核心业务系统,包括营销系统、订单、支付以及与外部系统的交互服务接口。为满足多元化的业务发展需求,降低系统间交互链路的复杂性,提升业务连续性,以及实现降本增效的整体规划,骏伯网络选择将TiDB作为综合运营管理平台的底层数据库。经过上线实践证明,TiDB为骏伯在业务连续性、性能提升、数据资源整合、降本增效等方面带来了显著价值。未来,骏
通过 Prometheus 编写 TiDB 巡检脚本(脚本已开源,内附链接)
TiDB_PingCAP
prometheus tidb 开源 分布式 云原生 数据库
作者丨caiyfc来自神州数码钛合金战队神州数码钛合金战队是一支致力于为企业提供分布式数据库TiDB整体解决方案的专业技术团队。团队成员拥有丰富的数据库从业背景,全部拥有TiDB高级资格证书,并活跃于TiDB开源社区,是官方认证合作伙伴。目前已为10+客户提供了专业的TiDB交付服务,涵盖金融、证券、物流、电力、政府、零售等重点行业。背景笔者最近在驻场,发现这里的tidb集群是真的多,有将近150
使用 Coze 搭建 TiDB 助手
TiDB_PingCAP
数据库 开源 分布式 TiDB tidb
导读本文介绍了使用Coze平台搭建TiDB文档助手的过程。通过比较不同AIBot平台,突出了Coze在插件能力和易用性方面的优势。文章深入讨论了实现原理,包括知识库、functioncall、embedding模型等关键概念,最后成功演示了如何在Coze平台上快速创建TiDBHelpBot。本文作者Weaxs,TiDB社区布道师。引言目前市面上有很多搭建AIBot的平台和应用,开源的有langch
一篇文章彻底搞懂 TiDB 集群各种容量计算方式
TiDB_PingCAP
数据库 tidb TiDB 云原生 开源
作者丨hey-hoho来自神州数码钛合金战队神州数码钛合金战队是一支致力于为企业提供分布式数据库TiDB整体解决方案的专业技术团队。团队成员拥有丰富的数据库从业背景,全部拥有TiDB高级资格证书,并活跃于TiDB开源社区,是官方认证合作伙伴。目前已为10+客户提供了专业的TiDB交付服务,涵盖金融、证券、物流、电力、政府、零售等重点行业。背景TiDB集群的监控面板里面有两个非常重要、且非常常用的指
“分布式透明化”在杭州银行核心系统上线之思考
TiDB_PingCAP
分布式 云原生 tidb 数据库 银行
导读随着金融行业数字化转型的需求,银行核心系统的升级改造成为重要议题。杭州银行成功上线以TiDB为底层数据库的新一代核心业务系统,该实践采用应用与基础设施解耦、分布式透明化的设计开发理念,推动银行核心系统的整体升级。本文聚焦银行核心系统演进,结合TiDB在杭州银行新一代核心的实践,深入解析“分布式透明化”理念,希望能为同行业的转型升级提供参考。本文作者:韩锋,CCIA(中国计算机协会)常务理事,前
作业帮 x TiDB丨多元化海量数据业务的支撑
TiDB_PingCAP
数据库 tidb TiDB 云原生 开源
导读作业帮是一家成立于2015年的在线教育品牌,致力于用科技手段助力教育普惠。经过近十年的积累,作业帮运用人工智能、大数据等技术,为学生、老师、家长提供学习、教育解决方案,智能硬件产品等。随着公司产品和业务场景越来越丰富,数据量越来越大,业务方对数据库的使用需求也越来越多元化。本文介绍了作业帮对TiDB的探索历程,以及逐渐落地多个业务场景的使用实践。TiDB在作业帮的探索和推广作业帮内部最开始接触
TiDB 7.5.0 LTS 高性能数据批处理方案
TiDB_PingCAP
tidb 分布式 云原生 数据库
过去,TiDB由于不支持存储过程、大事务的使用也存在一些限制,使得在TiDB上进行一些复杂的数据批量处理变得比较复杂。TiDB在面向这种超大规模数据的批处理场景,其能力也一直在演进,其复杂度也变得越来越低:○从TiDB5.0开始,TiFlash支持MPP并行计算能力,在大批量数据上进行聚合、关联的查询性能有了极大的提升○到了TiDB6.1版本,引入了BATCHDML(https://docs.pi
作业帮 x TiDB丨多元化海量数据业务的支撑
tidb
导读作业帮是一家成立于2015年的在线教育品牌,致力于用科技手段助力教育普惠。经过近十年的积累,作业帮运用人工智能、大数据等技术,为学生、老师、家长提供学习、教育解决方案,智能硬件产品等。随着公司产品和业务场景越来越丰富,数据量越来越大,业务方对数据库的使用需求也越来越多元化。本文介绍了作业帮对TiDB的探索历程,以及逐渐落地多个业务场景的使用实践。TiDB在作业帮的探索和推广作业帮内部最开始接触
TiDB 7.5.0 LTS 高性能数据批处理方案
tidb数据库
过去,TiDB由于不支持存储过程、大事务的使用也存在一些限制,使得在TiDB上进行一些复杂的数据批量处理变得比较复杂。TiDB在面向这种超大规模数据的批处理场景,其能力也一直在演进,其复杂度也变得越来越低:○从TiDB5.0开始,TiFlash支持MPP并行计算能力,在大批量数据上进行聚合、关联的查询性能有了极大的提升○到了TiDB6.1版本,引入了BATCHDML(https://docs.pi
JeecgBoot集成TiDB,打造高效可靠的数据存储解决方案
TiDB简介TiDB是PingCAP公司自主设计、研发的开源分布式关系型数据库,同时支持在线事务处理与在线分析处理(HybridTransactionalandAnalyticalProcessing,HTAP)的融合型分布式数据库产品,具备水平扩容或者缩容、金融级高可用、实时HTAP、云原生的分布式数据库、兼容MySQL5.7协议和MySQL生态等重要特性。TIDB安装部署TiDB是一个分布式系
读TiDB源码聊设计:浅析HTAP的SQL优化器
tidbgo性能优化分布式系统
版本日期备注1.02024.2.18文章首发本文的的源码分析全部基于TiDB6.5来做分析。1.引子如果让你做一个分布式数据库的优化器,面对以下的SQL,你会想到什么好的方法去执行他们呢?SELECTid,nameFROMpersonWHEREage>=18orheight>180limit100;:从条件上看,我们看到条件其实是二选一的:age>=18orheight>180。基于这种情况,我们
使用 Coze 搭建 TiDB 助手
tidb数据库
导读本文介绍了使用Coze平台搭建TiDB文档助手的过程。通过比较不同AIBot平台,突出了Coze在插件能力和易用性方面的优势。文章深入讨论了实现原理,包括知识库、functioncall、embedding模型等关键概念,最后成功演示了如何在Coze平台上快速创建TiDBHelpBot。本文作者Weaxs,TiDB社区布道师。引言目前市面上有很多搭建AIBot的平台和应用,开源的有langch
从 20 多套 MySQL 到 1 套 TiDB丨骏伯网络综合运营管理平台应用实践
tidb数据库
导读骏伯网络是一家聚焦移动互联网营销服务的公司,综合运营管理平台是其核心业务系统,包括营销系统、订单、支付以及与外部系统的交互服务接口。为满足多元化的业务发展需求,降低系统间交互链路的复杂性,提升业务连续性,以及实现降本增效的整体规划,骏伯网络选择将TiDB作为综合运营管理平台的底层数据库。经过上线实践证明,TiDB为骏伯在业务连续性、性能提升、数据资源整合、降本增效等方面带来了显著价值。未来,骏
一篇文章彻底搞懂 TiDB 集群各种容量计算方式
tidb数据库
作者丨hey-hoho来自神州数码钛合金战队神州数码钛合金战队是一支致力于为企业提供分布式数据库TiDB整体解决方案的专业技术团队。团队成员拥有丰富的数据库从业背景,全部拥有TiDB高级资格证书,并活跃于TiDB开源社区,是官方认证合作伙伴。目前已为10+客户提供了专业的TiDB交付服务,涵盖金融、证券、物流、电力、政府、零售等重点行业。背景TiDB集群的监控面板里面有两个非常重要、且非常常用的指
TiDB in 2023, 一次简单的回顾丨PingCAP 唐刘
TiDB_PingCAP
开源 分布式 数据库 TiDB tidb
2023年已经过去,TiDB经过了一年的迭代,又往前进步了一点点,我们非常自豪的看到,TiDB正在不断地帮助我们的客户成功,包括但不限于:○首个云原生、分布式、全栈国产化银行核心业务系统投产上线丨TiDB×杭州银行○国产数据库的珠穆朗玛峰,到底在哪里?○ScalingTiDBTo1MillionQPS(https://blog.flipkart.tech/scaling-tidb-to-1-mil
TiDB 在医疗保障信息平台的应用实践
TiDB_PingCAP
tidb 开源 分布式 数据库 TiDB
文章介绍了TiDB在医疗保障信息平台中的应用。东软医保云应用管理平台通过与TiDB联合,成功满足了医疗保障业务中高并发、实时性和复杂查询的要求。在某地市医疗保障信息平台的实践中,TiDB分布式数据库有效实现了在线交易和实时分析服务,日均QPS达22,000,总数据量接近30TB,降低了系统开发和维护成本,推动医疗保障信息平台的数字化和智能化发展。医疗保障信息平台简介医疗保障信息平台是涉及国计民生的
首个云原生、分布式、全栈国产化银行核心业务系统投产上线丨TiDB × 杭州银行
tidb银行卡云原生分布式全栈
日前,杭州银行新一代核心业务系统成功投产上线。新核心系统是业内首个实际投产的云原生、分布式、全栈国产化的银行核心系统,是金融科技领域突破关键核心技术应用的重大实践。新核心系统自上线以来运行安全稳定,大幅提升了业务处理效率,已支撑日均交易量1000+万笔,平均交易耗时小于100毫秒,较原核心业务系统缩减54%,日终跑批的处理速度为原核心业务系统的2.1倍,能够有效支撑未来业务的快速发展。标志着杭州银
TiDB 在医疗保障信息平台的应用实践
tidb医疗it数据库信息技术
文章介绍了TiDB在医疗保障信息平台中的应用。东软医保云应用管理平台通过与TiDB联合,成功满足了医疗保障业务中高并发、实时性和复杂查询的要求。在某地市医疗保障信息平台的实践中,TiDB分布式数据库有效实现了在线交易和实时分析服务,日均QPS达22,000,总数据量接近30TB,降低了系统开发和维护成本,推动医疗保障信息平台的数字化和智能化发展。医疗保障信息平台简介医疗保障信息平台是涉及国计民生的
面向对象面向过程
3213213333332132
java
面向对象:把要完成的一件事,通过对象间的协作实现。
面向过程:把要完成的一件事,通过循序依次调用各个模块实现。
我把大象装进冰箱这件事为例,用面向对象和面向过程实现,都是用java代码完成。
1、面向对象
package bigDemo.ObjectOriented;
/**
* 大象类
*
* @Description
* @author FuJian
Java Hotspot: Remove the Permanent Generation
bookjovi
HotSpot
openjdk上关于hotspot将移除永久带的描述非常详细,http://openjdk.java.net/jeps/122
JEP 122: Remove the Permanent Generation
Author Jon Masamitsu
Organization Oracle
Created 2010/8/15
Updated 2011/
正则表达式向前查找向后查找,环绕或零宽断言
dcj3sjt126com
正则表达式
向前查找和向后查找
1. 向前查找:根据要匹配的字符序列后面存在一个特定的字符序列(肯定式向前查找)或不存在一个特定的序列(否定式向前查找)来决定是否匹配。.NET将向前查找称之为零宽度向前查找断言。
对于向前查找,出现在指定项之后的字符序列不会被正则表达式引擎返回。
2. 向后查找:一个要匹配的字符序列前面有或者没有指定的
BaseDao
171815164
seda
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
public class BaseDao {
public Conn
Ant标签详解--Java命令
g21121
Java命令
这一篇主要介绍与java相关标签的使用 终于开始重头戏了,Java部分是我们关注的重点也是项目中用处最多的部分。
1
[简单]代码片段_电梯数字排列
53873039oycg
代码
今天看电梯数字排列是9 18 26这样呈倒N排列的,写了个类似的打印例子,如下:
import java.util.Arrays;
public class 电梯数字排列_S3_Test {
public static void main(S
Hessian原理
云端月影
hessian原理
Hessian 原理分析
一. 远程通讯协议的基本原理
网络通信需要做的就是将流从一台计算机传输到另外一台计算机,基于传输协议和网络 IO 来实现,其中传输协议比较出名的有 http 、 tcp 、 udp 等等, http 、 tcp 、 udp 都是在基于 Socket 概念上为某类应用场景而扩展出的传输协
区分Activity的四种加载模式----以及Intent的setFlags
aijuans
android
在多Activity开发中,有可能是自己应用之间的Activity跳转,或者夹带其他应用的可复用Activity。可能会希望跳转到原来某个Activity实例,而不是产生大量重复的Activity。
这需要为Activity配置特定的加载模式,而不是使用默认的加载模式。 加载模式分类及在哪里配置
Activity有四种加载模式:
standard
singleTop
hibernate几个核心API及其查询分析
antonyup_2006
html .net Hibernate xml 配置管理
(一) org.hibernate.cfg.Configuration类
读取配置文件并创建唯一的SessionFactory对象.(一般,程序初始化hibernate时创建.)
Configuration co
PL/SQL的流程控制
百合不是茶
oracle PL/SQL编程 循环控制
PL/SQL也是一门高级语言,所以流程控制是必须要有的,oracle数据库的pl/sql比sqlserver数据库要难,很多pl/sql中有的sqlserver里面没有
流程控制;
分支语句 if 条件 then 结果 else 结果 end if ;
条件语句 case when 条件 then 结果;
循环语句 loop
强大的Mockito测试框架
bijian1013
mockito 单元测试
一.自动生成Mock类 在需要Mock的属性上标记@Mock注解,然后@RunWith中配置Mockito的TestRunner或者在setUp()方法中显示调用MockitoAnnotations.initMocks(this);生成Mock类即可。二.自动注入Mock类到被测试类 &nbs
精通Oracle10编程SQL(11)开发子程序
bijian1013
oracle 数据库 plsql
/*
*开发子程序
*/
--子程序目是指被命名的PL/SQL块,这种块可以带有参数,可以在不同应用程序中多次调用
--PL/SQL有两种类型的子程序:过程和函数
--开发过程
--建立过程:不带任何参数
CREATE OR REPLACE PROCEDURE out_time
IS
BEGIN
DBMS_OUTPUT.put_line(systimestamp);
E
【EhCache一】EhCache版Hello World
bit1129
Hello world
本篇是EhCache系列的第一篇,总体介绍使用EhCache缓存进行CRUD的API的基本使用,更细节的内容包括EhCache源代码和设计、实现原理在接下来的文章中进行介绍
环境准备
1.新建Maven项目
2.添加EhCache的Maven依赖
<dependency>
<groupId>ne
学习EJB3基础知识笔记
白糖_
bean Hibernate jboss webservice ejb
最近项目进入系统测试阶段,全赖袁大虾领导有力,保持一周零bug记录,这也让自己腾出不少时间补充知识。花了两天时间把“传智播客EJB3.0”看完了,EJB基本的知识也有些了解,在这记录下EJB的部分知识,以供自己以后复习使用。
EJB是sun的服务器端组件模型,最大的用处是部署分布式应用程序。EJB (Enterprise JavaBean)是J2EE的一部分,定义了一个用于开发基
angular.bootstrap
boyitech
AngularJS AngularJS API angular中文api
angular.bootstrap
描述:
手动初始化angular。
这个函数会自动检测创建的module有没有被加载多次,如果有则会在浏览器的控制台打出警告日志,并且不会再次加载。这样可以避免在程序运行过程中许多奇怪的问题发生。
使用方法: angular .
java-谷歌面试题-给定一个固定长度的数组,将递增整数序列写入这个数组。当写到数组尾部时,返回数组开始重新写,并覆盖先前写过的数
bylijinnan
java
public class SearchInShiftedArray {
/**
* 题目:给定一个固定长度的数组,将递增整数序列写入这个数组。当写到数组尾部时,返回数组开始重新写,并覆盖先前写过的数。
* 请在这个特殊数组中找出给定的整数。
* 解答:
* 其实就是“旋转数组”。旋转数组的最小元素见http://bylijinnan.iteye.com/bl
天使还是魔鬼?都是我们制造
ducklsl
生活 教育 情感
----------------------------剧透请原谅,有兴趣的朋友可以自己看看电影,互相讨论哦!!!
从厦门回来的动车上,无意中瞟到了书中推荐的几部关于儿童的电影。当然,这几部电影可能会另大家失望,并不是类似小鬼当家的电影,而是关于“坏小孩”的电影!
自己挑了两部先看了看,但是发现看完之后,心里久久不能平
[机器智能与生物]研究生物智能的问题
comsci
生物
我想,人的神经网络和苍蝇的神经网络,并没有本质的区别...就是大规模拓扑系统和中小规模拓扑分析的区别....
但是,如果去研究活体人类的神经网络和脑系统,可能会受到一些法律和道德方面的限制,而且研究结果也不一定可靠,那么希望从事生物神经网络研究的朋友,不如把
获取Android Device的信息
dai_lm
android
String phoneInfo = "PRODUCT: " + android.os.Build.PRODUCT;
phoneInfo += ", CPU_ABI: " + android.os.Build.CPU_ABI;
phoneInfo += ", TAGS: " + android.os.Build.TAGS;
ph
最佳字符串匹配算法(Damerau-Levenshtein距离算法)的Java实现
datamachine
java 算法 字符串匹配
原文:http://www.javacodegeeks.com/2013/11/java-implementation-of-optimal-string-alignment.html------------------------------------------------------------------------------------------------------------
小学5年级英语单词背诵第一课
dcj3sjt126com
english word
long 长的
show 给...看,出示
mouth 口,嘴
write 写
use 用,使用
take 拿,带来
hand 手
clever 聪明的
often 经常
wash 洗
slow 慢的
house 房子
water 水
clean 清洁的
supper 晚餐
out 在外
face 脸,
macvim的使用实战
dcj3sjt126com
mac vim
macvim用的是mac里面的vim, 只不过是一个GUI的APP, 相当于一个壳
1. 下载macvim
https://code.google.com/p/macvim/
2. 了解macvim
:h vim的使用帮助信息
:h macvim
java二分法查找
蕃薯耀
java二分法查找 二分法 java二分法
java二分法查找
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 2015年6月23日 11:40:03 星期二
http:/
Spring Cache注解+Memcached
hanqunfeng
spring memcached
Spring3.1 Cache注解
依赖jar包:
<!-- simple-spring-memcached -->
<dependency>
<groupId>com.google.code.simple-spring-memcached</groupId>
<artifactId>simple-s
apache commons io包快速入门
jackyrong
apache commons
原文参考
http://www.javacodegeeks.com/2014/10/apache-commons-io-tutorial.html
Apache Commons IO 包绝对是好东西,地址在http://commons.apache.org/proper/commons-io/,下面用例子分别介绍:
1) 工具类
2
如何学习编程
lampcy
java 编程 C++ c
首先,我想说一下学习思想.学编程其实跟网络游戏有着类似的效果.开始的时候,你会对那些代码,函数等产生很大的兴趣,尤其是刚接触编程的人,刚学习第一种语言的人.可是,当你一步步深入的时候,你会发现你没有了以前那种斗志.就好象你在玩韩国泡菜网游似的,玩到一定程度,每天就是练级练级,完全是一个想冲到高级别的意志力在支持着你.而学编程就更难了,学了两个月后,总是觉得你好象全都学会了,却又什么都做不了,又没有
架构师之spring-----spring3.0新特性的bean加载控制@DependsOn和@Lazy
nannan408
Spring3
1.前言。
如题。
2.描述。
@DependsOn用于强制初始化其他Bean。可以修饰Bean类或方法,使用该Annotation时可以指定一个字符串数组作为参数,每个数组元素对应于一个强制初始化的Bean。
@DependsOn({"steelAxe","abc"})
@Comp
Spring4+quartz2的配置和代码方式调度
Everyday都不同
代码 配置 spring4 quartz2.x 定时任务
前言:这些天简直被quartz虐哭。。因为quartz 2.x版本相比quartz1.x版本的API改动太多,所以,只好自己去查阅底层API……
quartz定时任务必须搞清楚几个概念:
JobDetail——处理类
Trigger——触发器,指定触发时间,必须要有JobDetail属性,即触发对象
Scheduler——调度器,组织处理类和触发器,配置方式一般只需指定触发
Hibernate入门
tntxia
Hibernate
前言
使用面向对象的语言和关系型的数据库,开发起来很繁琐,费时。由于现在流行的数据库都不面向对象。Hibernate 是一个Java的ORM(Object/Relational Mapping)解决方案。
Hibernte不仅关心把Java对象对应到数据库的表中,而且提供了请求和检索的方法。简化了手工进行JDBC操作的流程。
如
Math类
xiaoxing598
Math
一、Java中的数字(Math)类是final类,不可继承。
1、常数 PI:double圆周率 E:double自然对数
2、截取(注意方法的返回类型) double ceil(double d) 返回不小于d的最小整数 double floor(double d) 返回不大于d的整最大数 int round(float f) 返回四舍五入后的整数 long round