键值型数据库通过 Key-Value 键值的方式来存储数据,其中 Key 和 Value 可以是简单的对象,也可以是复杂的对象。Key 作为唯一的标识符,优点是查找速度快,在这方面明显优于关系型数据库,缺点是无法像关系型数据库一样使用条件过滤(比如 WHERE),如果你不知道去哪里找数据,就要遍历所有的键,这就会消耗大量的计算。 键值型数据库典型的使用场景是作为 内存缓存 。 Redis 是最流行的键值型数据库。
此类数据库可存放并获取文档,可以是XML、JSON等格式。在数据库中文档作为处理信息的基本单位, 一个文档就相当于一条记录。文档数据库所存放的文档,就相当于键值数据库所存放的“值”
MongoDB是最流行的文档型数据库。此外,还有CouchDB等。
虽然关系型数据库采用了索引提升检索效率,但是针对全文索引效率却较低。搜索引擎数据库是应用在搜索引擎领域的数据存储形式,由于搜索引擎会爬取大量的数据,并以特定的格式进行存储,这样在检索的时候才能保证性能最优。核心原理是“倒排索引”。 典型产品:Solr、Elasticsearch、Splunk 等。
列式数据库是相对于行式存储的数据库,Oracle、MySQL、SQL Server 等数据库都是采用的行式存储(Row-based),而列式数据库是将数据按照列存储到数据库中,这样做的好处是可以大量降低系统的I/O,适合于分布式文件系统,不足在于功能相对有限。典型产品:HBase等。
顾名思义,就是一种存储图形关系的数据库。它利用了图这种数据结构存储了实体(对象) 之间的关系。关系型数据用于存储明确关系的数据,但对于复杂关系的数据存储却有些力不从心。如社交网络中人物之间的关系,如果用关系型数据库则非常复杂,用图形数据库将非常简单。典型产品:Neo4J、InfoGrid等。
ORM思想 (Object Relational Mapping)体现: 数据库中的一个表 <---> Java或Python中的一个类 表中的一条数据 <---> 类中的一个对象(或实体) 表中的一个列 <----> 类中的一个字段、属性(field)
要表示多对多关系,必须创建第三个表,该表通常称为 联接表 ,它将多对多关系划分为两个一对多关系。将这两个表的主键都插入到第三个表中。
#以下两句是一样的,不区分大小写 show databases; SHOW DATABASES; #创建表格 #create table student info(...); #表名错误,因为表名有空格 create table student_info(...); #其中order使用``飘号,因为order和系统关键字或系统函数名等预定义标识符重名了 CREATE TABLE `order`( ); select id as "编号", `name` as "姓名" from t_stu; #起别名时,as都可以省略 select id as 编号, `name` as 姓名 from t_stu; #如果字段别名中没有空格,那么可以省略"" select id as 编 号, `name` as 姓 名 from t_stu; #错误,如果字段别名中有空格,那么不能省略""
在命令行客户端登录mysql,使用source指令导入
mysql -u root -p 回车自己输入自己的密码
use depteruser 指定数据的库
导入sql文件
mysql> source d:\mysqldb.sql
基于具体的图形化界面的工具可以导入数据
比如: SQLyog中选择 “工具” -- “执行sql脚本” -- 选中xxx.sql即可。
SELECT 标识选择哪些列 FROM 标识从哪个表中选择
SELECT * FROM 数据表;
一般情况下,除非需要使用表中所有的字段数据,最好不要使用通配符‘*’。使用通配符虽然可以节 省输入查询语句的时间,但是获取不需要的列数据通常会降低查询和所使用的应用程序的效率。通 配符的优势是,当不知道所需要的列的名称时,可以通过它获取它们。 在生产环境下,不推荐你直接使用 SELECT * 进行查询。
语法:SELECT 列名1,列名2 FROM 数据表
SELECT name FROM doctor;
as全称:alias(别名),可以省略
列的别名
语法:SELECT 字段(列名) AS "别名" FROM 数据表
SELECT s_sex AS "性别" FROM stu
省略:
默认情况下,查询会返回全部行,包括重复行。
SELECT department_id
FROM employees;
针对于
语法:SELECT DISTINCT 列名 FROM 数据表
SELECT DISTINCT s_sex FROM stu
针对于
SELECT DISTINCT department_id,salary FROM employees;
不报错,但是没实际意义
解释:DISTINCT 其实是对后面所有列名的组合进行去重,你能看到最后的结果是 74 条,因为这 74 个部门id不同,都有 salary 这个属性值。如果你想要看都有哪些不同的部门(department_id),只需要写 DISTINCT department_id 即可,后面不需要再加其他的列名了。
空值:null
null不等同于 0 ,' ' , ' null'
所有运算符或列值遇到null值,运算的结果都为null
SELECT employee_id,salary,commission_pct, 12 * salary * (1 + commission_pct) "annual_sal" FROM employees;
这里你一定要注意,在 MySQL 里面, 空值不等于空字符串。一个空字符串的长度是 0,而一个空值的长度是空。而且,在 MySQL 里面,空值是占用空间的。
SELECT employee_id, salary "月工资", salary * (1 + commission_pct) * 12 "年工资", commission_pcr FROM employees;
SELECT employee_id, salary "月工资", salary * (1 +IFNULL(commission_pct, 0)) * 12 "年工资", commission_pcr FROM employees;
mysql> SELECT * FROM ORDER;
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that
corresponds to your MySQL server version for the right syntax to use near 'ORDER' at
line 1
mysql> SELECT * FROM `ORDER`;
+----------+------------+
| order_id | order_name |
+----------+------------+
| 1 | shkstart |
| 2 | tomcat |
| 3 | dubbo |
+----------+------------+
3 rows in set (0.00 sec)
mysql> SELECT * FROM `order`;
+----------+------------+
| order_id | order_name |
+----------+------------+
| 1 | shkstart |
| 2 | tomcat |
| 3 | dubbo |
+----------+------------+
3 rows in set (0.00 sec)
结论 我们需要保证表中的字段、表名等没有和保留字、数据库系统或常用方法冲突。如果真的相同,请在SQL语句中使用一对``(着重号)引起来。
ORDER 是关键字加’’ 就会把他当成一个表;
eg: ORDER 替换为 `ORDER`
SELECT 查询还可以对常数进行查询。对的,就是在 SELECT 查询结果中增加一列固定的常数列。这列的取值是我们指定的,而不是从数据表中动态取出的。
SELECT s_sex AS "性别" FROM stu; SELECT '性别', birthday FROM stu;
你可能会问为什么我们还要对常数进行查询呢? SQL 中的 SELECT 语法的确提供了这个功能,一般来说我们只从一个表中查询数据,通常不需要增加一个固定的常数列,但如果我们想整合不同的数据源,用常数列作为这个表的标记,就需要查询常数。 比如说,我们想对 stu 数据表中的学生姓名进行查询,同时增加一列字段 corporation ,这个字段固定值为“公司”,可以这样写:
SELECT s_sex AS "性别" FROM stu; SELECT '公司' as corporation FROM stu;
DESCRIBE employees; #显示了表中该字段的详细信息 DESCRIBE employees;
使用DESCRIBE 或 DESC 命令,表示表结构。
mysql> desc employees; +----------------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +----------------+-------------+------+-----+---------+-------+ | employee_id | int(6) | NO | PRI | 0 | | | first_name | varchar(20) | YES | | NULL | | | last_name | varchar(25) | NO | | NULL | | | email | varchar(25) | NO | UNI | NULL | | | phone_number | varchar(20) | YES | | NULL | | | hire_date | date | NO | | NULL | | | job_id | varchar(10) | NO | MUL | NULL | | | salary | double(8,2) | YES | | NULL | | | commission_pct | double(2,2) | YES | | NULL | | | manager_id | int(6) | YES | MUL | NULL | | | department_id | int(4) | YES | MUL | NULL | | +----------------+-------------+------+-----+---------+-------+ 11 rows in set (0.00 sec)
其中,各个字段的含义分别解释如下:
语法:
SELECT 字段1,字段2
FROM 表名
WHERE 过滤条件
SELECT employee_id, last_name, job_id, department_id
FROM employees
WHERE department_id = 90 ;
#查询90号部门的员工信息
SELECT * FROM employees;
#过滤条件,声明在FROM结构的后面
SELECT department_id = 90;
SELECT employee_id , last_time,
salary * 12 "ANNUAL SALARY"
FROM employees;
SELECT DISITNCT job_id
FROM employees
SELECT last_name, salary
FROM employees
WHERE salary > 12000;
SELECT last_name, department_id
FROM employees
WHERE employee_id = 176;
DESCRIBE department;
SELECT * FROM department;
今天就先到这了!!!