当前位置: 首页 > article >正文

SQLite 语法

SQLite 语法

SQLite 是一种轻量级的数据库管理系统,它遵循 SQL(结构化查询语言)标准。SQLite 的语法相对简单,易于学习和使用。本文将详细介绍 SQLite 的基本语法,包括数据定义语言(DDL)、数据操作语言(DML)、事务控制以及查询等。

数据定义语言(DDL)

数据定义语言用于创建、修改和删除数据库中的表和其他对象。

创建表

CREATE TABLE table_name (
    column1 datatype,
    column2 datatype,
    column3 datatype,
    ...
);

例如,创建一个名为 students 的表,包含 idnameage 三个字段:

CREATE TABLE students (
    id INTEGER PRIMARY KEY,
    name TEXT,
    age INTEGER
);

修改表

ALTER TABLE table_name
ADD column_name datatype;

例如,向 students 表中添加一个 grade 字段:

ALTER TABLE students
ADD grade TEXT;

删除表

DROP TABLE table_name;

例如,删除 students 表:

DROP TABLE students;

数据操作语言(DML)

数据操作语言用于插入、更新和删除表中的数据。

插入数据

INSERT INTO table_name (column1, column2, column3, ...)
VALUES (value1, value2, value3, ...);

例如,向 students 表中插入一条数据:

INSERT INTO students (name, age, grade)
VALUES ('Alice', 20, 'A');

更新数据

UPDATE table_name
SET column1 = value1, column2 = value2, ...
WHERE condition;

例如,将 students 表中名为 'Alice' 的学生的年龄更新为 21:

UPDATE students
SET age = 21
WHERE name = 'Alice';

删除数据

DELETE FROM table_name
WHERE condition;

例如,删除 students 表中年龄大于 21 的学生:

DELETE FROM students
WHERE age > 21;

事务控制

SQLite 中的事务用于确保数据库的一致性。事务可以是隐式的或显式的。

开始事务

BEGIN TRANSACTION;

提交事务

COMMIT;

回滚事务

ROLLBACK;

例如,一个简单的事务处理:

BEGIN TRANSACTION;
INSERT INTO students (name, age, grade)
VALUES ('Bob', 22, 'B');
UPDATE students
SET age = 23
WHERE name = 'Bob';
COMMIT;

如果在这个过程中发生错误,可以使用 ROLLBACK 回滚到事务开始前的状态。

查询

查询是数据库操作中最常用的操作之一。SQLite 支持各种类型的查询,包括简单查询、连接查询、子查询等。

简单查询

SELECT column1, column2, ...
FROM table_name
WHERE condition;

例如,查询 students 表中所有学生的姓名和年龄:

SELECT name, age
FROM students;

连接查询

SQLite 支持多种类型的连接,包括内连接、左连接和右连接。

SELECT columns
FROM table1
JOIN table2
ON table1.column = table2.column;

例如,假设有一个 courses 表,查询 students 表和 courses 表的连接结果:

SELECT students.name, courses.course_name
FROM students
JOIN courses
ON students.id = courses.student_id;

子查询

子查询是嵌套在另一个查询中的查询。

SELECT column1, column2, ...
FROM table_name
WHERE column IN (SELECT column FROM table_name WHERE condition);

例如,查询 students 表中年龄大于平均年龄的学生:

SELECT name, age
FROM students
WHERE age > (SELECT AVG(age) FROM students);

总结

SQLite 的语法相对简单,但功能强大。通过掌握上述基本语法,您可以进行大多数常见的数据库操作。无论是数据定义、数据操作还是查询,SQLite 都能提供高效且可靠的支持。随着您对 SQLite 的进一步学习和实践,您将能够利用它的更多高级功能来处理更复杂的数据库任务。


http://www.kler.cn/a/375827.html

相关文章:

  • 模拟栈的实现
  • 替代BD63006/罗姆应用于吸尘器⾏⾛轮、卷发器,⽔泵,⼩⻛扇等驱动芯片GC4928介绍
  • img 标签的 object-fit 属性
  • 显示器接口
  • YoloV8改进策略:Block改进|RFE模块,提高小物体的识别精度|即插即用|代码+修改过程
  • 什么是FUSE用户态文件系统
  • 【React】配置图标和题目
  • 【系统设计】深入了解四种通信机制:从同步到异步的演变
  • 【一网打尽】前端Vue和React项目的构建
  • 安装 Visual Studio
  • PPT素材、模板免费下载!
  • Qt 使用QXlsx将QTableView数据导出到Excel表格
  • Ceph 学习指南 集群部署【 cephadm 】
  • 嵌入式硬件设计:智能设备的核心
  • 人工智能中的学习方法详解
  • 盖电子章的软件
  • Tomcat安装和配置(超详细)
  • [运维] 服务器本地网络可用性检查脚本
  • 【深度学习】实验 — 动手实现 GPT【三】:LLM架构、LayerNorm、GELU激活函数
  • 基于单片机的宠物自动喂食系统的设计
  • 【Unity实战笔记】第二十二 · 基于SMB的角色控制中遇到的一些问题(斜坡移动鬼畜、落地卡顿、角色突进、头发动画失效等)
  • (五)关于InternVL2的模型训练二(如何训练目标定位模型)
  • IDEA中通义灵码的使用技巧
  • Python 游戏开发库比较与示例
  • vue当中的$使用方法
  • leetcode71:简化路径