mysql 中 偏移_MySQL 限制和偏移关系

示例

考虑下users表:ID用户名1用户1

2用户2

3用户3

4用户4

5用户5

为了限制SELECT查询结果集中的行数,该LIMIT子句可以与一个或两个正整数一起用作参数(包括零)。

LIMIT 有一个参数的子句

使用一个参数时,结果集将仅被约束为以以下方式指定的数字:

SELECT * FROM users ORDER BY id ASC LIMIT 2ID用户名1用户1

2用户2

如果参数的值为0,则结果集将为空。

还要注意,该ORDER BY子句可能很重要,以便指定将要显示的结果集的第一行(按另一列排序时)。

LIMIT有两个参数的子句

在LIMIT子句中使用两个参数时:第一个参数表示将要从中显示结果集行的行–该数字通常被称为offset,因为它表示受约束结果集的初始行之前的行。这允许自变量0作为值接收,因此考虑了非约束结果集的第一行。

该第二参数指定在结果集中(所述一个参数的例子同样地)将被返回的行的最大数量。

因此查询:

SELECT * FROM users ORDER BY id ASC LIMIT 2, 3

呈现以下结果集:ID用户名3用户3

4用户4

5用户5

注意,当offset参数为时0,结果集将等效于一个参数LIMIT子句。这意味着以下两个查询:

SELECT * FROM users ORDER BY id ASC LIMIT 0, 2

SELECT * FROM users ORDER BY id ASC LIMIT 2

产生相同的结果集:ID用户名1用户1

2用户2

OFFSET 关键字:替代语法

LIMIT具有两个参数的子句的另一种语法包括以OFFSET下列方式在第一个参数之后使用关键字:

SELECT * FROM users ORDER BY id ASC LIMIT 2 OFFSET 3

该查询将返回以下结果集:ID用户名3用户3

4用户4

注意,在这种替代语法中,参数的位置已切换:第一个参数表示结果集中要返回的行数;

该第二参数表示偏移。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
限时福利1:购课进答疑群专享柳峰(刘运强)老师答疑服务 为什么需要掌握高性能的MySQL实战? 由于互联网产品用户量大、高并发请求场景多,因此对MySQL的性能、可用性、扩展性都提出了很高的要求。使用MySQL解决大量数据以及高并发请求已经是程序员的必备技能,也是衡量一个程序员能力和薪资的标准之一。 为了让大家快速系统了解高性能MySQL核心知识全貌,我为你总结了「高性能 MySQL 知识框架图」,帮你梳理学习重点,建议收藏! 【课程设计】 课程分为四大篇章,将为你建立完整的 MySQL 知识体系,同时将重点讲解 MySQL 底层运行原理、数据库的性能调优、高并发、海量业务处理、面试解析等。 一、性能优化篇: 主要包括经典 MySQL 问题剖析、索引底层原理和事务与锁机制。通过深入理解 MySQL 的索引结构 B+Tree ,学员能够从根本上弄懂为什么有些 SQL 走索引、有些不走索引,从而彻底掌握索引的使用和优化技巧,能够避开很多实战遇到的“坑”。 二、MySQL 8.0新特性篇: 主要包括窗口函数和通用表表达式。企业的许多报表统计需求,如果不采用窗口函数,用普通的 SQL 语句是很难实现的。 三、高性能架构篇: 主要包括主从复制和读写分离。在企业的生产环境,很少采用单台MySQL节点的情况,因为一旦单个节点发生故障,整个系统都不可用,后果往往不堪设想,因此掌握高可用架构的实现是非常有必要的。 四、面试篇: 程序员获得工作的第一步,就是高效的准备面试,面试篇主要从知识点回顾总结的角度出发,结合程序员面试高频MySQL问题精讲精练,帮助程序员吊打面试官,获得心仪的工作机会。
Flink将偏移量保存到MySQL可以通过实现Flink的Checkpoint和Savepoint机制,将每个任务的状态和偏移量保存到MySQL。具体步骤如下: 1. 首先,需要在Flink作业启用Checkpoint和Savepoint机制,可以通过以下代码启用: ``` StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment(); env.enableCheckpointing(5000); env.setStateBackend(new FsStateBackend("hdfs://localhost:9000/flink/checkpoints")); ``` 2. 然后,需要在Flink作业实现Checkpoint和Savepoint的回调函数。在回调函数,可以将每个任务的状态和偏移量保存到MySQL。以下是一个简单的例子: ``` public class OffsetCheckpoint implements ListCheckpointed<Long> { private Long offset = 0L; private Connection connection; public OffsetCheckpoint() { try { Class.forName("com.mysql.jdbc.Driver"); connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "password"); } catch (ClassNotFoundException | SQLException e) { e.printStackTrace(); } } @Override public List<Long> snapshotState(long checkpointId, long timestamp) throws Exception { PreparedStatement statement = connection.prepareStatement("INSERT INTO offsets (checkpoint_id, offset) VALUES (?, ?)"); statement.setLong(1, checkpointId); statement.setLong(2, offset); statement.executeUpdate(); return Collections.singletonList(offset); } @Override public void restoreState(List<Long> state) throws Exception { if (!state.isEmpty()) { offset = state.get(0); } } } ``` 3. 最后,在Flink作业调用Checkpoint和Savepoint回调函数。以下是一个简单的例子: ``` DataStreamSource<String> stream = env.addSource(new FlinkKafkaConsumer<>("topic", new SimpleStringSchema(), properties)); stream .map(new MapFunction<String, String>() { @Override public String map(String value) throws Exception { // process data return value; } }) .addSink(new SinkFunction<String>() { @Override public void invoke(String value, Context context) throws Exception { // save offset OffsetCheckpoint checkpoint = new OffsetCheckpoint(); checkpoint.offset = context.currentWatermark(); env.addOperatorStateChangeListener(checkpoint); env.getCheckpointConfig().setCheckpointInterval(5000); } }); env.execute("job"); ``` 在以上代码,我们定义了一个名为`OffsetCheckpoint`的类,该类实现了Flink的`ListCheckpointed`接口。在`invoke`方法,我们创建了一个`OffsetCheckpoint`实例,并将当前任务的偏移量保存到该实例。然后,我们将`OffsetCheckpoint`实例添加到Flink作业的状态变化监听器,并设置Checkpoint间隔为5000毫秒。 以上就是将Flink的偏移量保存到MySQL的基本步骤。需要注意的是,在实现过程还需要考虑异常处理、连接池管理等问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值