热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Swift3.0服务端开发(四)MySQL数据库的连接与操作

本篇博客我们来聊聊MySQL数据库的连接与操作。如果你本地没有MySQL数据库的话,需要你先安装MySQL数据库。在Mac OS中使用brew包管理器进行MySQL的安装是及其方便的。安装MySQL的命令为:brew install mysql。本篇博客我们就要使用Perfect框架来连接操作数据库了,首先我们需要创建一个测试数据库,然后在测试数据库中创建一张测试表用来增删改查操作。

在博客的开头呢,先来推荐一款Mac上比较好用又免费的MySQL可视化管理工具Sequel Pro。这款工具用的是相当的顺手呢,应用的图标如下所示:

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

 

一、测试数据库的创建

本部分与Perfect框架无关,完全是MySQL的内容,是Perfect操作数据库的准备工作。前提是你已经安装好了MySQL数据库了。

 

1、启动MySQL的服务器

这一点虽然简单,但不要忘记启动你的MySQL服务呢,不然Sequel Pro是无法连接你的MySQL数据库的。具体启动方式如下。

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

启动是start,那么关闭MySQL数据库就是stop了,如下所示:

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

 

2.使用Sequel Pro连接操作数据库

(1)、连接MySQL数据库

打开Sequel Pro,输入你MySQL的主机名,用户名以及密码。具体连接那个数据库可以不选,然后填上具体的端口,默认是3306。点击连接即可。具体如下所示:

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

 

(2)、创建测试数据库

然后点击添加数据库,创建新的数据库即可,下方我们创建的是test数据库,编码方式用的是utf8。如下所示。

  Swift3.0服务端开发(四) MySQL数据库的连接与操作Swift3.0服务端开发(四) MySQL数据库的连接与操作

 

(3)、创建user表

创建完数据库后,接下来我们要创建一个user表用来进行测试。点击左下方的加号来创建新的数据库表,下方就是我们创建的数据库表的具体步骤以及具体的参数配置。如下所示:

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

创建完user表后,我们需要往表里边添加一些测试字段,下方就是我们添加的一些字段。在我们的user表中有下方四个字段,id是主键,用户的唯一标示。username-用户名,password-用户密码,create_time是创建时间,create_time的类型是时间戳,而且默认值是当前时间。具体如下所示。

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

 

 

二、Perfect数据库连接

万事俱备只欠东风,上面准备完MySQL数据库后,我们就要开始进行Perfect框架连接数据库的内容了。

1.引入依赖库

依照惯例,Perfect框架连接数据库依然需要包的支持。首先我们需要引入操作MySQL相关的包。

 //MySql数据库依赖包

.Package(url: "https://github.com/PerfectlySoft/Perfect-MySQL.git",
majorVersion: 2, minor: 0)

下方是添加完上述的依赖包后,重新进行编译的结果:

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

 

2、数据库连接

下方代码段中的MySQLConnnet类就负责数据库的连接并且选择相应的数据库。下方是MySQLConnnet类的整体结构,host,port,user,password都是只读的计算属性,负责配置连接数据库的参数。而mysql属性就是连接数据库后的操作句柄。下方主要有两个方法,一个是连接数据库的方法connectDataBase()和选择数据库的方法selectDataBase()MySQLConnnet类对外是以单例的形式存在的,不过对外暴漏的不是MySQLConnnet类的对象,而是MySQL类的对象。

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

接下来给出具体的代码实现,下方就是MySQLConnnet类的单例和私有构造器。具体实现如下所示:

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

下方是数据库的连接,核心语句就是下方红框中的内容。主要还是调用MySQL类中的connect()方法,在调用该方法时传入相应的参数即可。如果连接失败了会返回相应的errorMessage。具体代码如下所示:

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

连接完数据库后,然后是选择数据库,下方是选择数据库的代码。使用mysql句柄调用selectDataBase()方法,具体代码如下所示:

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

 

 

三、数据库操作

接下来我们就要调用上面的数据库操作类类操作具体数据库中的表了。在第一部分我们已经创建好了test数据库,并且创建好了相应的user表。接下来我们就要使用Swift代码来对User表进行增删改查操作了。

 

1.构建数据库操作基类

下方截图就是我们构建的数据库操作的基类,所有数据库表的操作都要继承自该基类,在基类中定义了操作数据库的名字dataBaseNameMySQL操作句柄mysql,以及响应json的格式responsJson。具体如下所示。

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

 

2.构建user表的操作类

下方的UserOperator类就是我们创建的专门来操作user表的类,主要是对user表的增删改查操作。insertUserInfo()负责“增”,即插入用户信息。deleteUser()负责“删”,通过userId来删除用户。updateUserInfo()就负责“改”,更新用户信息。queryUserInfo()就负责“查”了,负责从user表中通过用户名来查询信息。

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

 

(1)、InsertUserInfo()----"增"

下方就是插入数据的具体代码,第一个框就是我们要执行的SQL语句,然后使用mysql操作句柄调用query()方法进行SQL语句的执行。执行成功后,查询插入的数据并返回查询的结果,如下所示。

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

 

(2)、deleteUserInfo()----"删"

接下来我们来看一下删除的具体操作,下方截图就是deleteUserInfo()的具体实现。下方的方法与插入差不多,先给出delete的SQL语句,然后再调用mysql操作句柄的query()操作,具体代码如下所示:

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

 

(3)、updateUserInfo----更新用户信息

下方是更新用户信息的代码,与上两个代码差不多,只不过是通过mysql操作句柄调用query()方法执行的是update的SQL语句。更新时我们使用了MySQL的now()函数来更新时间,具体代码如下所示。

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

 

(4)、queryUserInfo----查询

接着我们来实现一下查询用户信息的代码。下方就是查询用户信息的代码,查询的代码稍微复杂一些,在执行完查询的SQL语句后,还需要价格查询结果进行存储。在存储后,会返回查询的结果results。我们可以通过resultsforEachRow()函数的尾随闭包来获取每行的数据。在取出数据后,将其转换成相应的字典,然后将存有查询结果的字典存入到responseJson中,然后将responseJson转换为json字符串返回给用户即可。具体做法如下所示。

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

 

 

四、测试用例

上面我们写完操作User表的相应的方法后接下来我们就来测试一些具体的结果。为了方便测试,我们配置4个路由专门用来对User表的增删改成进行操作。每个路由对应着上面每个方法。本部分就给出相应的测试用例。为了方便测试,我们在路由配置时,指定请求方法全是GET请求。

 

1、对“增”的测试

接下来我们对InsertUserInfo()的的测试,首先我们添加一个请求方式为GET的“/create”路由,然后获取用户提交的userName和password。获取完毕后,调用UserOperator对象的insertUserInfo()方法将数据插入到数据库中。当然插入后,会接着将数据查询出来返回给客户端的。

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

我们在浏览器里访问“http://127.0.0.1:8181/create?userName=Hellow&password=1234”这个地址,就会将用户Hellow,密码为1234的用户插入到数据库。当然我们故意将Hello写成了Hellow稍后进行更新。下方就是具体的操作结果:

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

 

2.对“改”的测试

接下来我们就要测试一下updateUserInfo()这个函数,该部分与上述的代码差不多,也是需要配置一个请求方式为GET的更新路由“/update”。然后在该路由中获取请求参数,然后调用updateUserInfo()这个函数即可。具体代码就不做过多赘述了,直接看下方的测试结果吧。通过结果不难看出,用户名被修改成正确的Hello了,而且时间也被更新了。

  Swift3.0服务端开发(四) MySQL数据库的连接与操作

 

剩下的查与删,和上方的示例差不多,在此就不做过多赘述了,我们的MySQL数据库的操作就先聊到这吧。官方上还介绍了一些数据库的ORM操作,其中就有MySQL的ORM操作,可以简化一些数据操作。这一点就留给读者自己去看吧。

 


推荐阅读
  • WhenIusepythontoapplythepymysqlmoduletoaddafieldtoatableinthemysqldatabase,itdo ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 本文详细介绍了MysqlDump和mysqldump进行全库备份的相关知识,包括备份命令的使用方法、my.cnf配置文件的设置、binlog日志的位置指定、增量恢复的方式以及适用于innodb引擎和myisam引擎的备份方法。对于需要进行数据库备份的用户来说,本文提供了一些有价值的参考内容。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 关于我们EMQ是一家全球领先的开源物联网基础设施软件供应商,服务新产业周期的IoT&5G、边缘计算与云计算市场,交付全球领先的开源物联网消息服务器和流处理数据 ... [详细]
  • r2dbc配置多数据源
    R2dbc配置多数据源问题根据官网配置r2dbc连接mysql多数据源所遇到的问题pom配置可以参考官网,不过我这样配置会报错我并没有这样配置将以下内容添加到pom.xml文件d ... [详细]
  • 本文介绍了将mysql从5.6.15升级到5.7.15的详细步骤,包括关闭访问、备份旧库、备份权限、配置文件备份、关闭旧数据库、安装二进制、替换配置文件以及启动新数据库等操作。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了如何使用Power Design(PD)和SQL Server进行数据库反向工程的方法。通过创建数据源、选择要反向工程的数据表,PD可以生成物理模型,进而生成所需的概念模型。该方法适用于SQL Server数据库,对于其他数据库是否适用尚不确定。详细步骤和操作说明可参考本文内容。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • Oracle10g备份导入的方法及注意事项
    本文介绍了使用Oracle10g进行备份导入的方法及相关注意事项,同时还介绍了2019年独角兽企业重金招聘Python工程师的标准。内容包括导出exp命令、删用户、创建数据库、授权等操作,以及导入imp命令的使用。详细介绍了导入时的参数设置,如full、ignore、buffer、commit、feedback等。转载来源于https://my.oschina.net/u/1767754/blog/377593。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
author-avatar
转化术治_953
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有