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

SQLite 和 MySQL语法区别

SQLite 和 MySQL 在 SQL 语法上有一些差异,这些差异主要体现在数据类型、函数、表和索引的管理等方面。以下是一些主要的不同之处:

1. 数据类型

SQLite
  • 支持的数据类型包括:TEXTINTEGERREALBLOB
  • 动态类型系统,允许在插入时自动转换数据类型。
MySQL
  • 支持更丰富的数据类型,如:
    • 数值类型:INTBIGINTFLOATDOUBLEDECIMAL 等。
    • 字符串类型:CHARVARCHARTEXTTINYTEXTMEDIUMTEXTLONGTEXT 等。
    • 时间日期类型:DATETIMEDATETIMETIMESTAMP 等。
    • 二进制类型:BINARYVARBINARYBLOB 等。
    • 枚举类型:ENUM
    • 集合类型:SET

2. 创建表

SQLite
1CREATE TABLE example (
2    id INTEGER PRIMARY KEY,
3    name TEXT NOT NULL,
4    age INTEGER
5);
MySQL
1CREATE TABLE example (
2    id INT AUTO_INCREMENT PRIMARY KEY,
3    name VARCHAR(255) NOT NULL,
4    age INT
5);

3. 自增主键

SQLite
  • 使用 AUTOINCREMENT 关键字。
  • 也可以使用 INTEGER PRIMARY KEY 来实现自增主键。
MySQL
  • 使用 AUTO_INCREMENT 关键字。

4. 修改表结构

SQLite
  • 列操作只能添加列 

    您说得对,SQLite 从版本 3.35.0 开始支持直接添加列的功能。以下是更新后的语法:

    SQLite (版本 3.35.0 及以上):

    1ALTER TABLE example ADD COLUMN new_column_name data_type;
    1-- 创建一个新表,包含原表的所有列加上新的列
    2CREATE TABLE new_example AS SELECT column1, column2 FROM example;
    3-- 删除旧表
    4DROP TABLE example;
    5-- 重命名新表为旧表的名字
    6ALTER TABLE new_example RENAME TO example;
MySQL
  • 添加列:
    1ALTER TABLE example ADD COLUMN new_column_name data_type;
  • 删除列:
    1ALTER TABLE example DROP COLUMN column_name;
  • 修改列的数据类型:
    1ALTER TABLE example MODIFY COLUMN column_name new_data_type;
  • 修改列的名称:
    1ALTER TABLE example CHANGE COLUMN old_column_name new_column_name new_data_type;

5. 索引

SQLite
  • 创建索引:
    1CREATE INDEX idx_name ON table_name (column_name);
  • 删除索引:
    1DROP INDEX idx_name;
MySQL
  • 创建索引:
    1CREATE INDEX idx_name ON table_name (column_name);
  • 删除索引:
    1DROP INDEX idx_name ON table_name;

6. 函数

SQLite
  • 常用函数:LOWER()UPPER()LENGTH()SUBSTR()REPLACE() 等。
  • 没有 IFNULL() 函数,可以使用 COALESCE() 替代。
MySQL
  • 常用函数:LOWER()UPPER()LENGTH()SUBSTRING()REPLACE()IFNULL() 等。

7. 子查询

SQLite
  • 支持子查询,但某些复杂子查询可能不被支持或性能较差。
MySQL
  • 支持复杂的子查询,并且优化器通常能更好地处理子查询。

8. 联接(JOIN)

SQLite
  • 支持标准的联接操作,如 INNER JOINLEFT JOINRIGHT JOINFULL OUTER JOIN
MySQL
  • 同样支持标准的联接操作,但在某些情况下可能会有不同的性能表现。

9. 事务

SQLite
  • 支持事务,但默认是自动提交模式。
  • 可以通过 BEGIN TRANSACTION; 开始一个事务,通过 COMMIT; 提交事务,通过 ROLLBACK; 回滚事务。
MySQL
  • 支持事务,具体行为取决于所使用的存储引擎(如 InnoDB 支持事务,MyISAM 不支持)。
  • 事务管理与 SQLite 类似,可以通过 BEGIN;COMMIT;ROLLBACK; 控制。

10. 其他特性

SQLite
  • 支持部分正则表达式匹配。
  • 支持虚拟表和模块化架构。
MySQL
  • 支持视图、存储过程、触发器等高级特性。
  • 支持分区表,可以在物理层面上将大表分成多个小表。
http://www.lryc.cn/news/488705.html

相关文章:

  • 基于BERT的命名体识别(NER)
  • 华为云鸿蒙应用入门级开发者认证考试题库(理论题和实验题)
  • SpringBoot+React养老院管理系统 附带详细运行指导视频
  • 使用element-plus el-table中使用el-image层级冲突table表格会覆盖预览的图片等问题
  • python读取Oracle库并生成API返回Json格式
  • 音视频入门基础:MPEG2-TS专题(5)——FFmpeg源码中,判断某文件是否为TS文件的实现
  • 每天10个vue面试题(九)
  • Jenkins的环境部署
  • 八、鸿蒙开发-网络请求、应用级状态管理
  • 经验笔记:Git 中的远程仓库链接及上下游关系管理
  • Paint 学习笔记
  • Jenkins修改LOGO
  • kafka是如何做到高效读写
  • Intern大模型训练营(九):XTuner 微调实践微调
  • 从一次java.io.StreamCorruptedException: invalid stream header: 48656C6C 错误中学到的调试思路
  • 树莓派的发展历史
  • K8S containerd拉取harbor镜像
  • Ubuntu 环境下通过 Apt-get 安装软件
  • vue使用List.forEach遍历集合元素
  • ROM修改进阶教程------安卓14去除修改系统应用后导致的卡logo验证步骤 适用安卓13 14 安卓15可借鉴参考
  • 苹果macbook,MacOS 11,12,13,14,15 跳过监管锁(配置锁)
  • 【YOLOv8】安卓端部署-2-项目实战
  • 第二十四章 Spring之源码阅读——AOP篇
  • Linux配置MySQL自动备份
  • qt 之 QDockWidget设置不可拖动
  • 【Java知识】Java性能测试工具JMeter
  • Git 安装
  • 【Python】FastAPI:Token认证
  • 【FAQ】HarmonyOS SDK 闭源开放能力 —ArkUI
  • ubuntu没有了有线网络如何修复