七天.NET 8操作SQLite入门到实战 - 第三天SQLite快速入门

前言

今天我们花费一个小时快速了解SQLite数据类型、SQLite常用命令和语法。

七天.NET 8操作SQLite入门到实战详细教程

SQLite数据类型

以下是SQLite常见的五种数据类型及其详细描述:

数据类型 描述
NULL 空值。
INTEGER 值是一个带符号的整数,根据值的大小存储在1、2、3、4、6或8字节中。
REAL 浮点数字,存储为8-byte IEEE浮点数。
TEXT 文本字符串,使用数据库编码(UTF-8、UTF-16BE或UTF-16LE)存储。
BLOB 二进制对象。

SQLite日期时间数据展示和操作

在SQLite中,日期时间数据可以使用以下几种方式表示:

  1. 文本格式:日期时间可以以文本形式存储在SQLite的文本字段中,常见的日期时间格式包括"YYYY-MM-DD HH:MM:SS"(如"2023-11-20 15:05:52")或其他类似的格式。

  2. 整数值格式:日期时间也可以用整数或实数类型来表示,例如Unix时间戳(从1970年1月1日开始的秒数)等。

  3. SQLite内置的日期和时间函数:SQLite支持内置的日期和时间函数,包括DATE、TIME和TIMESTAMP等。这些内置函数可以用来操作日期、时间或日期时间的组合。

SQLite常用命令

输出帮助信息:
复制代码
.help

创建一个新的数据库文件:

复制代码
在命令提示符下,输入以下命令来打开SQLite命令行:sqlite3
.open MyTest.db

建立或打开数据库文件:

复制代码
sqlite3 MyTest.db

查看数据库文件信息命令:

复制代码
.database

查看所有表的创建语句:

复制代码
.schema

查看指定表的创建语句:

复制代码
.schema UserInfo

以SQL语句的形式列出表内容:

复制代码
.dump UserInfo

列出当前显示格式的配置:

复制代码
.show

退出SQLite终端命令:

复制代码
.quit

复制代码
.exit

SQLite常用语法

SQLite是一种嵌入式关系型数据库,它支持SQL语言。大部分标准的SQL语法在SQLite中都可以使用,但也有一些特性和限制。

  • 以下是SQLite常用的SQL语法(请注意,具体语法细节可能会因版本和环境而有所不同,我当前使用的是SQLite3):

创建表:

复制代码
CREATE TABLE school (
    ID INTEGER PRIMARY KEY,
    school_name TEXT,
    school_address TEXT
);

插入数据:

复制代码
INSERT INTO school (ID, school_name, school_address)
VALUES (1, '追逐时光者学校', '北京市某区某街道');

查询数据:

复制代码
SELECT ID, school_name, school_address
FROM school
WHERE school_name = '追逐时光者学校';

更新数据:

复制代码
UPDATE school
SET school_address = '深圳南山区'
WHERE ID = 1;

删除数据:

复制代码
DELETE FROM school
WHERE ID = 1;

组合查询:

复制代码
SELECT s.school_name, s.school_address, t.teacher_name
FROM school s
JOIN teacher t ON s.ID = t.school_ID;

排序数据:

复制代码
SELECT ID, school_name, school_address
FROM school
ORDER BY school_name ASC;

聚合函数:

复制代码
SELECT COUNT(*) FROM school;
SELECT MAX(ID) FROM school;

索引操作:

复制代码
-- 创建索引
CREATE INDEX idx_school_name ON school (school_name);

-- 删除索引
DROP INDEX idx_school_name;
相关推荐
心灵宝贝9 分钟前
libopenssl-1_0_0-devel-1.0.2p RPM 包安装教程(openSUSE/SLES x86_64)
linux·服务器·数据库
张人玉2 小时前
C# 通讯关键类的API
开发语言·c#
程序新视界2 小时前
MySQL中,IS NULL和IS NOT NULL不会走索引?错!
数据库·mysql·dba
wdfk_prog2 小时前
闹钟定时器(Alarm Timer)初始化:构建可挂起的定时器基础框架
java·linux·数据库
许长安2 小时前
Redis(二)——Redis协议与异步方式
数据库·redis·junit
java_python源码3 小时前
python高校心理健康服务小程序(源码+文档+调试+基础修改+答疑)
数据库·sqlite
简色3 小时前
题库批量(文件)导入的全链路优化实践
java·数据库·mysql·mybatis·java-rabbitmq
点灯小铭4 小时前
基于单片机的自动存包柜设计
数据库·单片机·mongodb·毕业设计·课程设计
失散134 小时前
软件设计师——09 数据库技术基础
数据库·软考·软件设计师
养生技术人5 小时前
Oracle OCP认证考试题目详解082系列第53题
数据库·sql·oracle·database·开闭原则·ocp