学习数据库MySQL,与SQLite数据库作对比

MySQL数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司。MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

  • Mysql是开源的,所以你不需要支付额外的费用。
  • Mysql支持大型的数据库。可以处理拥有上千万条记录的大型数据库。
  • MySQL使用标准的SQL数据语言形式。
  • Mysql可以运行于多个系统上,并且支持多种语言。这些编程语言包括C、C++、
    Python、Java、Perl、PHP、Eiffel、Ruby和Tcl等。
  • Mysql对PHP有很好的支持,PHP是目前最流行的Web开发语言。
  • MySQL支持大型数据库,支持5000万条记录的数据仓库,32位系统表文件最大可- 支持4GB,64位系统支持最大的表文件为8TB。
  • Mysql是可以定制的,采用了GPL协议,你可以修改源码来开发自己的Mysql系统。

注:
下载地址:https://dev.mysql.com/downloads/mysql/
官网上下载安装MySQL要记得配置环境变量。

1.启动服务并登陆MySQL数据库

单击<开始>—<运行>输入cmd,打开DOS命令行。
(1)启动输入命令:

net start mysql80

学习数据库MySQL,与SQLite数据库作对比_第1张图片
停止输入命令:

net stop mysql80

学习数据库MySQL,与SQLite数据库作对比_第2张图片
注:除上述方法外,还可以进行手动启动服务
单击<开始>—<运行>输入services.msc,点击<确定>,如下所示。
学习数据库MySQL,与SQLite数据库作对比_第3张图片
(2)登录MySQL,输入如下命令

mysql -u root -p

(在在装过程中,已设置用户名为root,密码为空)
学习数据库MySQL,与SQLite数据库作对比_第4张图片

2.创建数据库—>创建表—>插入数据—>查询数据

① 创建数据库
基本语法如下:

CREATE DATABASE database_name;

删除数据库:

DROP DATABASE database_name;

② 创建表
基本语法如下:

CREATE TABLE table_name (column_name column_type);

修改数据表:

ALTER TABLE table_name MODIFY (column_name column_type);

删除数据表:

DROP TABLE table_name ;

③ 插入数据

INSERT INTO table_name ( field1, field2,...fieldN )
                       VALUES
                       ( value1, value2,...valueN );

④查询数据
基本语法如下:

SELECT column_name,column_name
FROM table_name
[WHERE Clause]
[LIMIT N][ OFFSET M]

####一个小例子:创建数据库company,创建数据表employees,插入如下数据,进行查询操作。
office表结构:

employeenumber name salary
01001 Jack 15000
01002 Lily 10000
01003 Lucy 20000

学习数据库MySQL,与SQLite数据库作对比_第5张图片
学习数据库MySQL,与SQLite数据库作对比_第6张图片
学习数据库MySQL,与SQLite数据库作对比_第7张图片

MySQL与SQLite对比

SQLite功能简约,小型化,追求最大磁盘效率;MySQL功能全面,综合化,追求最大并发效率。如果只是单机上用的,数据量不是很大,需要方便移植或者需要频繁读/写磁盘文件的话,就用SQLite比较合适;如果是要满足多用户同时访问,或者是网站访问量比较大是使用MYSQL比较合适。

SQLite

1.SQLite支持的数据类型

NULL:NULL值。
INTEGER:有符号整数,按照设置用1、2、3、4、6或8字节存储。
REAL:浮点数,使用8字节IEEE浮点数方式存储。
TEXT:文本字符串,使用数据库编码存储(UTF-8, UTF-16BE 或 UTF-16LE)。
BLOB:二进制大对象,怎么输入就怎么存储。

2.SQLite 的优点
①基于文件:
整个数据库都包含在磁盘上的一个文件中,因此它有很好的迁移性。

②标准化:
尽管它看起来像个“简化版”的数据库,SQLite 确实支持 SQL。它略去了一些功能(RIGHT OUTER JOIN 和 FOR EACH STATEMENT),但是,又同时增加了一些其他功能。

③对开发乃至测试都很棒:
在绝大多数应用的开发阶段中,大部分人都非常需要解决方案能有并发的灵活性。SQLite 含有丰富功能基础,所能提供的超乎开发所需。

3.SQLite的缺点
①没有用户管理
②缺乏额外优化性能的灵活性

MySQL

1.MySQL支持的数据类型

TINYINT:一个非常小的整数.
SMALLINT:一个小整数.
MEDIUMINT:一个中间大小的整数.
INT or INTEGER:一个正常大小的整数.
BIGINT:一个大的整数.
FLOAT:一个小的 (单精度) 浮点数,不能是无符号的那种.
DOUBLE, DOUBLE PRECISION, REAL:一个正常大小 (双精度) 的浮点数,不能使无符号的那种.
DECIMAL, NUMERIC:没有被包装的浮点数。不能使无符号的那种.
DATE:一个日期.
DATETIME:一个日期和时间的组合.
TIMESTAMP:一个时间戳.
TIME:一个时间.
YEAR:一个用两位或者4位数字格式表示的年份(默认是4位).
CHAR:一个固定长度的字符串,存储时总是在其固定长度的空间里右对齐.
VARCHAR:一个可变长度的字符串.
TINYBLOB, TINYTEXT:一个BLOB或者TEXT列,最大长度255 (2^8 - 1)个字符.
BLOB, TEXT:一个BLOB或者TEXT列,最大长度 65535 (2^16 - 1)个字符.
MEDIUMBLOB, MEDIUMTEXT:一个BLOB或者TEXT列,最大长度 16777215 (2^24 - 1)个字符.
LONGBLOB, LONGTEXT:一个BLOB或者TEXT列,最大长度4294967295 (2^32 - 1) 个字符.
ENUM:一个枚举类型.
SET:一个集合.

2.MySQL的优点
①容易使用:
安装MySQL非常容易。第三方库,包括可视化(也就是有GUI)的库让上手使用数据库非常简单。

②功能丰富:
MySQL 支持大部分关系型数据库应该有的 SQL 功能——有些直接支持,有些间接支持。

③安全:
MYSQL 有很多安全特性,其中有些相当高级。

④灵活而强大:
MySQL 能处理很多数据,此外如有需要,它还能“适应”各种规模的数据。

⑤快速:
放弃支持某些标准,让 MySQL 效率更高并能使用捷径,因此带来速度的提升。

3.MySQL的缺点

①已知的局限:
从设计之初,MySQL 就没打算做到全知全能,因此它有一些功能局限,无法满足某些顶尖水平应用的需求。

②可靠性问题:
MySQL 对于某些功能的实现方式(例如,引用,事务,数据审核等) 使得它比其他一些关系型数据库略少了一些可靠性。

③开发停滞:
尽管 MySQL 理论上仍是开源产品,也有人抱怨它诞生之后更新缓慢。然而,应该注意到有一些基于 MySQL 并完整集成的数据库(如 MariaDB),在标准的 MySQL 基础上带来了额外价值。

数据库基本语法对比

MySQL SQLite
show databases .databases
show tables .tables
quit .quit
help .help

你可能感兴趣的:(数据库)