> ### 第六例 原生sql操作
~~~
package demo3
import (
"database/sql"
"fmt"
_ "github.com/go-sql-driver/mysql"
"html/template"
"net/http"
"time"
)
//TODO : Datatase
func getConn() (*sql.DB, error) {
host := "localhost"
dbname := "messagebox"
username := "root"
password := "123456"
db, err := sql.Open("mysql", username+":"+password+"@tcp("+host+")/"+dbname+"?charset=utf8")
return db, err
}
//TODO : 留言板列表頁
func Index(w http.ResponseWriter, r *http.Request) {
r.ParseForm()
sort := r.Form["sort"]
if len(sort) == 0 {
sort = append(sort, "0")
}
db, err := getConn()
if err != nil {
fmt.Println(err.Error())
}
sortfiled := ""
if sort[0] == "0" {
sortfiled = "time"
} else {
sortfiled = "viewnum"
}
rows, err := db.Query(fmt.Sprintf("select id, title, viewnum, time as time2 from msg_article where status = 'A' order by %s desc limit 10", sortfiled))
if err != nil {
fmt.Println(err.Error())
}
data := make([]map[string]string, 0, 0)
for rows.Next() {
var (
id string
title string
viewnum string
time2 int64
)
err = rows.Scan(&id, &title, &viewnum, &time2)
if err != nil {
fmt.Println(err)
}
m := make(map[string]string)
m["id"] = id
m["title"] = title
m["viewnum"] = viewnum
tm := time.Unix(time2, 0)
m["time"] = tm.Format("2006-01-02 15:04:05")
data = append(data, m)
}
tpl, err := template.ParseFiles("demo3/view/index.html")
if err != nil {
fmt.Println(err.Error())
return
}
tpl.Execute(w, data)
}
//TODO : 創建留言板
func Create(w http.ResponseWriter, r *http.Request) {
tpl, err := template.ParseFiles("demo3/view/create.html")
if err != nil {
fmt.Println(err.Error())
return
}
tpl.Execute(w, nil)
}
//TODO : 處理留言板表單
func CreateForm(w http.ResponseWriter, r *http.Request) {
r.ParseForm()
if r.Method == "POST" {
name := r.Form["title"]
content := r.Form["content"]
times := time.Now().Unix()
db, err := getConn()
if err != nil {
fmt.Println("getConn", err.Error())
}
_, err = db.Exec("insert into msg_article(title, content, time) values (?, ?, ?)", name[0], content[0], times)
if err != nil {
fmt.Println("Insert:", err.Error())
} else {
http.Redirect(w, r, "/index", 302)
}
}
}
//TODO : 刪除留言
func Delete(w http.ResponseWriter, r *http.Request) {
r.ParseForm()
id := r.Form["id"]
db, err := getConn()
if err != nil {
fmt.Println("getConn", err.Error())
}
_, err = db.Exec(fmt.Sprintf("update msg_article set status='D' where id=%s", id[0]))
if err != nil {
fmt.Println("Delete", err.Error())
} else {
http.Redirect(w, r, "/index", 302)
}
}
func Demo3() {
//設置靜態目錄
http.Handle("/static/", http.StripPrefix("/static/", http.FileServer(http.Dir("demo3/static"))))
http.HandleFunc("/", Index)
http.HandleFunc("/index", Index)
http.HandleFunc("/create", Create)
http.HandleFunc("/createform", CreateForm)
http.HandleFunc("/delete", Delete)
http.HandleFunc("/favicon.ico", func(writer http.ResponseWriter, request *http.Request) {})
http.ListenAndServe(":9001", nil)
}
~~~
- 第一例 留言板
- 第二例 gRPC使用例子
- 第三例 基于go-micro做服務注冊和服務發現
- 第四例 聊天室
- 第五例 工具庫 第五例 并發安全字典
- dao
- common
- common.go
- config
- config.go
- gorm
- grom.go
- sqlx
- sqlx.go
- kafka
- kafka.go
- log
- log.go
- log2.go
- redis
- redis.go
- zookeeper
- zookeeper.go
- init
- main.go
- 第六例 原生sql操作
- 第七例 sqlx操作
- 第八例 Redis數據庫(gomodule/redigo)
- 第九例 Redis消息隊列
- 第十例 Redis集群連接
- 第十一例 Zookeeper操作
- 第十二例 Kafka操作
- 第十三例 NSQ操作
- 第十四例 二分查找
- 第十五例 交換排序 - 冒泡排序
- 第十六例 插入排序 - 直接插入排序
- 第十七例 插入排序 - 希爾排序
- 第十八例 交換排序 - 快速排序
- 第十九例 算法求解應用
- 第二十例 pprof性能分析
- 第二一例 CPU信息采集
- 第二二例 Heap信息采集
- 第二三例 Http信息采集
- 第二四例 單元測試(功能測試)
- 第二五例 基準測試(壓力測試/性能測試)
- 第二六例 gdb調試
- 第二七例 json序列化和反序列化
- 第二八例 protobuf序列化和反序列化
- 第二九例 包管理工具 go vendor
- 第三十例 包管理工具 go mod
- 第三一例 zip壓縮
- 第三二例 交叉編譯
- 第三三例 線上環境部署
- 第三四例 業務:實現固定周期維護
- 第三五例 聊天室(精簡版)
- 第三六例 并發安全字典
- 第三七例 導出Excel表格
- 第三八例 導出CSV表格
- 第三九例 聊天室(高并發)
- 第四十例 JWT (Json Web Token)
- 第四一例 雪花算法生成 Id
- 第四二例 對稱加密 AES
- 第四三例 非對稱加密 RSA
- 第四四例 簽名算法 SHA1
- 第四五例 數據庫操作 gorm
- 第四六例 數據庫操作 gorm 集合
- 數據庫連接和創建表
- 查詢 - 分頁
- 查詢所有數據
- 查詢單條數據
- 插入一條或多條數據
- 更新一條或多條數據
- 更新一條或多條數據(有零值)
- 第四七例 RSA(MD5WithRSA 算法)簽名和驗簽方式
- 第四八例 線上部署腳本
- 第四九例 Elasticsearch
- 第五十例 對象池
- 第五十一例 相關閱讀