数据库知识初步汇总

创建标签表格:

sql 复制代码
CREATE TABLE IF NOT EXISTS labels (
    标签ID INTEGER PRIMARY KEY,
    标签名称 TEXT
);

创建文本与标签的关联表格:

sql 复制代码
CREATE TABLE IF NOT EXISTS 文本标签 (
    文本ID INTEGER,
    标签ID INTEGER,
    FOREIGN KEY (文本ID) REFERENCES texts(编号),
    FOREIGN KEY (标签ID) REFERENCES labels(标签ID)
);

给文本贴标签:

sql 复制代码
-- 假设文本ID为1的文本贴上了标签ID为1和2的标签
INSERT INTO 文本标签 (文本ID, 标签ID) VALUES (1, 1);
INSERT INTO 文本标签 (文本ID, 标签ID) VALUES (1, 2);

查询特定文本的标签:

sql 复制代码
-- 查询编号为1的文本的标签
SELECT 文本.编号, 文本.文本, labels.标签名称
FROM texts
JOIN 文本标签 ON texts.编号 = 文本标签.文本ID
JOIN labels ON 文本标签.标签ID = labels.标签ID
WHERE 文本.编号 = 1;

复制代码
数据库是
input输入多行文本,允许特殊字符串
按"# ꧂ ꧁"结束一个文本输入
无限循环

你想要创建一个数据库,允许用户输入多行文本,并在输入特殊字符串"# ꧂ ꧁"时结束输入,然后再次开始新的文本输入,是吗?这种情况下,你可以使用以下SQL语句创建一个表格来存储这些文本:

sql 复制代码
CREATE TABLE IF NOT EXISTS 文本输入 (
    编号 INTEGER PRIMARY KEY,
    文本内容 TEXT,
    输入时间 TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

然后,你可以编写一个程序或者脚本来实现无限循环,接受用户的输入并将其插入到数据库中。这里提供一个示例的Python脚本,使用SQLite数据库来实现这个功能:

python 复制代码
import sqlite3

# 连接到数据库文件(如果不存在会自动创建)
conn = sqlite3.connect('text_input.db')
cursor = conn.cursor()

# 创建文本输入表格
cursor.execute('''CREATE TABLE IF NOT EXISTS 文本输入 (
                    编号 INTEGER PRIMARY KEY,
                    文本内容 TEXT,
                    输入时间 TIMESTAMP DEFAULT CURRENT_TIMESTAMP
                )''')

# 无限循环接受用户输入并插入数据库
while True:
    文本 = input('请输入文本内容,以"# ꧂ ꧁"结束:\n')
    if 文本.strip() == '# ꧂ ꧁':
        break
    else:
        # 插入文本到数据库
        cursor.execute('''INSERT INTO 文本输入 (文本内容) VALUES (?)''', (文本,))
        conn.commit()

# 关闭数据库连接
conn.close()

这个Python脚本会持续接受用户输入文本,直到输入"# ꧂ ꧁"时结束并退出循环,然后将文本内容插入到名为"文本输入"的数据库表格中。你可以根据实际需求调整代码和数据库结构。

#有查询和统计行#

如果你想要实现查询和统计已经输入的文本行的功能,你可以修改上面的Python脚本来实现。以下是一个示例,演示如何查询数据库中的文本行以及进行一些基本的统计:

python 复制代码
import sqlite3

# 连接到数据库文件(如果不存在会自动创建)
conn = sqlite3.connect('text_input.db')
cursor = conn.cursor()

# 查询所有文本行
cursor.execute('''SELECT * FROM 文本输入''')
rows = cursor.fetchall()

# 打印所有文本行
print("已输入的文本行:")
for row in rows:
    print(row)

# 统计已输入的文本行数量
num_rows = len(rows)
print("已输入的文本行数量:", num_rows)

# 关闭数据库连接
conn.close()

这个示例Python脚本会查询数据库中的所有文本行,并打印出来。然后,它会统计已输入的文本行的数量并打印出来。你可以根据需要修改这个脚本以实现更复杂的查询和统计功能。

相关推荐
冒泡的肥皂13 分钟前
MVCC初学demo(一
数据库·后端·mysql
.Shu.1 小时前
Redis Reactor 模型详解【基本架构、事件循环机制、结合源码详细追踪读写请求从客户端连接到命令执行的完整流程】
数据库·redis·架构
yatingliu20192 小时前
HiveQL | 个人学习笔记
hive·笔记·sql·学习
中科米堆2 小时前
中科米堆CASAIM自动化三维测量设备测量汽车壳体直径尺寸
运维·自动化·汽车·视觉检测
薛晓刚4 小时前
当MySQL的int不够用了
数据库
SelectDB技术团队4 小时前
Apache Doris 在菜鸟的大规模湖仓业务场景落地实践
数据库·数据仓库·数据分析·apache doris·菜鸟技术
星空下的曙光5 小时前
mysql 命令语法操作篇 数据库约束有哪些 怎么使用
数据库·mysql
小楓12015 小时前
MySQL數據庫開發教學(一) 基本架構
数据库·后端·mysql
染落林间色5 小时前
达梦数据库-实时主备集群部署详解(附图文)手工搭建一主一备数据守护集群DW
数据库·sql
颜颜yan_5 小时前
企业级时序数据库选型指南:从传统架构向智能时序数据管理的转型之路
数据库·架构·时序数据库