iOS学习笔记41-Swift(一)基础部分

7. 运算符

Swift除去支持中心运算符以外,还多了2个独特之运算符,分别是距离运算符和浩起运算符

/**
 * 区间运算符,通常用于整形或者字符范围(例如"a"..."z")
 */
for i in 1...5 { //闭区间运算符...(从1到5,包含5)
    println("i=\(i)")
}
for i in 1..<5{ //半开区间运算符..<(从1到4)
    println("i=\(i)")
}
var str = "hello world."
var range = "a"..."z"
for t in str {
    if range.contains(String(t)) {
        print(t) //结果:helloworld
    }
}
//溢出运算符
var a = UInt8.max //a = 255
Error: -> var b:UInt8 = a + 1 //注意b会出现溢出,此句报错
//下面使用溢出运算符,结果为:0
Success: -> var b:UInt8 = a &+ 1
//类似的还有&-、&*、&/,使用溢出运算符可以在最大值和最小值之前循环而不会报错,下面c的值为255
Success: -> var c:UInt8 = b &- 1

Azure SQL 的版本

Azure SQL Database 是微软资的 SQL 服务(PaaS)。最新的版为 Azure SQL
Database V12,其实微软还是通过 SQL Server 2014 来提供数据库服务:

 葡京在线开户 1

达成图中率先个数据库服务器是本地安装的 SQL Server
2014,第二只同老三只则是云上的 Azure SQL
Database。我们得挺清楚的观望,它们的版是平等的。

而是只是不用以为 Azure SQL Database
提供的数据库及当地安装版本是千篇一律的哦。它们还是产生为数不少异样之,这同碰于搬现有数据库时尤其重大。

由于提供的是在线的劳动,所以 Azure SQL Database
可以便捷的披露新特点,这些自不断更新的 MSDN
文档可见一斑。MS也强烈建议我们当跟 Azure SQL Database
打交道时一定要因此时髦版本的工具。笔者于正开应用了 SQL Server 2014 中的
SSMS (SQL Server Management Studio) ,结果连 Azure SQL
后发现显示的消息和 Azure portal 对无达到,安装时版本的 SSMS 后问题消灭。

脚进入正题,看看迁移的进程被都亟需哪的工具,如何操作和要留意的事项。在斯特别强调,旧数据库一般还是高居正在使的状态,所以绝对不要以真的仓库上举行各种尝试。笔者有着的最初试验都是当经过恢复备份文件创建的测试库上得的。

 

5. 元组使用

元组就像是休能够修改的数组一样,元组中的价是免克改改的,不过元组内之价值好假设任意档次,并无求是平档次,这或多或少跟数组不同

/**
 * 元组的基本用法
 */
var point = (x:50, y:100) //自动推断其类型:(Int,Int)
print(point.x) //可以用类似于结构体的方式直接访问元素,结果:50
print(point.y) //结果:100
print(point.0) //也可以采用类似数组的方式使用下标访问,结果:50
print(point.1) //结果:100

//元组也可以不指定元素名称,访问的时候只能使用下标
let frame:(Int,Int,Int,Float) = (0,0,100,100.0)
print(frame) //结果:(0, 0, 100, 100.0)

//注意下面的语句是错误的,如果指定了元组的类型则无法指定元素名称
Error: -> let frame:(Int,Int,Int,Int) = (x:0, y:0, width:100, height:100)

var size = (width:100, 25) //仅仅给其中一个元素命名
print(size.width) //结果:100
print(size.1)  //结果:25

var httpStatus:(Int,String) = (200, "success") //元组的元素类型并不一定相同

var (status, description) = httpStatus //一次性赋值给多个变量,此时status=200,description="success"

//接收元组的其中一个值忽略另一个值使用"_"(注意在Swift中很多情况下使用_忽略某个值或变量)
var ( sta , _ ) = httpStatus
print("sta = \(sta)") //结果:sta = 200

 

有啊问题在下方评论区中提出!O(∩_∩)O哈!

创建 clustered index

兼容性检查的报显示下面的音:

One or more unsupported elements were found in the schema used as part of a data package.

Error SQL71564: Table Table: [dbo].[xxxx] does not have a clustered index.  Clustered indexes are required for inserting data in this version of SQL Server.

其间的xxxx是数据库中同张表的名号。

用为表创建 clustered
index,这不过免是一致码小事情,因为另外对表的改都或会见潜移默化到程序逻辑,怎么惩罚吧?网上的冤家等早已来矣于靠谱的解决方案,就是于表上加同排用来开
clustered index,这样原本表中的排列就从未有过发生变化:

ALTER TABLE [xxxx] ADD

RowId int NOT NULL IDENTITY (1, 1) PRIMARY KEY CLUSTERED

GO
4. 凑合类型应用
//Array数组
//定义数组的几种方式
var arrStr1:Array<String> = ["hello","world"]
var arrStr2:[String] = ["hello","world"]
var arrDouble1:[Double] = []
var arrDouble2 = [Double]()
//追加元素
arrStr1 += ["Swift","Obj-C"]    //arrStr1 = ["hello","world","Swift","Obj-C"]
arrStr1.append("Swift")         //arrStr1 = ["hello","world","Swift","Obj-C","Swift"]
//修改元素,x...y表示[x,y]区间,是Swift语法特性
arrStr1[3...4] = ["Array","Change"]    //arrStr1 = ["hello","world","Swift","Array","Change"]
arrStr1[1] = "Nice"                 //arrStr1 = ["hello","Nice","Swift","Array","Change"]
//删除元素
arrStr1.removeAtIndex(1)               //arrStr1 = ["hello","Swift","Array","Change"]
//插入元素
arrStr1.insert("insert", atIndex: 2)   //arrStr1 = ["hello","Swift","insert","Array","Change"]

//Set集合
var setStr1:Set<String> = ["hello","world"] //定义集合,注意集合没有数组的简化格式
var setStr2:Set = [1,2]             //自动推导类型为Set<Int>
setStr1.insert("!")     //插入元素,不保证顺序
setStr1.remove("!")     //删除元素
setStr1.contains("!")     //判断是否包含

//Dictionary字典
var dictIntToStr1:Dictionary<Int,String> = [200:"success", 404:"error"]
var dictIntToStr2:[Int:String] = [200:"success", 404:"error"]
var dictIntToStr3 = [200:"success", 404:"error"]        //自动推导为[Int,String]类型
dictIntToStr2[200] = "hahaha"        //修改元素,通过key找到value,进行修改
dictIntToStr1[500] = "server"        //添加元素 500:"server"
print(dictIntToStr1) //结果:[500: "server", 200: "success", 404: "error"]
print(dictIntToStr2) //结果:[200: "hahaha", 404: "error"]
print(dictIntToStr3) //结果:[200: "success", 404: "error"]

兴打地方访问 Azure SQL Server

Azure SQL Server 创建好后,我们由此 SSMS
测试一下连连情况。当我们输入了是的地点和用户信息后倒弹有了一个提拔框:

 葡京在线开户 2

它唤醒我们,当前之IP不克看 Azure 上的数据库服务器,并且为自身坐 Azure
账号登录并创立同漫长防火墙规则。

骨子里就是 Azure
提供的一个安康法,它深受您显式的指定哪些IP地址或者IP网段可以拜 Azure
SQL Server。

这儿咱们发出个别种缓解办法:

1.点击对话框中之 ”Sign in”,用 Azure 账户登录;然后点击
”OK”,此时曾经做到了防火墙规则的设置,SSMS 已报到 Azure SQL
Server。这种艺术一般用来开发以及测试,只能添加当前客户端所下的IP。

2.更是通用的艺术是登录 Azure portal,进入 Azure SQL Server
的配备界面,为防火墙添加规则。同样的,可以添加单个IP也可以同蹩脚补充加一个网段:

 葡京在线开户 3

 

3. 基础项目应用
import Foundation
var intValue:Int = 1            //通过var定义一个Int变量
var floatValue:Float = 1.0      //通过var定义一个Float变量
var doubleValue:Double = 2.0000     //通过var定义一个Double变量
var boolValue:Bool = true           //通过var定义一个Bool变量,if语句中的条件只能是布尔类型
var charValue:Character = "c"       //通过var定义一个Character变量
var strValue:String = "hello"       //通过var定义一个String变量
let number:Int = 1      //let表示常量,值不能被修改
let numMax = Int.max    //枚举值,Int整形最大值9223372036854775807
let score = 96      //自动推导为Int类型
let width = 10.32       //自动推导为Double类型
let name = "Join"       //自动推导为String类型
let anotherPi = 3 + 0.14159 //表达式中同时出现了整数和浮点数,会被推测为Double类型 

/* println中通过的\(var或者let变量)进行格式化输出 */
println("log some value: score = \(score)")
//等价于println("log some value: score = " + String(score))

//Swift是强类型语言,不同类型变量不能运算,会报错,但字面量除外
Error: -> let sum = intValue + floatValue
Success: -> let sumNum = 1 + 1.2
  1. Swift通过var开展变量定义,通过let展开常量定义(这和JavaScript类似)
  1. Swift添加了品种推断,对于赋值的常量或者变量会自动测算其切实品种
  2. Swift强类型语言,不同的数据类型之间不能够隐式转化,如果急需转接只能强制转化
  3. Swift惨遭类型转换直接通过该列构造函数即可,降低了API的学习成本

不支持Extended Property

兼容性检查的语显示下面的消息:

One or more unsupported elements were found in the schema used as part of a data package.

Error SQL71564: The element Extended Property: [dbo].[xxxx].[MS_Description] is not supported when used as part of a data package (.bacpac file).

内部的xxxx是数据库被相同张表的名目。

即时下可麻烦了,不支持 Extended
Property!在笔者之数据库中来好几处于还用到了是特性。怎么收拾?只好一总体又同样任何的查看程序。最后发现先后中并未动是特性,好像这只是有人用它举行了一些认证。还好,最终之下结论是可以移除的。

第二、Swift基础部分

搬要接触分析

同一、Swift语言介绍

  • Swift大凡苹果2014年推出的崭新的编程语言,它延续了C语言、ObjC的性状,且克服了C语言的兼容性问题。
  • Swift迈入历程遭到不仅仅保留了ObjC很多语法特性,它也借鉴了多现代化语言的风味,在中你可视C#JavaJavascriptPython相当多种语言的阴影。
  • 以2015年之WWDC上,苹果还公布Swift的新本子Swift2.0,并于随后公布Swift开源,除了支持iOS、OS
    X之外还将支持Linux。
  • Swift言语是苹果强推的均等栽编程语言,未来或者会见代表ObjC的身份。

此处不见面起零基础一点点解析这门语言的语法,旨在帮助大家迅速从ObjC高速衔接至Swift付出被,入门初学可以参见The
Swift Programming Language中文手册 和Swift系列学习推荐

Xcode从6.0上马在了Playground代码测试,可以实时查看代码执行结果,如果还未曾Xcode6以上的,可以利用在线Swift编译网站调试:Swift在线编译网站

前不久来只保障的品类要将 SQL Server 2012 的数据库迁移至 Azure SQL
上去,迁移过程可谓一波三折,故在是分享这次迁徙中遇见的点点滴滴,希望对情人等有助。

8. 控制流

Swift的大多数控制流和其它语言相差不很,有for-inwhiledo-whileif-elseswitch抵,下面就讲一些特别之语法:

var a = ["a","b","c","d","e","f","g"]
let b = a[1]
/**
* switch支持一个case多个模式匹配,
* 同时case后不用写break也会在匹配到种情况后自动跳出匹配,不存在隐式贯穿,
* 如果想要贯穿在case之后添加"fallthrough"关键字
*/
switch b{
case "a","b":
    println("b = a or b = b")
case "c","d","e","f":
    println("b in (c,d,e,f)")
default:
    println("b = g")
}
/**
 * switch匹配区间,同时注意switch必须匹配所有情况,否则必须加上default
 */
let c:Int = 88
switch c{
case 1...60:
    println("1 - 60")
case 61...90:
    println("61 - 90")
case 91...100:
    println("91 - 100")
default:
    println("1 > c > 100")
}
/**
*  switch元组匹配、值绑定、where条件匹配
*  注意下面的匹配没有default,因为它包含了所有情况
*/
var d = (x:900, y:0)
switch d{
case (0, 0):
    println("d in (0,0)")
case (_, 0):        //忽略x值匹配
    println("d in y")
case (0, let y):        //值绑定
    println("d in x,y = \(y)")
case (-100...100, -100...100): 
    //注意这里有可能和第一、二、三个条件重合,但是Swift允许多个case匹配同一个条件,但是只会执行第一个匹配
    println("x in(0-100),y in (0-100)")
case let (x, y) where x == y: //where条件匹配,注意这里的写法等同于:(let x,let y) where x==y
    println("x = y = \(x)")
case let (x, y):
    println("x = \(x),y = \(y)")    
}
/* 利用标签你可以随意指定转移的位置 */
var a = 5
whileLoop: while --a > 0 {
    for var i = 0;i < a;++i{
        println("a=\(a),i=\(i)")
       /* 
          如果此处直接使用break将跳出for循环,而由于这里使用标签直接跳出了while,
          结果只会打印一次,其结果为:a=4,i=0
       */
        break whileLoop
    }
}

数据库被安装的用户不在

兼容性检查的报显示下面的音信:

Error SQL71564: Error validating element [xxxx]: The element [xxxx] has been orphaned from its login and cannot be deployed.

个中的xxxx是数据库中安装的用户称。

是荒唐的原委是用户给定义在地头的 SQL Server
中,数据库被假如用用户之音讯,把数据库迁移到讲话上后,就搜不至对应用户之概念了,所以就是得移除本地用户的音。

甭操心数据库的造访问题,因为成功搬迁后,你可使刚才创建的 Azure SQL
Server
账号访问数据库。当然你为堪为一个数据库创建独立的顾账号,具体操作请参考
MSDN。

6. 只是选类型使用

方的类型定义的常量或变量初始化都要出价,而只是选类型暗示了常量或者变量可以没有价值

/**
 * 可选类型基础
 */
var x:Float? //使用?声明成一个可选类型,如果不赋值,默认为nil
x = 172.0
var y:Float = 60.0

//注意此句报错,因为Int和Int?根本就是两种不同的类型,在Swift中两种不同的类型不能运算
Error: -> var z = x + y 
Success: -> var z = x! + y     //使用!进行强制解包,得到基本类型

//注意ageInt是Int可选类型而不是Int类型,因为String的toInt()方法并不能保证其一定能转化为Int类型
var age:String = "29"
var ageInt = Int(age) //ageInt是Int?可选类型

/**
* 可选类型判断
*/
if ageInt == nil {
    print("ageInt = nil")
} else {
    print("ageInt = \(ageInt!)") //注意这里使用感叹号!强制解析
}

/**
 * 可选类型绑定
 * 如果可选类型有值,则将值赋值给一个临时变量或者常量(此时此变量或者常量接受的值已经不是可选类型)
 * 如果没有值,则不执行此条件
 */
if let newAge = ageInt{ //此时newAge可以定义成常量也可以定义成变量
    print("newAge = \(newAge)") //注意这里并不需要对newAge强制解包
} else {
    print("ageInt = nil")
}

/**
* 隐式解析可选类型
*/
var age2:Int! = 0 //通过感叹号声明隐式解析可选类型,此后使用时虽然是可选类型但是不用强制解包
age2 = 29
var newAge:Int = age2 //不用强制解包直接赋值给Int类型(程序会自动解包)

if let tempAge = age2 {
    print("tempAge = \(tempAge)")
}else{
    print("age=nil")
}
  1. Swift受到接近于IntInt?连无是一模一样种植档次,不克拓展有关运算,如果如运算只能用感叹号解包;
  1. 但是选类型其庐山真面目,就是此类型内部存储分为SomeNone少个组成部分,如果有价则存储到Some蒙,没有值则为None,使用感叹号强制解包的过程就取出Some部分;
  2. 而一个可选类型从第一糟糕赋值之后便会担保发生价,那么以时就是无须进行强制解包了,这种情景下得以隐式可选解析类型

兼容性处理

是因为 MS SQL Server
版本群,且曰上的本子与本土本也有差异,所以能够不能够迁徙成功,主要关押能无克找到并缓解数据库里的兼容性问题。

下用详细的牵线笔者碰到的兼容性问题。

2. 数据类型

Swift包含了C和ObjC语言中的有所基础项目,还增了片高阶类型

  1. 基本功项目:
  • Int整形和UInt无符号整形
  • FloatDouble浮点型
  • Bool布尔型
  • Character字符型
  • String字符串类型

  • 枚举类型enum以及组织体类型struct

  • 聚类型

  • Array数组

  • Set集合
  • Dictionary字典

  • 高阶数据类型

  • Tuple元组

  • Optinal而选类型

其他

再有一些点,主要是跟事务相关的,就未以是赘述。个人感觉绝大多数底问题在网上还发生两样之解决方案,关键是要是下自己的作业会经受之法去化解问题。

连片下把所有对数据库的反写成一个本子文件,在业内的搬中,直接当正规库上推行脚本文件。

1. 第一个Swift程序
import Foundation
/* Swift没有main函数,默认从第一个非声明语句开始执行,自上而下执行 */
println("Hello World!")
  1. Swift没有main函数,第一个非声明语句开始施行,表达式或者控制结构,类、结构体、枚举和方齐属于声明语句。
  1. Swift通过import引入其他类库,和Python言语的导入好像。
  2. Swift喻句子不需双引号结尾(尽管增长也无报错),除非一行包含多长语句,也和Python稍许类似。

结语

是因为一切搬迁过程涉及的满实在太多,本文只是概要式的介绍笔者觉得迁移过程遭到之要点和团结遇的题目。总体感觉是MS提供的工具还算是比较完善,网络直达之各种已领略问题迎刃而解方案吗老详细。所以尽管笔者碰到了众多底题材,但未曾死的地方,总算磕磕绊绊的得了数据库迁移的任务。

 

有关阅读:

最好咸的Windows
Azure学习课程汇总

Azure Blob Storage 基本用法 — Azure Storage 之
Blob

Azure Queue Storage 基本用法 — Azure Storage 之
Queue

Azure File Storage 基本用法 — Azure Storage 之
File

Azure Table storage 基本用法 — Azure Storage 之
Table

 

搬过程

MS提供了不同之家伙进行兼容性检查、迁移等工作。我们这边全采取 SSMS (SQL
Server Management Studio) 。

脚看看具体的操作步骤。

在 SSMS 中右键需要迁移的数据库,选择 Tasks 中之 ”Deploy Database to
Microsoft Azure SQL Database…”。

 葡京在线开户 4

以开拓的引路中点击 “next” 进入 “Deployment Settings” 界面。

先是需要设置Azure SQL Server的连天地址与连续账号:

 葡京在线开户 5

连片下设置迁移后的数据库名称及资源配置:

 葡京在线开户 6

顾 Azure SQL Database
settings,MS把数据库使用的资源划分成了三单不同的种类:Basic, Standard,
Premium。每个门类中又分了不同的收费标准,简单说哪怕是公只要动用更多更好的资源就假设付出更多之钱。当然也可以反过来说,如果本身所以的资源不多,付一点点钱就是足够了!

俺们发现及图被的终极一行要求我们也 *.bacpac
文件指定一个囤路径。*.bacpac
文件是搬迁过程被变化的中级文件,当兼容性检查通过后,就将数据库被的具有内容还导出到这文件中。从者消息我们可得知,无论使用何种迁移方式,其中心操作都是个别步:先由当地数据库生成
*.bacpac 文件,再从*.bacpac 文件恢复一个 Azure SQL Database。

单击 “Next”
显示配置的详情,再下同样步就是起兼容性检查。如果无兼容性问题,就行迁移操作。

自身的数据库是一些兼容性问题,所以展示了错误报告并停止了搬操作:

 葡京在线开户 7

点击 “Result”
列中的链接就是可知看到详细的告诉,前面已经介绍过兼容性问题,直接实施我们处理兼容性问题的台本文件,然后再试一次!

 葡京在线开户 8

这次的实施业已远非错误提示了,其实后台就起来了搬迁过程。比较不便利的凡此过程没详尽的进度提示,只能耐心等。我的经验数据是8G的堆栈完成搬迁大概是8-12小时。当然这同汝总是
Azure 的带来富有大挺的涉…

兼容性处理详情

于云端创建 Azure SQL Server

Azure SQL Database 是运作于 Azure SQL Server 中之,所以我们要在 Azure
上先把 Azure SQL Server 创建好。操作过程比较简单,直接在 Azure 上添加
SQL Server (logical server)
就好了,请留心选择适用的区域(这会影响访问速度)。