mysql 建表时间一直在变_138 张图带你 MySQL 入门一

SQL 基础使用

MySQL 是一种关系型数据库,说到关系,那么就离不开表与表之间的关系,而最能体现这种关系的其实就是我们接下来需要介绍的主角 SQL,SQL 的全称是 Structure Query Language ,结构化的查询语言,它是一种针对表关联关系所设计的一门语言,也就是说,学好 MySQL,SQL 是基础和重中之重。SQL 不只是 MySQL 中特有的一门语言,大多数关系型数据库都支持这门语言。

下面我们就来一起学习一下这门非常重要的语言。

查询语言分类

在了解 SQL 之前我们需要知道下面这几个概念

  • 数据定义语言: 简称DDL (Data Definition Language),用来定义数据库对象:数据库、表、列等;
  • 数据操作语言: 简称DML (Data Manipulation Language),用来对数据库中表的记录进行更新。关键字: insert、update、delete等
  • 数据控制语言: 简称DCL(Data Control Language),用来定义数据库访问权限和安全级别,创建用户等。关键字: grant等
  • 数据查询语言: 简称DQL(Data Query Language),用来查询数据库中表的记录,关键字: select from where等

DDL 语句

创建数据库

下面就开始我们的 SQL 语句学习之旅,首先你需要启动 MySQL 服务,我这里是 mac 电脑,所以我直接可以启动

b5ea788c228e8bead76f85ceac54a788.png

然后我们使用命令行的方式连接数据库,打开 iterm,输入下面

MacBook:~ mr.l$ mysql -uroot -p

就可以连接到数据库了

57659df7af00b1eb504f8b11b22de08b.png

在上面命令中,mysql 代表客户端命令,- u 表示后面需要连接的用户,-p 表示需要输入此用户的密码。在你输入用户名和密码后,如果成功登陆,会显示一个欢迎界面(如上图 )和 mysql> 提示符。

欢迎界面主要描述了这些东西

  • 每一行的结束符,这里用 ; 或者 g 来表示每一行的结束
  • Your MySQL connection id is 4,这个记录了 MySQL 服务到目前为止的连接数,每个新链接都会自动增加 1 ,上面显示的连接次数是 4 ,说明我们只连接了四次
  • 然后下面是 MySQL 的版本,我们使用的是 5.7
  • 通过 help 或者 h 命令来显示帮助内容,通过 c 命令来清除命令行 buffer。

然后需要做的事情是什么?我们最终想要学习 SQL 语句,SQL 语句肯定是要查询数据,通过数据来体现出来表的关联关系,所以我们需要数据,那么数据存在哪里呢?数据存储的位置被称为 表(table),表存储的位置被称为 数据库(database),所以我们需要先建数据库后面再建表然后插入数据,再进行查询。

a2b159c3086319b669cef2384079ff19.png

所以我们首先要做的就是创建数据库,创建数据库可以直接使用指令

CREATE DATABASE dbname;

进行创建,比如我们创建数据库 cxuandb

create database cxuandb;

注意最后的 ; 结束语法一定不要丢掉,否则 MySQL 会认为你的命令没有输出完,敲 enter 后会直接换行输出

4b6e1182c1985cf76ab4d9e821fee57b.png

创建完成后,会提示 Query OK, 1 row affected,这段语句什么意思呢? Query OK 表示的就是查询完成,为什么会显示这个?因为所有的 DDL 和 DML 操作执行完成后都会提示这个, 也可以理解为操作成功。后面跟着的 **1 row affected ** 表示的是影响的行数,() 内显示的是你执行这条命令所耗费的时间,也就是 0.03 秒。

上图我们成功创建了一个 cxuandb 的数据库,此时我们还想创建一个数据库,我们再执行相同的指令,结果提示

25e561fa7c599dc460558f60ae287328.png

提示我们不能再创建数据库了,数据库已经存在。这时候我就有疑问了,我怎么知道都有哪些数据库呢?别我再想创建一个数据库又告诉我已经存在,这时候可以使用 show databases 命令来查看你的 MySQL 已有的数据库

show databases;

执行完成后的结果如下

2d59049c4df6b87b1889ff9c24d948f9.png

因为数据库我之前已经使用过,这里就需要解释一下,除了刚刚新创建成功的 cxuandb 外,informationn_schema 、performannce_schema 和 sys 都是系统自带的数据库,是安装 MySQL 默认创建的数据库。它们各自表示

  • informationn_schema: 主要存储一些数据库对象信息,比如用户表信息、权限信息、分区信息等
  • performannce_schema: MySQL 5.5 之后新增加的数据库,主要用于收集数据库服务器性能参数。
  • sys: MySQL 5.7 提供的数据库,sys 数据库里面包含了一系列的存储过程、自定义函数以及视图来帮助我们快速的了解系统的元数据信息。

其他所有的数据库都是作者自己创建的,可以忽略他们。

在创建完数据库之后,可以用如下命令选择要操作的数据库

use cxuandb

这样就成功切换为了 cxuandb 数据库,我们可以在此数据库下进行建表、查看基本信息等操作。

50d0f48a7ea2e675e2041015bdfe49f2.png

比如想要看康康我们新建的数据库里面有没有其他表

show tables;

果然,我们新建的数据库下面没有任何表,但是现在,我们还不进行建表操作,我们还是先来认识一下数据库层面的命令,也就是其他 DDL 指令

删除数据库

如果一个数据库我们不想要了,那么该怎么办呢?直接删掉数据库不就好了吗?删表语句是

drop database dbname;

比如 cxuandb 我们不想要他了,可以通过使用

drop database cxuandb;

进行删除,这里我们就不进行演示了,因为 cxuandb 我们后面还会使用。

但是这里注意一点,你删除数据库成功后会出现 0 rows affected,这个可以不用理会,因为在 MySQL 中,drop 语句操作的结果都是 0 rows affected

创建表

下面我们就可以对表进行操作了,我们刚刚 show tables 发现还没有任何表,所以我们现在进行建表语句

CREATE TABLE 表名称(列名称1 数据类型 约束,列名称2 数据类型 约束,列名称3 数据类型 约束,....)

这样就很清楚了吧,列名称就是列的名字,紧跟着列名后面就是数据类型,然后是约束,为什么要这么设计?举个例子你就清楚了,比如 cxuan 刚被生出来就被打印上了标签

3e0e47829f7fa498de158e8f0bc69226.png

比如我们创建一个表,里面有 5 个字段,姓名(name)、性别(sex)、年龄(age)、何时雇佣(hiredate)、薪资待遇(wage),建表语句如下

create table job(name varchar(20), sex varchar(2), age int(2), hiredate date, wage decimal(10,2));

事实证明这条建表语句还是没问题的,建表完成后可以使用 DESC tablename 查看表的基本信息

cf044e4522ff4eff13795fe51dacb6c6.png

DESC 命令会查看表的定义,但是输出的信息还不够全面,所以,如果想要查看更全的信息,还要通过查看表的创建语句的 SQL 来得到

show create table job G;
b3865a95fdcc46ddb7995b0bb83a2e21.png

可以看到,除了看到表定义之外,还看到了表的 engine(存储引擎) 为 InnoDB 存储引擎,G 使得记录能够竖着排列,如果不用 G 的话,效果如下

893a8c0696bc98ce8c333789e17eb310.png

删除表

表的删除语句有两种,一种是 drop 语句,SQL 语句如下

drop table job

一种是 truncate 语句,SQL 语句如下

truncate table job

这两者的区别简单理解就是 drop 语句删除表之后,可以通过日志进行回复,而 truncate 删除表之后永远恢复不了,所以,一般不使用 truncate 进行表的删除。‘

修改表

对于已经创建好的表,尤其是有大量数据的表,如果需要对表做结构上的改变,可以将表删除然后重新创建表,但是这种效率会产生一些额外的工作,数据会重新加载近来,如果此时有服务正在访问的话,也会影响服务读取表中数据,所以此时,我们需要表的修改语句来对已经创建好的表的定义进行修改。

修改表结构一般使用 alter table 语句,下面是常用的命令

ALTER TABLE tb MODIFY [COLUMN] column_definition [FIRST | AFTER col_name];

比如我们想要将 job 表中的 name 由 varchar(20) 改为 varchar(25),可以使用如下语句

alter table job modify name varchar(25);
63386cc4aa5b8fe957787ef65dbc733c.png

也可以对表结构进行修改,比如增加一个字段

alter table job add home varchar(30);
398f3489927737a795792c4c3c47cbd7.png

将新添加的表的字段进行删除

alter table job drop column home;
629c384644b6ec0e62c698df6ea89315.png

可以对表中字段的名称进行修改,比如吧 wage 改为 salary

alter table job change wage salary decimal(10,2);
941cd84615d2ff7bf46e4d3c6fb4c37f.png

修改字段的排列顺序,我们前面介绍过修改语法涉及到一个顺序问题,都有一个可选项 **first | after ** column_name,这个选项可以用来修改表中字段的位置,默认 ADD 是在添加为表中最后一个字段,而 CHANGE/MODIFY 不会改变字段位置。比如

alter table job add birthday after hiredate;
de464ec7ef1218f66cb4391ec14a6247.png

可以对表名进行修改,例如将 job 表改为 worker

alter table job rename worker;

DML 语句

有的地方把 DML 语句(增删改)和 DQL 语句(查询)统称为 DML 语句,有的地方分开,我们目前使用分开称呼的方式

插入

表创建好之后,我们就可以向表里插入数据了,插入记录的基本语法如下

INSERT INTO tablename (field1,field2) VALUES(value1,value2);

例如,向中插入以下记录

insert into job(name,sex,age,hiredate,birthday,salary) values("cxuan","男",24,"2020-04-27","1995-08-22",8000);

也可以不用指定要插入的字段,直接插入数据即可

insert into job values("cxuan02","男",25,"2020-06-01","1995-04-23",12000);

这里就有一个问题,如果插入的顺序不一致的话会怎么样呢?

对于含可空字段、非空但是含有默认值的字段、自增字段可以不用在 insert 后的字段列表出现,values 后面只需要写对应字段名称的 value 即可,没有写的字段可以自动的设置为 NULL、默认值或者自增的下一个值,这样可以缩短要插入 SQL 语句的长度和复杂性。

比如我们设置一下 hiredate、age 可以为 null,来试一下

insert into job(name,sex,birthday,salary) values("cxuan03","男","1992-08-23",15000);
411ac25e9a8c73bc868f696491756de8.png

我们看一下实际插入的数据

3f5106b75e56d50d1aca4d0f5f33bcee.png

我们可以看到有一行两个字段显示 NULL。在 MySQL 中,insert 语句还有一个很好的特性,就是一次可以插入多条记录

INSERT INTO tablename (field1,field2) VALUES(value1,value2),(value1,value2),(value1,value2),...;

可以看出,每条记录之间都用逗号进行分割,这个特性可以使得 MySQL 在插入大量记录时,节省很多的网络开销,大大提高插入效率。

更新记录

对于表中已经存在的数据,可以通过 update 命令对其进行修改,语法如下

UPDATE tablename SET field1 = value1, field2 = value2 ;

例如,将 job 表中的 cxuan03 中 age 的 NULL 改为 26,SQL 语句如下

update job set age = 26 where name = 'cxuan03';

SQL 语句中出现了一个 where 条件,我们会在后面说到 where 条件,这里简单理解一下它的概念就是根据哪条记录进行更新,如果不写 where 的话,会对整个表进行更新

删除记录

如果记录不再需要,可以使用 delete 命令进行删除

DELETE FROM tablename [WHERE CONDITION]

例如,在 job 中删除名字是 cxuan03 的记录

delete from job where name = 'cxuan03';
1a28d6e4375716edde19b2f2cb3314a5.png

在 MySQL 中,删除语句也可以不指定 where 条件,直接使用

delete from job

这种删除方式相当于是清楚表的操作,表中所有的记录都会被清除。

DQL 语句

下面我们一起来认识一下 DQL 语句,数据被插入到 MySQL 中,就可以使用 SELECT 命令进行查询,来得到我们想要的结果。

SELECT 查询语句可以说是最复杂的语句了,这里我们只介绍一下基本语法

一种最简单的方式就是从某个表中查询出所有的字段和数据,简单粗暴,直接使用 SELECT *

SELECT * FROM tablename;

例如我们将 job 表中的所有数据查出来

select * from job;
6289198bbcd3719f2e0889e0c44f2266.png

其中 * 是查询出所有的数据,当然,你也可以查询出指定的数据项

select name,sex,age,hiredate,birthday,salary from job;

上面这条 SQL 语句和 select * from job 表是等价的,但是这种直接查询指定字段的 SQL 语句效率要高。

上面我们介绍了基本的 SQL 查询语句,但是实际的使用场景会会比简单查询复杂太多,一般都会使用各种 SQL 的函数和查询条件等,下面我们就来一起认识一下。

去重

使用非常广泛的场景之一就是 去重,去重可以使用 distinct 关键字来实现

为了演示效果,我们先向数据库中插入批量数据,插入完成后的表结构如下

a5c4a64a7802ee9cb15875e88192a059.png

下面我们使用 distinct 来对 age 去重来看一下效果

db2edafdce3fff9b2c79634c519fb355.png

你会发现只有两个不同的值,其他和 25 重复的值被过滤掉了,所以我们使用 distinct 来进行去重

条件查询

我们之前的所有例子都是查询全部的记录,如果我们只想查询指定的记录呢?这里就会用到 where条件查询语句,条件查询可以对指定的字段进行查询,比如我们想查询所有年龄为 24 的记录,如下

select * from job where age = 24;
ec1786a3f044ec0b32a33bcd32993a3d.png

where 条件语句后面会跟一个判断的运算符 =,除了 = 号比较外,还可以使用 >、=、<=、!= 等比较运算符;例如

select * from job where age >= 24;

就会从 job 表中查询出 age 年龄大于或等于 24 的记录

除此之外,在 where 条件查询中还可以有多个并列的查询条件,比如我们可以查询年龄大于等于 24,并且薪资大雨 8000 的记录

select * from job where age >= 24 and salary > 8000;
f550ef00d28a20a5d9aa737937ef9360.png

多个条件之间还可以使用 or、and 等逻辑运算符进行多条件联合查询,运算符会在以后章节中详细讲解。

排序

我们会经常有这样的需求,按照某个字段进行排序,这就用到了数据库的排序功能,使用关键字 order by 来实现,语法如下

SELECT * FROM tablename [WHERE CONDITION] [ORDER BY field1 [DESC|ASC] , field2 [DESC|ASC],……fieldn [DESC|ASC]]

其中 DESC 和 ASC 就是顺序排序的关键字,DESC 会按照字段进行降序排列,ASC 会按照字段进行升序排列,默认会使用升序排列,也就是说,你不写 order by 具体的排序的话,默认会使用升序排列。order by 后面可以跟多个排序字段,并且每个排序字段可以有不同的排序顺序。

为了演示功能,我们先把表中的 salary 工资列进行修改,修改完成后的表记录如下

17378e50134d87b9eacc0bcfc352935e.png

下面我们按照工资进行排序,SQL 语句如下

select * from job order by salary desc;

语句执行完成后的结果如下

4b7f5ab508f83bdea2c45631524333ae.png

这是对一个字段进行排序的结果,也可以对多个字段进行排序,但是需要注意一点

根据 order by 后面声名的顺序进行排序,如果有三个排序字段 A、B、C 的话,如果 A 字段排序字段的值一样,则会根据第二个字段进行排序,以此类推。

如果只有一个排序字段,那么这些字段相同的记录将会无序排列。

限制

对于排序后的字段,或者不排序的字段,如果只希望显示一部分的话,就会使用 LIMIT 关键字来实现,比如我们只想取前三条记录

select * from job limit 3;
ac5192173f623a812a0ea6ab258abf83.png

或者我们对排序后的字段取前三条记录

select * from job order by salary limit 3;
76054a57da213f21e5e462463e8945e2.png

上面这种 limit 是从表记录的第 0 条开始取,如果从指定记录开始取,比如从第二条开始取,取三条记录,SQL 如下

select * from job order by salary desc limit 2,3;
b22761aba73b63218712c4f0e64ad6d3.png

limit 一般经常和 order by 语法一起实现分页查询。

注意:limit 是 MySQL 扩展 SQL92 之后的语法,在其他数据库比如 Oracle 上就不通用,我犯过一个白痴的行为就是在 Oracle 中使用 limit 查询语句。。。

聚合

下面我们来看一下对记录进行汇总的操作,这类操作主要有

  • 汇总函数,比如 sum 求和、count 统计数量、max 最大值、min 最小值等
  • group by,关键字表示对分类聚合的字段进行分组,比如按照部门统计员工的数量,那么 group by 后面就应该跟上部门
  • with 是可选的语法,它表示对汇总之后的记录进行再次汇总
  • having 关键字表示对分类后的结果再进行条件的过滤。

看起来 where 和 having 意思差不多,不过它们用法不一样,where 是使用在统计之前,对统计前的记录进行过滤,having 是用在统计之后,是对聚合之后的结果进行过滤。也就是说 where 永远用在 having 之前,我们应该先对筛选的记录进行过滤,然后再对分组的记录进行过滤。

可以对 job 表中员工薪水进行统计,选出总共的薪水、最大薪水、最小薪水

select sum(salary) from job;
07d797b0fd1fa6116c68efa0b088375b.png
select max(salary),min(salary) from job;
9825ec9333f3eb7c11a5c695e730cffd.png

比如我们要统计 job 表中人员的数量

select count(1) from job;

统计完成后的结果如下

2f17d956ae1e2d02da64a91e22766bb8.png

我们可以按照 job 表中的年龄来进行对应的统计

select age,count(1) from job group by age;
f7fd093bdf1f6c50b7161a39daa9ffb8.png

既要统计各年龄段的人数,又要统计总人数

select age,count(1) from job group by age with rollup;
b20140d9b61206cb7826c40e963df151.png

在此基础上进行分组,统计数量大于 1 的记录

select age,count(1) from job group by age with rollup having count(1) > 1;
178fc93fbf9385ad6b4b662424e6054f.png

表连接

表连接一直是笔者比较痛苦的地方,曾经因为一个表连接挂了面试,现在来认真撸一遍。

表连接一般体现在表之间的关系上。当需要同时显示多个表中的字段时,就可以用表连接来实现。

为了演示表连接的功能,我们为 job 表加一个 type 字段表示工作类型,增加一个 job_type 表表示具体的工作种类,如下所示

d1110d01e98e8ac4e02237757ad2f7d0.png

下面开始我们的演示

查询出 job 表中的 type 和 job_type 表中的 type 匹配的姓名和工作类型

select job.name,job_type.name from job,job_type where job.type = job_type.type;
ac0e1538244750a6cc5243529f833efe.png

上面这种连接使用的是内连接,除此之外,还有外连接。那么它们之间的区别是啥呢?

内连接:选出两张表中互相匹配的记录;

外连接:不仅选出匹配的记录,也会选出不匹配的记录;

外连接分为两种

  • 左外连接:筛选出包含左表的记录并且右表没有和它匹配的记录
  • 右外连接:筛选出包含右表的记录甚至左表没有和它匹配的记录

为了演示效果我们在 job 表和 job_type 表中分别添加记录,添加完成后的两表如下

d908e5f712e1e508290d8666e55063df.png

下面我们进行左外连接查询:查询出 job 表中的 type 和 job_type 表中的 type 匹配的姓名和工作类型

select job.name,job_type.name from job left join job_type on job.type = job_type.type;

查询出来的结果如下

d8cb650f72625abed4967c9b86bf3a52.png

可以看出 cxuan06 也被查询出来了,而 cxuan06 他没有具体的工作类型。

使用右外连接查询

select job.name,job_type.name from job right join job_type on job.type = job_type.type;
d910bb38b45c54ade000237895c1433b.png

可以看出,job 表中并没有 waiter 和 manager 的角色,但是也被查询出来了。

子查询

有一些情况,我们需要的查询条件是另一个 SQL 语句的查询结果,这种查询方式就是子查询,子查询有一些关键字比如 in、not in、=、!=、exists、not exists 等,例如我们可以通过子查询查询出每个人的工作类型

select job.* from job where type in (select type from job_type);
d60a9c22f525e76020ca1a97f82e783b.png

如果自查询数量唯一的话,还可以用 = 来替换 in

select * from job where type = (select type from job_type);
f5da74f2b6409873c31e138283f02e49.png

意思是自查询不唯一,我们使用 limit 限制一下返回的记录数

select * from job where type = (select type from job_type limit 1,1);
626775328f503b356b1d6770cf48a5b0.png

在某些情况下,子查询可以转换为表连接

联合查询

我们还经常会遇到这样的场景,将两个表的数据单独查询出来之后,将结果合并到一起进行显示,这个时候就需要 UNION 和 UNION ALL 这两个关键字来实现这样的功能,UNION 和 UNION ALL 的主要区别是 UNION ALL 是把结果集直接合并在一起,而 UNION 是将 UNION ALL 后的结果进行一次 DISTINCT 去除掉重复数据。

比如

select type from job union all select type from job_type;

它的结果如下

dddda7032ddc270767b00213b339e4cc.png

上述结果是查询 job 表中的 type 字段和 job_type 表中的 type 字段,并把它们进行汇总,可以看出 UNION ALL 只是把所有的结果都列出来了

使用 UNION 的 SQL 语句如下

select type from job union select type from job_type;
02045c8582e599ff1141357f5643e023.png

可以看出 UNION 是对 UNION ALL 使用了 distinct 去重处理。

DCL 语句

DCL 语句主要是管理数据库权限的时候使用,这类操作一般是 DBA 使用的,开发人员不会使用 DCL 语句。

关于帮助文档的使用

我们一般使用 MySQL 遇到不会的或者有疑问的东西经常要去查阅网上资料,甚至可能需要去查 MySQL 官发文档,这样会耗费大量的时间和精力。

下面教你一下在 MySQL 命令行就能直接查询资料的语句

按照层次查询

可以使用 ? contents 来查询所有可供查询的分类,如下所示

? contents;
af92d93365f80b1bc07c0f616470676a.png

我们输入

? Account Management

可以查询具体关于权限管理的命令

8d99b105f8ade76887f74deab9a16e80.png

比如我们想了解一下数据类型

? Data Types
216abad05a281b23e67b3e7b12deafa2.png

然后我们想了解一下 VARCHAR 的基本定义,可以直接使用

? VARCHAR
c1d8a5bbb9ef15d4c8080c929130dd38.png

可以看到有关于 VARCHAR 数据类型的详细信息,然后在最下面还有 MySQL 的官方文档,方便我们快速查阅。

快速查阅

在实际应用过程中,如果要快速查询某个语法时,可以使用关键字进行快速查询,比如我们使用

? show
18aa01f4e8a4143d7456b6536f2125e3.png

能够快速列出一些命令

比如我们想要查阅 database 的信息,使用

SHOW CREATE DATABASE cxuandb;
89c403414005af2e3ede7a58877692a2.png
智慧旅游解决方案利用云计算、物联网和移动互联网技术,通过便携终端设备,实现对旅游资源、经济、活动和旅游者信息的智能感知和发布。这种技术的应用旨在提升游客在旅游各个环节的体验,使他们能够轻松获取信息、规划行程、预订票务和安排食宿。智慧旅游平台为旅游管理部门、企业和游客提供服务,包括政策发布、行政管理、景区安全、游客流量统计分析、投诉反馈等。此外,平台还提供广告促销、库存信息、景点介绍、电子门票、社交互动等功能。 智慧旅游的建设规划得到了国家政策的支持,如《国家中长期科技发展规划纲要》和国务院的《关于加快发展旅游业的意见》,这些政策强调了旅游信息服务平台的建设和信息化服务的重要性。随着技术的成熟和政策环境的优化,智慧旅游的时机已经到来。 智慧旅游平台采用SaaS、PaaS和IaaS等云服务模式,提供简化的软件开发、测试和部署环境,实现资源的按需配置和快速部署。这些服务模式支持旅游企业、消费者和管理部门开发高性能、高可扩展的应用服务。平台还整合了旅游信息资源,提供了丰富的旅游产品创意平台和统一的旅游综合信息库。 智慧旅游融合应用面向游客和景区景点主管机构,提供无线城市门户、智能导游、智能门票及优惠券、景区综合安防、车辆及停车场管理等服务。这些应用通过物联网和云计算技术,实现了旅游服务的智能化、个性化和协同化,提高了旅游服务的自由度和信息共享的动态性。 智慧旅游的发展标志着旅游信息化建设的智能化和应用多样化趋势,多种技术和应用交叉渗透至旅游行业的各个方面,预示着全面的智慧旅游时代已经到来。智慧旅游不仅提升了游客的旅游体验,也为旅游管理和服务提供了高效的技术支持。
智慧旅游解决方案利用云计算、物联网和移动互联网技术,通过便携终端设备,实现对旅游资源、经济、活动和旅游者信息的智能感知和发布。这种技术的应用旨在提升游客在旅游各个环节的体验,使他们能够轻松获取信息、规划行程、预订票务和安排食宿。智慧旅游平台为旅游管理部门、企业和游客提供服务,包括政策发布、行政管理、景区安全、游客流量统计分析、投诉反馈等。此外,平台还提供广告促销、库存信息、景点介绍、电子门票、社交互动等功能。 智慧旅游的建设规划得到了国家政策的支持,如《国家中长期科技发展规划纲要》和国务院的《关于加快发展旅游业的意见》,这些政策强调了旅游信息服务平台的建设和信息化服务的重要性。随着技术的成熟和政策环境的优化,智慧旅游的时机已经到来。 智慧旅游平台采用SaaS、PaaS和IaaS等云服务模式,提供简化的软件开发、测试和部署环境,实现资源的按需配置和快速部署。这些服务模式支持旅游企业、消费者和管理部门开发高性能、高可扩展的应用服务。平台还整合了旅游信息资源,提供了丰富的旅游产品创意平台和统一的旅游综合信息库。 智慧旅游融合应用面向游客和景区景点主管机构,提供无线城市门户、智能导游、智能门票及优惠券、景区综合安防、车辆及停车场管理等服务。这些应用通过物联网和云计算技术,实现了旅游服务的智能化、个性化和协同化,提高了旅游服务的自由度和信息共享的动态性。 智慧旅游的发展标志着旅游信息化建设的智能化和应用多样化趋势,多种技术和应用交叉渗透至旅游行业的各个方面,预示着全面的智慧旅游时代已经到来。智慧旅游不仅提升了游客的旅游体验,也为旅游管理和服务提供了高效的技术支持。
深度学习是机器学习的一个子领域,它基于人工神经网络的研究,特别是利用多层次的神经网络来进行学习和模式识别。深度学习模型能够学习数据的高层次特征,这些特征对于图像和语音识别、自然语言处理、医学图像分析等应用至关重要。以下是深度学习的一些关键概念和组成部分: 1. **神经网络(Neural Networks)**:深度学习的基础是人工神经网络,它是由多个层组成的网络结构,包括输入层、隐藏层和输出层。每个层由多个神经元组成,神经元之间通过权重连接。 2. **馈神经网络(Feedforward Neural Networks)**:这是最常见的神经网络类型,信息从输入层流向隐藏层,最终到达输出层。 3. **卷积神经网络(Convolutional Neural Networks, CNNs)**:这种网络特别适合处理具有网格结构的数据,如图像。它们使用卷积层来提取图像的特征。 4. **循环神经网络(Recurrent Neural Networks, RNNs)**:这种网络能够处理序列数据,如时间序列或自然语言,因为它们具有记忆功能,能够捕捉数据中的时间依赖性。 5. **长短期记忆网络(Long Short-Term Memory, LSTM)**:LSTM 是一种特殊的 RNN,它能够学习长期依赖关系,非常适合复杂的序列预测任务。 6. **生成对抗网络(Generative Adversarial Networks, GANs)**:由两个网络组成,一个生成器和一个判别器,它们相互竞争,生成器生成数据,判别器评估数据的真实性。 7. **深度学习框架**:如 TensorFlow、Keras、PyTorch 等,这些框架提供了构建、训练和部署深度学习模型的工具和库。 8. **激活函数(Activation Functions)**:如 ReLU、Sigmoid、Tanh 等,它们在神经网络中用于添加非线性,使得网络能够学习复杂的函数。 9. **损失函数(Loss Functions)**:用于评估模型的预测与真实值之间的差异,常见的损失函数包括均方误差(MSE)、交叉熵(Cross-Entropy)等。 10. **优化算法(Optimization Algorithms)**:如梯度下降(Gradient Descent)、随机梯度下降(SGD)、Adam 等,用于更新网络权重,以最小化损失函数。 11. **正则化(Regularization)**:技术如 Dropout、L1/L2 正则化等,用于防止模型过拟合。 12. **迁移学习(Transfer Learning)**:利用在一个任务上训练好的模型来提高另一个相关任务的性能。 深度学习在许多领域都取得了显著的成就,但它也面临着一些挑战,如对大量数据的依赖、模型的解释性差、计算资源消耗大等。研究人员正在不断探索新的方法来解决这些问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值