Go语言入门1.4 包
每个 Go 程序都是由包构成的。
程序从 main 包开始运行。
先看一个例子
package main
import (
"fmt"
"math/rand"
)
func main() {
fmt.Println("My favorite number is", rand.Intn(10))
}
每个 Go 程序都是由包构成的。
程序从 main 包开始运行。
先看一个例子
package main
import (
"fmt"
"math/rand"
)
func main() {
fmt.Println("My favorite number is", rand.Intn(10))
}
常量表达式的值在编译期计算,而不是在运行期。每种常量的潜在类型都是基础类型:boolean、string或数字。
一个常量的声明语句定义了常量的名字,和变量的声明语法类似,常量的值不可修改,这样可以防止在运行期被意外或恶意的修改。例如,常量比变量更适合用于表达像π之类的数学常数,因为它们的值不会发生变化。
const pi = 3.14159
仅以此记录自己学习Go语言的过程。今日开始每天做下相应的记录,方便自己复习,同时也可以让一些想入门的看看吧。开发环境安装就不再说了,这些内容网上太多了。
像其它很多语言一样,就从hello world开始吧。我是在macbook pro使用Visual Studio Code进行学习。与windows下的执行稍稍有些不同。之前一直使用的是php程序进行开发,程序中可能会将go与php的写法做一些对比。
package main
import (
"database/sql"
"fmt"
"log"
"os"
_ "github.com/mattn/go-sqlite3"
)
func main() {
os.Remove("./products.db")
db, err := sql.Open("sqlite3", "./products.db")
if err != nil {
log.Fatal(err)
}
sql := `create table t_products(id integer not null primary key, name text, price float)`
_, err = db.Exec(sql)
defer db.Close()
if err != nil {
log.Fatal(err)
return
}
// 插入的事务开始
tx, err := db.Begin()
if err != nil {
log.Fatal(err)
return
}
stmt, err := tx.Prepare("insert into t_products(id, name, price) values(?,?,?)")
if err != nil {
log.Fatal(err)
return
}
defer stmt.Close()
for i := 0; i < 10; i++ {
_, err = stmt.Exec(i+1, fmt.Sprintf("产品%d", i+1), float64(i+1)*54.8)
if err != nil {
log.Fatal(err)
return
}
}
tx.Commit() // 提交
// 查询
rows, err := db.Query("select id, name, price from t_products")
if err != nil {
log.Fatal(err)
return
}
defer rows.Close()
for rows.Next() {
var id int
var name string
var price float64
err = rows.Scan(&id, &name, &price)
if err != nil {
log.Fatal(err)
return
}
priceStr := fmt.Sprintf("%.2f", price)
fmt.Println(id, name, priceStr)
}
stmt, _ = db.Prepare("select name,price from t_products where id=?")
defer stmt.Close()
var name string
var price float64
stmt.QueryRow("6").Scan(&name, &price)
priceStr := fmt.Sprintf("%.2f", price)
fmt.Println("--------------")
fmt.Println(name, priceStr)
// 删除
stmt, _ = db.Prepare("delete from t_products where id=?")
stmt.Exec(9)
}