SQL学习笔记

DDL概述

DDL(Data Definition Language,数据定义语言)用于定义和管理数据库中的所有对象的语言,包括创建、修改、删除数据库、表、索引、视图、存储过程等

  • CREATE - 创建数据库对象(数据库、表、索引、视图等)
  • ALTER - 修改数据库对象的结构
  • DROP - 删除数据库对象

创建表

sql 复制代码
create table if not exists emp
(
    id     text,
    name   text,
    age    int,
    gender text
);

查看表中的字段

sql 复制代码
/*
这里会展示出所有的字段, 而不是显示每个字段的值
PRAGMA:是 SQLite 中用于查询或修改数据库内部配置的特殊命令。
table_info:是 PRAGMA 的一个参数,用于获取指定表的列信息。
emp:是表名,这里可以替换为任何你想查看的表名。

输出列说明:
name 列名 
type  列的数据类型(在 SQLite 中,数据类型是动态的,这里显示的是创建表时声明的类型)
notnull 该列是否允许 NULL 值,1 表示不允许,0 表示允许
dflt_value 该列的默认值,如果没有默认值则为 NULL
pk 该列是否为主键,1 表示是主键(或主键的一部分),0 表示不是
*/

PRAGMA  table_info (emp);

修改表中的字段

sql 复制代码
// - 添加字段
alter table emp add column nick_name text;

// - 修改字段
alter table emp rename id to uid;

// - 删除字段
alter table emp drop nick_name;

删除表

sql 复制代码
drop table emp;

DML概述

DML(Data Manipulation Language)

  • INSERT - 插入新数据
  • UPDATE - 更新现有数据
  • DELETE - 删除数据

DML使用

插入数据

sql 复制代码
// - 单条插入
insert into emp values ('Z-0001', 'n1', 11, '男');
insert into emp(uid, name, age, gender) values ('Z-0001', 'n1', 11, '男');

// - 多条插入
insert into emp values ('Z-0001', 'n1', 11, '男'), ('Z-0002', 'n2', 22, '女'),('Z-0003', 'n3', 33, '男');
insert into emp(uid, name, age, gender) values ('Z-0001', 'n1', 11, '男'), ('Z-0002', 'n2', 22, '女'),('Z-0003', 'n3', 33, '男');

// -  其他表插入无条件
insert into emp select * from  emp1;
insert into emp(uid, name, age, gender) select * from  emp1;
insert into emp(uid, name, age, gender) select uid, name, age, gender from  emp1;

// -  其他表插入有条件
insert into emp select * from  emp1 where age > 10;
insert into emp(uid, name, age, gender) select * from  emp1 where age > 10;
insert into emp(uid, name, age, gender) select uid, name, age, gender from  emp1;

修改数据

sql 复制代码
// - 指定一列数据更新
update emp set gender = '女' where uid = 'Z-0003';

// - 指定多列数据更新
update emp set gender = '女', uid = 'Z-0004', name = 'n4' where uid = 'Z-0003';

删除数据

sql 复制代码
// - 删除指定的一行
delete from emp where uid = 'Z-0003';

// - 删除指定的多行
delete from emp where uid in ('Z-0001', 'Z-0002', 'Z-0003');

// - 删除所有行
delete from emp;
相关推荐
廿一夏2 小时前
MySql存储引擎与索引
数据库·sql·mysql
辰海Coding2 小时前
MiniSpring框架学习笔记-解决循环依赖的简化IoC容器
笔记·学习
晓梦林2 小时前
cp520靶场学习笔记
android·笔记·学习
心中有国也有家3 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
玄米乌龙茶1233 小时前
LLM成长笔记(三):API 开发基础
笔记
Upsy-Daisy3 小时前
AI Agent 项目学习笔记(八):Tool Calling 工具调用机制总览
人工智能·笔记·学习
lzhdim3 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
LuminousCPP5 小时前
数据结构 - 线性表第四篇:C 语言通讯录优化升级全记录(踩坑 + 思考)
c语言·开发语言·数据结构·经验分享·笔记·学习
魔法阵维护师5 小时前
从零开发游戏需要学习的c#模块,第十四章(保存和加载)
学习·游戏·c#
_李小白6 小时前
【android opencv学习笔记】Day 17: 目标追踪(MeanShift)
android·opencv·学习