SQL基础
SQLite 数据库简介
SQLite 是一个开源的、 内嵌式的关系型数据库, 第一个版本诞生于 2000 年 5 月, 目前最高版本为 SQLite3。
下载地址: https://www.sqlite.org/download.html
菜鸟教程 : https://www.runoob.com/sqlite/sqlite-tutorial.html
Linux 下 字符界面
Linux 下 图形界面
该教程没有使用这个, 因为我下载时找不到
SQLite 特性:
零配置
灵活
可移植
自由的授权
紧凑
可靠
简单
易用
SQL 语句基础
SQL 是一种结构化查询语言(Structured Query Language) 的缩写, SQL 是一种专门用来与数据库通信的语言。
SQL 目前已成为应用最广的数据库语言。
SQL 已经被众多商用数据库管理系统产品所采用, 不同的数据库管理系统在其实践过程中都对 SQL 规范作了某些编改和扩充。 故不同数据库管理系统之间的 SQL 语言不能完全相互通用。
SQLite 数据类型 :
一般数据采用固定的静态数据类型, 而 SQLite 采用的是动态数据类型, 会根据存入值自动判断。
SQLite 具有以下五种基本数据类型 :
integer
: 带符号的整型(最多 64 位) 。real
: 8 字节表示的浮点类型。text
: 字符类型, 支持多种编码(如 UTF-8、 UTF-16) , 大小无限制。blob
: 任意类型的数据, 大小无限制。BLOB
(binary large object)二进制大对象, 使用二进制保存数据null
: 表示空值
对数据库文件 SQL 语句:
创建、 打开数据库:
当*.db 文件不存在时, sqlite 会创建并打开数据库文件。
当*.db 文件存在时, sqlite 会打开数据库文件。
SQL 的语句格式:
所有的 SQL 语句都是以分号结尾的, SQL 语句不区分大小写。 两个减号“--” 则代表注释。
关系数据库的核心操作:
创建、 修改、 删除表
添加、 修改、 删除行
查表
创建表: create 语句
语法:
创建一表格该表包含 3 列, 列名分别是: “id” 、 “name” 、 “addr” 。
创建表: create 语句 (设置主键)
在用 sqlite 设计表时, 每个表都可以通过 primary key
手动设置主键, 每个表只能有一个主键, 设置为主键的列数据不可以重复。
语法:
查看表: .table
查看数据表的结构:
退出数据库命令
图形化的软件查看表的结构 :
修改表: alter 语句
在已有的表中添加或删除列以及修改表名。(添加、 删除-sqlite3 暂不支持、 重命名)
语法 :
语法: (alter 修改表名)
删除表: drop table 语句
用于删除表(表的结构、 属性以及表的索引也会被删除)
语法:
插入新行: insert into 语句(全部赋值)
给一行中的所有列赋值。
当列值为字符串时要加上‘ ’
号。
语法:
插入新行: insert into 语句部分赋值)
给一行中的部分列赋值
语法:
修改表中的数据: update 语句
使用 where 根据匹配条件, 查找一行或多行, 根据查找的结果修改表中相应行的列值(修改哪一列由列名指定)。
语法:
匹配: where 子句
where 子句用于规定匹配的条件。
匹配条件语法:
当表中有多列、 多行符合匹配条件时会修改相应的多行。 当匹配条件为空时则匹配所有。
当表中有多列、 多行符合匹配条件时会修改相应的多行 :
查询
插入
查询
修改
查看
当匹配条件为空时则匹配所有 :
修改 :
删除表中的数据: delete 语句
使用 where 根据匹配条件, 查找一行或多行, 根据查找的结果删除表中的查找到的行。
当表中有多列、 多行符合匹配条件时会删除相应的多行。
语法:
删除
查看
查询: select 语句
用于从表中选取数据, 结果被存储在一个结果表中(称为结果集) 。
星号(*) 是选取所有列的通配符
语法:
查看
列名显示
左对齐
匹配条件语法
数据库提供了丰富的操作符配合 where 子句实现了多种多样的匹配方法。
in 操作符
and 操作符
or 操作符
between and 操作符
like 操作符
not 操作符
in
允许我们在 where 子句中规定多个值。
匹配条件语法:
and
可在 where 子语句中把两个或多个条件结合起来(多个条件之间是与的关系) 。
匹配条件语法:
or
可在 where 子语句中把两个或多个条件结合起来(多个条件之间是或的关系) 。
匹配条件语法:
between A and B
会选取介于 A、 B 之间的数据范围。 这些值可以是数值、 文本或者日期。
匹配字符串时会以 ascii 顺序匹配。
不同的数据库对 between A and B 操作符的处理方式是有差异的。
有些数据库包含 A 不包含 B。
有些包含 B 不包含 A
有些既不包括 A 也不包括 B。
有些既包括 A 又包括 B
匹配条件语法:
like
用于模糊查找
匹配条件语法:
若列值为数字 , 相当于列名=列值
若列值为字符串 , 可以用通配符“ % ” 代表缺少的字符(一个或多个) 。
not
可取出原结果集的补集
匹配条件语法:
order by 语句
根据指定的列对结果集进行排序。
默认按照升序对结果集进行排序, 可使用 desc
关键字按照降序对结果集进行排序。
升序
降序
事务
事务(Transaction) 可以使用 BEGIN TRANSACTION
命令或简单的 BEGIN
命令来启动。 此类事务通常会持续执行下去, 直到遇到下一个 COMMIT
或 ROLLBACK
命令。 不过在数据库关闭或发生错误时, 事务处理也会回滚。 以下是启动一个事务的简单语法:
在 SQLite 中, 默认情况下, 每条 SQL 语句自成事务。
begin
: 开始一个事务, 之后的所有操作都可以取消
commit
: 使 begin 后的所有命令得到确认。
rollback
: 取消 begin 后的所有操作。
Last updated