SQLite 和 MySQL语法区别

devtools/2024/11/17 19:10:20/

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.ppmy.cn/devtools/134765.html

相关文章

ASUS/华硕灵耀X双屏Pro UX8402Z 原厂Win11-22H2系统 工厂文件 带ASUS Recovery恢复

华硕工厂文件恢复系统 ,安装结束后带隐藏分区,一键恢复,以及机器所有驱动软件。 系统版本:windows11 原厂系统下载网址:http://www.bioxt.cn 需准备一个20G以上u盘进行恢复 请注意:仅支持以上型号专用…

sql注入基础知识

sql注入原理 web页面通常会根据用户输出的内容生成动态的sql查询语句,如果数据库没有对用户输的语句进行合适的过滤导致攻击者可以通过特殊的sql语句来操作查询内容。 sql注入的形式 基础字符串解析: table_schema代表数据库名 table_name代表表名 …

内网安全-代理技术-socket协议

小迪安全网络架构图: 背景:当前获取window7 出网主机的shell。 1.使用msf上线,查看路由 run autoroute -p 添加路由: run post/multi/manage/autoroute 使用socks模块开启节点,作为流量跳板 msf6 exploit(multi/ha…

计算机视觉 1-8章 (硕士)

文章目录 零、前言1.先行课程:python、深度学习、数字图像处理2.查文献3.环境安装 第一章:概论1.计算机视觉的概念2.机器学习 第二章:图像处理相关基础1.图像的概念2.图像处理3.滤波器4.卷积神经网络CNN5.图像的多层表示:图像金字…

Python从0到100(七十二):Python OpenCV-OpenCV实现手势音量控制(文末送书)

前言: 零基础学Python:Python从0到100最新最全教程。 想做这件事情很久了,这次我更新了自己所写过的所有博客,汇集成了Python从0到100,共一百节课,帮助大家一个月时间里从零基础到学习Python基础语法、Pyth…

鸿蒙next版开发:相机开发-元数据(ArkTS)

在HarmonyOS 5.0中,ArkTS提供了对相机元数据的访问能力,这对于开发者在相机应用中获取图像的详细信息非常有用。元数据(Metadata)是对相机返回的图像信息数据的描述和上下文,比如照片或视频中识别人像的取景框坐标等信…

【Mysql】Mysql的多表查询---多表联合查询(中)

1、外连接查询 外连接 查询分为左外连接(left outer join), 右外连接查询(right outer join) ,满外连接查询(full outer join). 注意:oracle 里面有full join &#xf…

python 爱心邮件代码

import smtplib import time from email.mime.text import MIMEText import requests from lxml import etree import datetime from requests.exceptions import RequestException# 邮件配置 sender_maile # 发件人地址 sender_pass # 邮件授权码 boy_name # 发件人姓…