开发了5年android,我开始了go学习之旅

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

c234ff479d1bbf91910bb1b66e39e927b064c003

做了近5年的android开发,最近项目也是不怎么忙,空闲的时候总会思考一些事情,不过作为移动开发,我个人觉得很有必要学习后台开发,由于公司是Go语言开发的,了解go语言一段时间后,我发现go语言的强大。基于优雅的语法和其强大的并发性,我开启我的go学习之旅。

对Go不太了解的童鞋们可参考:体验golang语言的风骚编程>>

golang强大的数据库驱动

Go与PHP不同的地方是Go没有官方提供数据库驱动,而是为开发者开发数据库驱动定义了一些标准接口,开发者可以
根据定义的接口来开发相应的数据库驱动,这样做有一个好处,只要按照标准接口开发的代码, 以后需要迁移数据
库时,不需要任何修改

不乱说用到MySQL还是sqlite3,都需要提前安装数据库驱动

sqlite3

32 位 windows 的安装

1、安装 sqlite3。到 http://www.sqlite.org/download.html 的页面中,找到 sqlite-dll-win32-x86-3071700.zip 下载解压,并把里面的 dll 文件复制到 windows/system32 目录下。

2、下载 gcc 编译器。到 http://tdm-gcc.tdragon.net/download,下载 tdm-gcc-4.7.1-2。如果是 64 位的 win,下载 tdm64-gcc-4.7.1-3。运行这个 exe 文件,安装好 gcc 编译器。

3、运行命令:go get github.com/mattn/go-sqlite3 ,安装 go 的 sqlite3 的驱动等。

64 位 windows 的安装

1、下载 gcc 编译器。到 http://tdm-gcc.tdragon.net/download,下载 tdm64-gcc-4.7.1-3。运行这个 exe 文件,安装好 gcc 编译器。

2、运行命令:go get github.com/mattn/go-sqlite3 ,安装 go 的 sqlite3 的驱动等。

MySQL

下载:Go语言的 database/sql 包的一个 MySQL驱动。

地址: https://golang.org/pkg/database/sql/

github地址:

https://github.com/go-sql-driver/mysql

官网地址:

http://godoc.org/github.com/go-sql-driver/mysql。

也可以在shell下面执行命令:

go get github.com/go-sql-driver/mysql
开发阶段
https://github.com/Go-SQL-Driver/MySQL 支持database/sql,全部采用go写。
https://github.com/ziutek/mymysql 支持database/sql,也支持自定义的接口,全部采用go写。
https://github.com/Philio/GoMySQL 不支持database/sql,自定义接口,全部采用go写。

以MySQL为例:

使用

sql包的用法简洁明了:

1、建立连接

首先是Open,

db, err := sql.Open(“mysql”, “user:password@/dbname”)

解释:

db 是一个*sql.DB类型的指针,在后面的操作中,都要用到db open之后,并没有与数据库建立实际的连接,与数据库建立实际的连接是通过Ping方法完成。此外,db应该在整个程序的生命周期中存在,也就是说,程序一启动,就通过Open获得db,直到程序结束,再Close db,而不是经常Open/Close。
err = db.Ping()

2、基本用法

DB的主要方法有:

  • Query 执行数据库的Query操作,例如一个Select语句,返回*Rows

  • QueryRow 执行数据库至多返回1行的Query操作,返回*Row

  • PrePare 准备一个数据库query操作,返回一个*Stmt,用于后续query或执行。这个Stmt可以被多次执行,或者并发执行

  • Exec 执行数不返回任何rows的据库语句,例如delete操作

Stmt的主要方法:

  • Exec

  • Query

  • QueryRow

  • Close

用法与DB类似

Rows的主要方法:

  • Cloumns: 返回[]string,column names

  • Scan:

  • Next:

  • Close:

详见:
http://golang.org/pkg/database/sql/
https://github.com/go-sql-driver/mysql/wiki/Examples
https://github.com/VividCortex/go-database-sql-tutorial
备注

Mysql的数据库开启方式:

1、打开任务管理器→打开服务→查找到服务名称为→Mysql的服务→启动就ok了。

2、Ctrl+R 输入cmd 。在你的Mysql配置好的情况下,你可以输入net start mysql命令

简单开发测试案例

//插入
func insert(db *sql.DB) {
   stmt, err := db.Prepare("INSERT INTO user(username, password) VALUES(?, ?)")
   defer stmt.Close()

   if err != nil {
       log.Println(err)
       return
   }
   stmt.Exec("guotie""guotie")
   stmt.Exec("testuser""123123")

}
var CURRENT_AGE = 20
var  sex   = "男"

//公共类,检查错误
func checkError(str  string,err error) bool{
   if err !=  nil{
       fmt.Printf(str+" %s \b \n",err.Error())
       panic(err)
       return false
   }
   return true
}

func main() {
   db, err := sql.Open("mysql""root:yyh123@tcp(localhost:3306)/test?charset=utf8")
   checkError("打开一个 数据库",err)

   //创建数据库
   //createDataBase(db)
   //userDb(db)

   createTable(db)
   insertTableContent(db)
   queryFromDb(db)
   updataFromDb(db)
   //deleteFromTabCase(db)
   //dropTab(db)
}

//删除表
func dropTab(db *sql.DB) {
   res ,erro := db.Exec("drop table tb_user")
   if erro != nil{
       panic(erro)
   }
    affect,erro := res.RowsAffected()
    if erro != nil{
       checkError("删除表\n",erro)
   }
   fmt.Printf("\n删除表成功 ,结果影响的行数是:%d\n",affect)
}
//删除表周中数据
func deleteFromTabCase(db *sql.DB) {
    stmt ,err := db.Prepare("delete from tb_user where name = ?")
    checkError("根据条件进行删除表",err)

   res ,err :=  stmt.Exec("卡卡罗特")
   if err!= nil{
       panic(err)
   }

   affect, err := res.RowsAffected()
   lastId, err := res.LastInsertId()
   fmt.Printf("affect : %d   lasetId: %d",affect,lastId)
}
//更新数据
func updataFromDb(db *sql.DB) {
   stmt ,err := db.Prepare("update tb_user set name = ? where name = ?")
   checkError("查询条件数据库",err)
   result ,erro := stmt.Exec("卡卡罗特","yuer")
   if erro != nil{
       checkError("查询条件数据库",erro)
   }
   affect ,err := result.RowsAffected()
   checkError("查询的结果",err)
   fmt.Printf("更新的数据:%d",affect)
}

//查询数据
func queryFromDb(db *sql.DB) {
   row, error := db.Query("select * from tb_user")

    if checkError("查询数据库",error){
        defer  row.Close()
            for row.Next(){
                var id int
                var name string
                var age int
                var sex string
                var addr string
                var tel string
                row.Scan(&id,&name,&age,&sex,&addr,&tel)

                fmt.Printf("查询到了: id:  %d  %s %d  %s  %s  %s \n",id,name,age ,sex,addr,tel)
           }

    }
   //row, error := db.Query("select * from tb_user")
}

//增加:既插入数据
func insertTableContent(db *sql.DB) {
   //var userId int = utils.GetNowtimeMD5()
   stmt ,err := db.Prepare("insert   tb_user set id = ?, name = ? ,age = ?, sex = ?,addr = ?,tel=?;")
   //stmt, err := db.Prepare("insert userinfo set username=?,departname=?,created=?,password=?,uid=?")
   checkError("准备阶段,回准备要执行的sql操作,然后返回准备完毕的执行状态。",err)

   if CURRENT_AGE % 2 == 0{
       sex = "男"
   }else{
       sex = "女 "
   }
   CURRENT_AGE = CURRENT_AGE+utils.Generate_Randnum()
   result, err :=stmt.Exec(CURRENT_AGE,"yuer",CURRENT_AGE,sex,"河南省商水县等城镇林村","13011007869")
   if err != nil{
       panic(err)
   }
   fmt.Println("插入数据成功",result)
}

//创建表
func createTable(db *sql.DB) {
   _, err := db.Exec("CREATE TABLE IF NOT EXISTS tb_user(id int(10) primary key,name varchar(20),age int(10),sex varchar(5),addr varchar(64),tel varchar(11));")
   if err != nil {
       fmt.Println("create table  failed:", err.Error())
       return
   }
   fmt.Println("创建表成功啦~~")
   //第二种方式
   stmt, erro := db.Prepare(userDetail)
   if erro != nil {
       panic(erro)
   }

   _, err = stmt.Exec()
   if err != nil {
       panic(err)
   }
}

func main1() {
   db, err := sql.Open("mysql""root:yyh123@tcp(10.2.0.215:3306)/test?charset=utf8")
   if err != nil {
       log.Fatalf("Open database error: %s\n", err)
   }
   defer db.Close()

   err = db.Ping()
   if err != nil {
       log.Fatal(err)
   }

   insert(db)

   rows, err := db.Query("select id, username from user where id = ?"1)
   if err != nil {
       log.Println(err)
   }

   defer rows.Close()
   var id int
   var name string
   for rows.Next() {
       err := rows.Scan(&id, &name)
       if err != nil {
           log.Fatal(err)
       }
       log.Println(id, name)
   }

   err = rows.Err()
   if err != nil {
       log.Fatal(err)
   }
}


当然 ,也可以到博客里去看我平常做的一些笔记,有时候公众号不方便编辑,我这边就在博客里面做一下Note,以便后期查看。

https://blog.csdn.net/androidstarjack/article

总结

今天的总结只是go开发的冰山一角,接下来还需要学习很多。之所以学Go,公司的需要以及自己考虑到今后的职业规划,虽然目前还是一Android开发为主,不过个人的精力很多时候放到了go上面,自己也建立的有微信交流群,,如果你也有兴趣,可以一起来探讨go。


原文发布时间为:2018-11-12

本文作者:安卓混合开发外包

本文来自云栖社区合作伙伴“终端研发部”,了解相关信息可以关注“终端研发部”。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2天前
|
持续交付 Android开发 开发者
构建高性能微服务架构:后端开发的终极指南构建高效Android应用:Kotlin与Jetpack的完美结合
【5月更文挑战第28天】 在现代软件开发的浪潮中,微服务架构已经成为了设计灵活、可扩展且易于维护系统的重要模式。本文将深入探讨如何构建一个高性能的微服务架构,涵盖从基础概念理解到实践策略部署的全过程。我们将讨论关键的设计原则、技术选型、性能优化技巧以及安全性考虑,旨在为后端开发者提供一个全面的指南,帮助他们构建出能够适应快速变化的市场需求和技术挑战的系统。 【5月更文挑战第28天】 在移动开发的世界中,效率和性能是衡量一个应用成功与否的关键因素。本文将深入探讨如何通过结合Kotlin语言和Android Jetpack组件,来构建一个既高效又易维护的Android应用。我们将透过实际案例分析
|
2天前
|
Java Android开发 Swift
揭秘安卓与iOS开发的核心差异
本文深入探讨了安卓与iOS这两大移动操作系统在应用开发过程中的关键不同点。我们将从编程语言、用户界面设计、应用市场政策、硬件集成以及开发者支持等多个维度展开比较,为开发者提供一个清晰的框架,帮助他们根据项目需求和目标受众选择最合适的平台。
|
3天前
|
Android开发 开发者 UED
安卓应用开发中的性能优化技巧
在当今移动应用市场竞争激烈的环境中,用户对于应用性能的需求日益增加。因此,在安卓应用开发过程中,如何实现高效的性能优化成为开发者需要关注的重要问题。本文将探讨安卓应用开发中的性能优化技巧,包括减少内存占用、优化界面渲染、提升响应速度等方面的方法,帮助开发者更好地提升应用的用户体验。
10 0
|
3天前
|
存储 人工智能 安全
移动应用与系统:探索开发与操作系统的融合安卓应用开发:打造高效用户界面的关键技术
【5月更文挑战第27天】 随着移动互联网的飞速发展,移动应用和操作系统已经成为了我们日常生活中不可或缺的一部分。本文将深入探讨移动应用开发的关键要素,以及移动操作系统的核心功能。我们将分析移动应用开发的挑战和机遇,并讨论移动操作系统如何适应不断变化的技术环境。通过深入研究这些主题,我们希望为读者提供对移动应用和系统领域的全面理解。
|
3天前
|
缓存 安全 物联网
构建未来:基于Android的智能家居控制系统开发
【5月更文挑战第27天】 随着物联网技术的蓬勃发展,智能家居系统作为其重要分支,正逐步渗透到人们的日常生活中。本文旨在探讨并实现一个基于Android平台的智能家居控制系统,通过分析系统需求、设计架构以及具体实现过程,展现如何利用现代移动开发技术与物联网设备进行有效集成,以提升居住环境的智能化水平。文中不仅详细阐述了系统的设计理念和功能模块,还对关键技术如设备通信协议、用户界面设计和后台服务管理进行了深入讨论。
|
3天前
|
编解码 缓存 数据处理
安卓应用开发中的内存优化策略
【5月更文挑战第27天】在移动应用开发领域,尤其是安卓平台,内存管理是影响应用性能和用户体验的关键因素。本文将深入探讨针对安卓应用的内存泄漏问题,并提出一系列实用的优化策略,包括合理使用数据结构、优化图片资源、减少冗余对象以及利用系统提供的内存管理工具等。通过这些策略的实施,开发者可以有效降低应用的内存消耗,提升应用的响应速度和稳定性。
|
3天前
|
测试技术 开发工具 Android开发
安卓应用开发:打造高效用户界面的关键步骤
【5月更文挑战第27天】本文将探讨在安卓应用开发中如何通过关键步骤打造高效且用户友好的界面。我们将分析UI设计的基本原则,探究Material Design指南,并讨论如何利用Android Studio中的设计工具来优化布局和提高性能。此外,文章还将涉及如何进行有效的测试以确保应用界面既美观又实用。
|
5天前
|
数据处理 API Android开发
安卓应用开发:构建一个高效的通知管理系统
【5月更文挑战第25天】在移动操作系统中,通知管理是用户体验的核心组成部分。特别是对于安卓设备,由于其开放性和多样性,有效的通知管理系统显得尤为重要。本文将详细介绍如何在安卓平台上构建一个高效、用户友好的通知管理系统。我们将从通知渠道的管理、用户自定义设置以及后台数据处理等方面展开讨论,并提供实用的代码示例和最佳实践建议。
|
6天前
|
缓存 监控 Java
安卓应用开发中的内存优化策略
【5月更文挑战第24天】 在移动设备上,资源的有限性要求开发者对应用程序进行细致入微的性能优化。特别是对于安卓平台,由于设备的多样性和碎片化问题,内存管理成为提升应用性能、用户体验和电池寿命的关键因素。本文将探讨针对安卓开发的内存优化技巧,从避免内存溢出、减少内存占用到提高内存回收效率等方面展开讨论,旨在为开发者提供实用的内存优化策略,以改善应用的运行效率和稳定性。
|
9天前
|
缓存 负载均衡 网络协议
使用Go语言开发高性能服务的深度解析
【5月更文挑战第21天】本文深入探讨了使用Go语言开发高性能服务的技巧,强调了Go的并发性能、内存管理和网络编程优势。关键点包括:1) 利用goroutine和channel进行并发处理,通过goroutine池优化资源;2) 注意内存管理,减少不必要的分配和释放,使用pprof分析;3) 使用非阻塞I/O和连接池提升网络性能,结合HTTP/2和负载均衡技术;4) 通过性能分析、代码优化、缓存和压缩等手段进一步提升服务性能。掌握这些技术能帮助开发者构建更高效稳定的服务。