* 课程回顾:
    * 完成注册和登陆的功能。
    * 准备的工作
        * 技术、开源jar包

    * 开发的功能使用MVC模式
    * C:控制层(接收请求和从客户端发送过来的参数)
        * 接收参数(request对象)
        * 为了操作方便(封装数据,内省,BeanUtils开源的工具)
        * 自己new User(); user.setXXX数据
        * 完成业务逻辑的代码(不推荐写在Servlet)   new UserService();
        * 接收结果,通过结果把显示的数据发送给JSP。(把结果存入域对象)

    * M:模型层(JavaBean封装数据,其他JavaBean处理业务)
        * 处理业务逻辑根据注册的功能。(用户名不能重名,邮箱不能重名)
        * 需要把结果返回去。

    * V:视图层(完成数据的显示)
        * 到JSP的页面,通过EL表达式取域的值。

==========================================================================================================
    * MySQL数据库
        * 数据库
            * 数据库就是一个文件系统,访问数据的时候需要通过标准的SQL语言来完成。

        * 关系型的数据
            * 保存的实体与实体之间的关系。(用户、商品、订单)

        * 常见的数据库
            * Oracle        公司Oracle(甲骨文)数据产品,收费的大型的数据库。
            * MySQL         开源的,被Oracle收购了,小型的数据库。5.x版本免费,6.x收费了。
            * SQLServer     微软的,收费的中型的数据库。
            * DB2           IBM公司收费的大型的数据库。
            * SyBASE        PowerDigener软件(非常牛)

        * MySQL的简介
            * 卸载干净
                * 找到MySQL的安装路径,找到my.ini的配置文件。
                * basedir="C:/Program Files (x86)/MySQL/MySQL Server 5.5/"      安装的路径
                * datadir="C:/ProgramData/MySQL/MySQL Server 5.5/Data/"         MySQL存储数据的路径

                * 通过控制面板卸载MySQL
                * 找到上面的两个路径,删除就ok了。

            * 安装了
                * 安装路径不要有中文(*****)
                * MySQL默认端口是3306,不要修改。
                * 设置MySQL的编码集(采用UTF-8的编码)
                * 要把黑窗口的勾勾选上。
                * 设置用户名的密码:两行都是密码,第一行是密码,第二行是确认密码。
                * 安装完成。

            * 访问:
                cmd > 输入命令  mysql -u root -p 回车
                输入密码 回车

            * 密码重置
                1.停止mysql服务:
                    services.msc 进入到服务界面

                2.在cmd>输入一个命令:
                    mysqld --skip-grant-tables  (开启一个mysql服务,不需要进行认证.)

                3.新打开一个cmd窗口
                    mysql -u root -p  不需要输入密码.就可以进入.

                4.输入命令 show databases;查看数据库,输入命令 use mysql;使用mysql数据库。
                5.修改密码的语句:
                    update user set password=password('root') WHERE user='root';
                6.将两个窗口都关闭.
                7.任务管理器中结束(mysqld)进程.
                8.重启mysql服务

        * MySQL之间的关系(看图)
            * 总结:一个数据库的服务器中有多个数据库,一个数据库中有多个表,
                每个表有多个字段。字段和Java中类的属性是对应的。
                每一条记录对应是一个Java实例对象。

        * SQL语句(*****)
            * SQL的简介
                * Structured Query Language, 结构化查询语言
                * 非过程性的语言
                    * 过程性的语言:我下一条语句,需要依赖上一条或者上几条语句。
                    * 非过程性的语言:写一条语句,就会执行一个结果。

                * Oracle开发PL/SQL,只能在Oracle使用。
                * SQL Server、Sybase的T-SQL

            * SQL语言分类
                * DDL(数据定义语言)
                    * 创建数据库、创建表

                * DML(数据操纵语言)(*****)
                    * 插入数据(insert) 修改数据(update) 删除数据(delete)

                * DCL (数据控制语言)
                    * if else

                * DQL(数据查询语言)(*****)
                    * 查询数据 select

            * 数据库(CURD -- 增删改查)
                * 创建数据库
                    * 语法:create database 数据名称;      创建一个数据了。
                    *       create database 数据库名称 character set 编码 collate 校对规则;

                    * 校对规则:和编码是成对出现的。

                * 练习
                    创建一个名称为mydb1的数据库。
                        create database mydb1;
                    创建一个使用utf8字符集的mydb2数据库。
                        create database mydb2 character set 'utf8';
                    创建一个使用utf8字符集,并带校对规则的mydb3数据库。
                        create database mydb3 character set 'utf8' collate 'utf8_bin';

                * 查看数据库 show databases;
                * 查询数据库的定义  show create database 数据库;
                    show create database mydb2;

                * 删除数据库 drop database 数据库名称;

                练习
                    查看当前数据库服务器中的所有数据库
                        show databases;
                    查看前面创建的mydb2数据库的定义信息
                        show create database mydb2;
                    删除前面创建的mydb1数据库
                        drop database mydb1;

                * 修改数据库
                    * 语法:alter database 数据库 character set 编码 collate 校对规则;

                    * 练习:查看服务器中的数据库,并把其中某一个库的字符集修改为gbk
                        alter database mydb2 character set 'gbk';

                * 其他的操作
                    * 切换数据库(*****) use db_name;
                    * 查看当前使用的数据库 select database();

            * 表(table)(CURD -- 增删改查)
                * 语法:
                    create table 表名(
                        字段1 类型(长度) 约束,
                        字段2 类型(长度) 约束,
                        字段3 类型(长度) 约束,
                        字段4 类型(长度) 约束
                    );

                    注意:
                        * 表名小括号,后面要有分号。
                        * 每一行字段后面要有逗号,但是最后一行没有逗号。
                        * 数据的类型后面有长度,如果是字符串类型,长度必须加。如果其他类型可以不加。默认长度。int 默认长度11

                    public class User{
                        int id;
                        String name;
                        String pass;
                        String eamil;
                        String nikename;
                    }

                * 数据的类型
                    字符串型
                    VARCHAR、CHAR
                        * varchar和char区别:
                            * varchar(经常使用) 长度是可变的。 name varchar(8) 存入数据hello,但是如果存入helloworld报错了。
                            * char              长度不可变的。   name char(8) 存入的数据hello,如果不够用空格补全。
                            * 效率高:char效果。

                    大数据类型(一般不用)
                    BLOB、TEXT
                        BLOB:二进制文件
                        TEXT:字符

                    数值型
                    TINYINT 、SMALLINT、INT、BIGINT、FLOAT、DOUBLE

                    逻辑性 对应boolean
                    BIT

                    日期型
                    DATE、TIME、DATETIME、TIMESTAMP
                        * date  只包含日期
                        * time  只包含时分秒
                        * datetime和timestamp包含日期和时分秒区别:
                            * datetime需要手动录入时间。
                            * timestamp不传入数据,默认选择当前系统时间。

                * 练习,创建表的练习
                    create table employee(
                        id int,
                        name varchar(20),
                        gender varchar(10),
                        birthday date,
                        entry_date date,
                        job varchar(100),
                        salary double,
                        resume text
                    );

            * 约束(单表)
                * 主键约束(*****)
                    * 标识标记该条记录。 通过pramary key声明主键。(默认唯一、非空)
                    * auto_increment    数据库维护主键。自动增长。

                * 唯一约束
                    * 值是唯一的。使用unique声明

                * 非空约束
                    * 值不能为空 not null

            * 创建新的标签employee2,把约束加上。
                create table employee2(
                    id int primary key auto_increment,
                    name varchar(20) unique not null,
                    gender varchar(10) not null,
                    birthday date not null,
                    entry_date date not null,
                    job varchar(100) not null,
                    salary double not null,
                    resume text not null
                );

            * 使用desc 表名; 查看表的信息
            * show tables ; 查看当前库内所有表名
            * show create table 表名; 查看建表语句和字符集

            * 删除表
                drop table employee2;

            * 修改表
                alter table 表名 add 字段 类型(长度) 约束;                    -- 添加字段
                alter table 表名 drop 字段;                                 -- 删除字段
                alter table 表名 modify 字段 类型(长度) 约束;             -- 修改类型或者约束
                alter table 表名 change 旧字段 新字段 类型(长度) 约束     -- 修改字段的名称  

                rename table 表名 to 新表名;                             -- 修改表名
                alter table 表名 character set utf8;                      -- 修改字符集

            * 练习
                在上面员工表的基本上增加一个image列。
                    alter table employee add image varchar(20);
                修改job列,使其长度为60。
                    alter table employee modify job varchar(60);
                删除gender列。
                    alter table employee drop gender;
                表名改为user。
                    rename table employee to user;
                修改表的字符集为utf8
                    alter table user character set utf8;
                列名name修改为username
                    alter table user change name username varchar(30);

        * 数据(CURD -- 增删改查)(******)

            * 添加数据
            * insert into 表名 (字段1,字段2,字段3..) values(值1,值2,值3...);   有几列就插入多少的值。
            * insert into 表名 values(值1,值2,值3...);                           插入所有的列

            * 注意:
                * 数据与字段的类型相同。
                * 字段长度需要控制。
                * 字符串或者日期类型需要使用''   

            * 向user表中插入数据
                insert into user values (1,'xiaofeng','1994-10-10','2011-1-1','HR',19000,'aaa','abc');
                insert into user values (2,'美美','1994-10-10','2011-1-1','HR',19000,'aaa','abc');
                insert into user values (3,'小风','1994-10-10','2011-1-1','WORKER',21000,'aaa','abc');
                insert into user values (4,'芙蓉','1994-10-10','2011-1-1','HR',1000,'aaa','abc');
                insert into user values (5,'班长','1994-10-10','2011-1-1','HR',100,'aaa','abc');

            * 解决中文乱码的问题(*****)
                [client]
                port=3306
                [mysql]
                default-character-set=gbk
            * 修改完需要重新启动服务。  

        * 修改语句
            * 语法:   update 表名 set 字段=值,字段=值... [where ]
                * 如果没有where条件,默认更新所有的记录。
                * 有where提交,选择某一条记录。

            将所有员工薪水修改为5000元。
                update user set salary=5000;

            将姓名为’班长’的员工薪水修改为3000元。
                update user set salary=3000 where username='班长';

            将姓名为’美美’的员工薪水修改为4000元,job改为BOSS。
                update user set salary=4000,job='BOSS' where username='美美';

            将班长的薪水在原有基础上增加1000元。
                update user set salary = salary+1000 where username='班长';

        * 删除数据  delete
            语法:delete from 表名 [where ]; 删除数据
            truncate 表名; 删除所有的数据

            * truncate 和 delete的区别:
                * truncate删除数据,先删除整个表。再创建一个新的空的表。(效率)
                * delete删除数据,一条一条删除的。(*****)

                * 事物(insert update delete)

            删除表中名称为’班长’的记录。
                * delete from user where username='班长';
            删除表中所有记录。
                * delete from user;
            使用truncate删除表中记录。
                * truncate user;

        * 查询语句
            * 语法:   select * from 表名;                               查询所有(字段)
                        select 字段名1,字段名2,字段名3 from 表名;      显示查询字段名
                        select DISTINCT 字段名 from 表名;                去除重复的数据。        

            查询表中所有学生的信息。
                select * from stu;
            查询表中所有学生的姓名和对应的英语成绩。
                select name,english from stu;
            过滤表中重复数据。(面试题)
                select distinct english from stu;

            * 查询的列可以运算
            * 可以使用别名:使用as 别名        并且as可以省略。

                练习:
                    在所有学生分数上加10分特长分。
                        select name,math+10,english+10,chinese+10 from stu;
                    统计每个学生的总分。
                        select name,math+english+chinese from stu;

                    使用别名表示学生分数。
                    select name,(math+english+chinese) as sum from stu;

            * 使用where条件过滤
                查询姓名为班长的学生成绩
                    select * from stu where name='班长';

                查询英语成绩大于90分的同学
                    select name,english from stu where english < 15;

                查询总分大于200分的所有同学
                    select name,math+english+chinese from stu where (math+english+chinese) > 200;

            * 常用的符号
                >   <   <=   >=   =    <>(不等于)
                in(范围内取内容)
                like        -- 模糊查询     写法:like '张_或者%';    _和%区别:占位符。_只一个%可以有多个
                                                    %的写法    like '%张';      结果XXX张
                                                            like '张%';      结果张XXX
                                                            like '%张%'; 只要有张就行
                is null     -- 判断是否为null
                and         -- 并且
                or          -- 或者
                not         -- 不成立

                * 练习
                    查询英语分数在 80-90之间的同学。
                        select * from stu where english >80 and english <90;
                        select * from stu where english between 80 and 90;

                    查询数学分数为18,78,46的同学。(in)
                        select * from stu where math in(18,78,46);

                    查询所有姓班的学生成绩。
                        select * from stu where name like '班%';
                    查询数学分>80,语文分>80的同学。
                        select * from stu where math >80 or chinese > 80;

            * 排序    使用order by 升序默认的(asc)/降序(desc)
                * 出现select的语句末尾。

                练习
                    对数学成绩排序后输出。
                        select name,math from stu order by math;
                    对总分排序按从高到低的顺序输出
                        select name,math+english+chinese from stu order by (math+english+chinese) desc;
                    对学生成绩按照英语进行降序排序,英语相同学员按照数学降序
                        select * from stu order by english desc,math desc;

                    对姓美的学生成绩排序输出
                        select * from stu where name like '美%' order by english desc;

            * 聚集函数
                * count     获取数量
                    练习:
                    统计一个班级共有多少学生?
                        select count(*) from stu;
                    统计数学成绩大于90的学生有多少个?
                        select count(*) from stu where math > 90;
                    统计总分大于150的人数有多少?
                        select count(*) from stu where (math+english+chinese) > 150;

                * sum       求和(忽略null值)     可以同ifnull(xxx,0)
                    统计一个班级数学总成绩?
                        select sum(math) from stu;
                    统计一个班级语文、英语、数学各科的总成绩
                        select sum(math),sum(english),sum(chinese) from stu;
                    统计一个班级语文、英语、数学的成绩总和
                        select sum(ifnull(math,0)+english+chinese) from stu;
                        select sum(math)+sum(english)+sum(chinese) from stu;

                    统计一个班级语文成绩平均分
                        select sum(chinese) / count(*) from stu;

                * avg       平均数
                    练习:
                    求一个班级数学平均分?
                        select avg(math) from stu;
                    求一个班级总分平均分
                        select avg(ifnull(math,0)+english+chinese) from stu;

                * max       最大值
                    select max(math) from stu;
                * min       最小值
                    select min(math) from stu;

                * group by  分组(一起使用)    条件过滤需要是having,不能使用where
                    练习:对订单表中商品归类后,显示每一类商品的总价.
                        select product,count(*),sum(price) from orders group by product;

                    练习:查询购买了几类商品,并且每类总价大于100的商品
                        select product,sum(price) from orders group by product having sum(price) > 100;

        * 小结 select 语句 : S-F-W-G-H-O 组合 select ... from ... where ... group by... having... order by ... ;
                    顺序不能改变

create table orders(
    id int,
    product varchar(20),
    price float
);

insert into orders(id,product,price) values(1,'电视',900);
insert into orders(id,product,price) values(2,'洗衣机',100);
insert into orders(id,product,price) values(3,'洗衣粉',90);
insert into orders(id,product,price) values(4,'桔子',9);
insert into orders(id,product,price) values(5,'洗衣粉',90);
insert into orders(id,product,price) values(6,'电视',900);
重置密码
1.停止mysql服务:
    services.msc 进入到服务界面

2.在cmd>输入一个命令:
    mysqld --skip-grant-tables  (开启一个mysql服务,不需要进行认证.)

3.新打开一个cmd窗口
    mysql -u root -p  不需要输入密码.就可以进入.

4.输入命令 show databases;查看数据库,输入命令 use mysql;使用mysql数据库。

5.修改密码的语句:
    update user set password=password('root') WHERE user='root';

6.将两个窗口都关闭.

7.任务管理器中结束(mysqld)进程.

8.重启mysql服务

MySQL安装图解

一、MYSQL的安装

1、双击打开mysql-5.5.27-win32.msi进行安装”。

选择我同意

2、选择安装类型,有“Typical(默认)”、“Complete(完全)”、“Custom(用户自定义)”三个选项,选择“Custom”,按“next”键继续。

3、可以选择MySQL的安装路径和数据的安装路径。

选择MySQL Server,点击Browse.. 选择安装的路径。

还可以选择Server data files,点击Browse..选择安装的路径。

4、填上安装目录,我的是“F:\Server\MySQL\MySQL Server 5.0”,也建议不要放在与操作系统同一分区,这样可以防止系统备份还原的时候,数据被清空。按“OK”继续。

确认一下先前的设置,如果有误,按“Back”返回重做。按“Install”开始安装。

5、正在安装中,请稍候,直到出现下面的界面

点击Finish完成安装。

二、MYSQL的配置

1、安装完成了,出现如下界面将进入mysql配置向导。

2、选择配置方式,“Detailed Configuration(手动精确配置)”、“Standard Configuration(标准配置)”,我们选择“Detailed Configuration”,方便熟悉配置过程。

3、选择服务器类型,“Developer Machine(开发测试类,mysql占用很少资源)”、“Server Machine(服务器类型,mysql占用较多资源)”、“Dedicated MySQL Server Machine(专门的数据库服务器,mysql占用所有可用资源)”

4、选择mysql数据库的大致用途,“Multifunctional Database(通用多功能型,好)”、“Transactional Database Only(服务器类型,专注于事务处理,一般)”、“Non-Transactional Database Only(非事务处理型,较简单,主要做一些监控、记数用,对MyISAM数据类型的支持仅限于non-transactional),按“Next”继续。

默认选择Next

5、选择网站并发连接数,同时连接的数目,“Decision Support(DSS)/OLAP(20个左右)”、“Online Transaction Processing(OLTP)(500个左右)”、“Manual Setting(手动设置,自己输一个数)”。

6、MySQL的默认端口号是3306,不要去修改,咱们都使用默认的端口号就OK。在这个页面上,您还可以选择“启用标准模式”(Enable Strict Mode),这样MySQL就不会允许细小的语法错误。如果是新手,建议您取消标准模式以减少麻烦。但熟悉MySQL以后,尽量使用标准模式,因为它可以降低有害数据进入数据库的可能性。按“Next”继续

7、就是对mysql默认数据库语言编码进行设置(重要),一般选UTF-8,按 “Next”继续。

8、选择是否将mysql安装为windows服务,还可以指定Service Name(服务标识名称),是否将mysql的bin目录加入到Windows PATH(加入后,就可以直接使用bin下的文件,而不用指出目录名,比如连接,“mysql.exe -uusername -ppassword;”就可以了,不用指出mysql.exe的完整地址,很方便),我这里全部打上了勾,Service Name不变。按“Next”继续。

9、询问是否要修改默认root用户(超级管理)的密码。“Enable root access from remote machines(是否允许root用户在其它的机器上登陆,如果要安全,就不要勾上,如果要方便,就勾上它)”。最后“Create An Anonymous Account(新建一个匿名用户,匿名用户可以连接数据库,不能操作数据,包括查询)”,一般就不用勾了,设置完毕,按“Next”继续。

10、确认设置无误,按“Execute”使设置生效,即完成MYSQL的安装和配置。

注意:设置完毕,按“Finish”后有一个比较常见的错误,就是不能“Start service”,一般出现在以前有安装mysql的服务器上,解决的办法,先保证以前安装的mysql服务器彻底卸载掉了;不行的话,检查是否按上面一步所说,之前的密码是否有修改,照上面的操作;如果依然不行,将mysql安装目录下的data文件夹备份,然后删除,在安装完成后,将安装生成的 data文件夹删除,备份的data文件夹移回来,再重启mysql服务就可以了,这种情况下,可能需要将数据库检查一下,然后修复一次,防止数据出错。

数据库-MYSQL安装配置和删除的更多相关文章

  1. Linux 数据库MySql 安装配置教程!

    本文价绍Linux 相关mysql 安装和配置以及基本连接测试 1官网下载安装mysql-server # wget http://dev.mysql.com/get/mysql-community- ...

  2. Linux下的Mysql安装 & 配置

    Hive的数据,是存在HDFS里的.此外,hive有哪些数据库,每个数据库有哪些表,这样的信息称之为hive的元数据信息. 元数据信息不存在HDFS里.而是存在关系型数据库里,hive默认用的是der ...

  3. mysql 安装配置及经常使用操作

    作为关系型数据库的一种,mysql因其占用内存小和开源等特性而兴起.以下简介下关于mysql配置和简单的操作. mysql配置 1.安装文件的下载 免安装版下载地址 :http://dev.mysql ...

  4. MySQL---5、可视化工具Navicat for MySQL安装配置

    一.安装文件包下载 Navicat for MySQL 安装软件和破解补丁: 链接:https://pan.baidu.com/s/1oKcErok_Ijm0CY9UjNMrnA   密码:4xb1 ...

  5. Linux-CentOS7环境MySQL安装配置

    Linux-CentOS7环境MySQL安装配置 1. 安装准备 (1)检查MySQL是否已安装 (2)如果有的话,就全部卸载 2. 安装libaio (1)检索相关信息: (2)安装依赖包: 3. ...

  6. Linux(Manjaro) - Docker - MySQL 安装配置

    Linux(Manjaro) - Docker - MySQL 安装配置 拉取mysql镜像 # 使用网易的 MySQL 镜像地址 docker pull hub.c.163.com/library/ ...

  7. FreeRADIUS + MySQL 安装配置笔记

    FreeRADIUS + MySQL 安装配置笔记 https://www.2cto.com/net/201110/106597.html

  8. 数据库 MySQL安装图解

    MySQL安装图解 一.MYSQL的安装 1.打开下载的mysql安装文件,双击运行mysql-5.5.40-win32.msi. 2.选择安装类型,有"Typical(默认)". ...

  9. tomcat和mysql安装配置总结

    我安装的tomcat和mysql都是解压缩版的.安装和配置tomcat倒没花费我多少时间,主要是mysql,几乎花费了我一天的时间. Tomcat安装总结: 首先将下载好的tomcat压缩包解压放在其 ...

随机推荐

  1. Android studio中找不到so文件的问题:java.lang.UnsatisfiedLinkError

    解决Android studio中找不到so文件的问题:java.lang.UnsatisfiedLinkError 表示我们不编译jni代码,直接从libs里面复制so库 文件路径:app\buil ...

  2. bzoj2002: [Hnoi2010]Bounce 弹飞绵羊 [分块][LCT]

    Description 某天,Lostmonkey发明了一种超级弹力装置,为了在他的绵羊朋友面前显摆,他邀请小绵羊一起玩个游戏.游戏一开始,Lostmonkey在地上沿着一条直线摆上n个装置,每个装置 ...

  3. 【.net 深呼吸】在运行阶段修改应用配置文件

    上一篇博文中,老周所介绍的自行编写的配置类,虽然能够很好地做封装,但它仅允许修改用户级别的配置,所以文件都是保存到用户配置目录下的.可是,许多情况下,我们还是不考虑用户隔离,而是能够直接修改与应用程序 ...

  4. 【Django】Python web开发:几个模板系统的性能对比(转)

    http://blog.chedushi.com/archives/910 结论: 点评一下吧.django就是个渣,不多废话了.webpy的代码很简洁,可惜速度太慢了.bottle看起来快一点,不过 ...

  5. AtCoder Beginner Contest 068

    A - ABCxxx 题意: 给出n,输出“ABCn”就可以了,纯水题. B - Break Number 题意: 给出n,找出从1到n的闭区间内能够被2整除最多次的数. 思路: 直接模拟. 代码: ...

  6. ES6数组扩展

    前面的话 数组是一种基础的JS对象,随着时间推进,JS中的其他部分一直在演进,而直到ES5标准才为数组对象引入一些新方法来简化使用.ES6标准继续改进数组,添加了很多新功能.本文将详细介绍ES6数组扩 ...

  7. springboot用thymeleaf模板的paginate分页

    本文根据一个简单的user表为例,展示 springboot集成mybatis,再到前端分页完整代码(新手自学,不足之处欢迎纠正): 先看java部分 pom.xml 加入 <!--支持 Web ...

  8. Keras Xception Multi loss 细粒度图像分类

    作者: 梦里茶 如果觉得我的工作对你有帮助,就点个star吧 关于 这是百度举办的一个关于狗的细粒度分类比赛,比赛链接: http://js.baidu.com/ 框架 Keras Tensorflo ...

  9. python-桶排序

    桶排序 通排序非常浪费空间, 比如需要排序的范围在0~2000之间, 需要排序的数是[3,9,4,2000], 同样需要2001个空间 注意: 通排序不能排序小数 以下为从小到大代码实现 #!/usr ...

  10. ReactiveSwift源码解析(十) Lifetime代码实现

    为了之后博客的进行,本篇博客我们就来聊一下ReactiveSwift框架中的Lifetime类的具体实现.从Lifetime这个名字中我们就这道,就是生命周期.在ReactiveSwift中使用Lif ...