草稿

一、快速了解

1.scanf( )函数和gets( )函数都可用于输入字符串,但在功能上有区别。若想从键盘上输入字符串”hi hello”,则应该使用gets函数。

2.gets可以接收空格,回车结束,gets(s)是输入一行;而scanf(%s)遇到空格、回车和Tab键都会认为输入结束,所有它不能接收空格。

char string[15]; gets(string); /遇到回车认为输入结束/

scanf(“%s”,string); /遇到空格认为输入结束/

所以在输入整行时,应该使用gets输入。

二、详细分析
在C语言中,能构获取字符串的函数至少有两个:

scanf()

所在头文件:stdio.h

语法:scanf(“格式控制字符串”,变量地址列表);

接受字符串时:scanf(“%s”,字符数组名或指针);

gets()

所在头文件:stdio.h

语法:gets(字符数组名或指针);

两者在接受字符串时:

1.不同点:
scanf不能接受空格、制表符Tab、回车等;

而gets能够接受空格、制表符Tab和回车等;

scanf返回的为接收到的变量值的个数;

gets(str) 在读取成功的时候返回str,str保存的是成功读入的内容 在失败的时候返回NULL,str的内容保持不变;

2.相同点:
字符串接受结束后自动加’\0’。

例1:

[cpp] view plain copy

include

include

include

include

### 如何在 MySQL 中创建或管理草稿 #### 创建草稿表 为了创建一个用于存储草稿的表,可以定义一张具有特定结构的表来保存未完成的内容。以下是创建草稿表的一个示例: ```sql CREATE TABLE draft_table ( id INT AUTO_INCREMENT PRIMARY KEY, title VARCHAR(255) NOT NULL COMMENT '标题', content TEXT COMMENT '内容', state TINYINT DEFAULT 0 COMMENT '状态:0 草稿;1 已发布', created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间' ); ``` 此表设计中包含了 `state` 字段[^5],用来区分记录的状态(草稿还是已发布)。默认情况下,新插入的记录会被标记为草稿。 --- #### 插入草稿数据 向上述草稿表中插入一条新的草稿记录可以通过以下 SQL 语句实现: ```sql INSERT INTO draft_table (title, content, state) VALUES ('我的文章', '这是文章的内容...', 0); ``` 这里将 `state` 设置为 `0`,表示该条目是一个草稿。 --- #### 查询草稿数据 如果需要查询所有的草稿记录,则可以执行如下查询操作: ```sql SELECT * FROM draft_table WHERE state = 0; ``` 这条命令会返回所有处于草稿状态 (`state=0`) 的记录。 --- #### 更新草稿至已发布 当草稿准备好被正式发布时,可以将其状态更改为已发布的状态(即 `state=1`),例如: ```sql UPDATE draft_table SET state = 1 WHERE id = 1; ``` 这一步骤假设我们正在修改 ID 为 `1` 的那条记录,并将其从草稿转为已发布状态。 --- #### 删除草稿 对于不再需要的草稿,可以直接删除对应的记录: ```sql DELETE FROM draft_table WHERE id = 2 AND state = 0; ``` 这里的条件确保只删除那些尚未发布的草稿记录。 --- #### 使用存储过程清理草稿 通过 Navicat 创建一个存储过程,定期自动清除超过一定天数的草稿记录。下面展示了一个简单的例子[^4]: ```sql DELIMITER $$ CREATE PROCEDURE cleanup_drafts() BEGIN DELETE FROM draft_table WHERE state = 0 AND DATEDIFF(CURDATE(), created_at) > 7; END$$ DELIMITER ; ``` 这个存储过程的作用是从 `draft_table` 表中移除所有超过七天且仍处于草稿状态的记录。 --- #### 配置 Binlog 参数支持 CDC 特性 如果您计划利用 Flink 等工具实时捕获 MySQL 数据库中的变化事件,那么还需要调整 MySQL 的配置文件以启用完整的行日志模式。具体来说,在数据库管理界面下的参数设置部分,应将 `binlog_row_image` 设定为 FULL 值][^[^23]。这样做的目的是为了让变更数据捕捉功能能够正常运作。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值