go+mysql实现页面的增删改查练习
原文地址:http://www.niu12.com/article/35
初次学go,在了解一些基础之后就开始做一个用户的增删改查来回顾知识,有很多数据验证和安全漏洞并没有考虑,只当作联系
前提:下载mysql驱动
a.go get github.com/go-sql-driver/mysql
b.数据表结构
-- ----------------------------
-- Table structure for users
-- ----------------------------
DROP TABLE IF EXISTS `users`;
CREATE TABLE `users` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`username` varchar(255) NOT NULL COMMENT '姓名',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of users
-- ----------------------------
INSERT INTO `users` VALUES ('1', '卡牌');
INSERT INTO `users` VALUES ('2', 'card');
INSERT INTO `users` VALUES ('3', '周起');
INSERT INTO `users` VALUES ('4', '有的人');
1.目录结构
| tpl --------模板文件
|-----create.html --------创建页面
|-----list.html --------列表页面
|-----update.html --------更新页面
| handlers.go --------业务逻辑处理(增删改查)
| main.go --------入口文件(路由控制)
| models.go --------模型文件(映射数据表)
2.main.go
package main
import (
"database/sql"
_ "github.com/go-sql-driver/mysql"
"log"
"net/http"
"os"
)
var (
db *sql.DB
err error
)
/**
检测错误,抛出异常
*/
func checkError(err error) {
if err != nil {
panic(err)
}
}
func main() {
db, err = sql.Open("mysql", "root:123456@tcp(47.97.215.189 )/test?charset=utf8")
checkError(err)
defer db.Close()
// 测试连接
err = db.Ping()
checkError(err)
os.Setenv("PORT", "8888")
port := os.Getenv("PORT")
if port == "" {
log.Fatal("服务器端口号未设置")
}
// 路由
// 用户列表
http.HandleFunc("/", listHandle)
http.HandleFunc("/list", listHandle)
// 添加用户
http.HandleFunc("/create", createHandle)
//// 更新用户
http.HandleFunc("/update", updateHandle)
//// 删除用户
http.HandleFunc("/delete", deleteHandle)
// 监听端口
http.ListenAndServe(":"+port, nil)
}
3.handlers.go
package main
import (
"html/template"
"net/http"
)
// 用户列表
func listHandle(w http.ResponseWriter, r *http.Request) {
if r.Method != "GET" {
http.Error(w, "请求方式错误", http.StatusMethodNotAllowed)
}
rows, err := db.Query("SELECT * FROM users")
if err != nil {
panic(err)
}
var users []User
var user User
for rows.Next() {
err = rows.Scan(&user.Id
, &user.Username)
users = append(users, user)
}
t, err := template.New("list.html").ParseFiles("tpl/list.html")
err = t.Execute(w, users)
if err != nil {
panic(err)
}
}
// 创建用户
func createHandle(w http.ResponseWriter, r *http.Request) {
if r.Method == "GET" {
t, err := template.New("create.html").ParseFiles("tpl/create.html")
if err != nil {
panic(err)
}
t.Execute(w,nil)
}
if r.Method == "POST" {
r.ParseForm()
username := r.Form["username"][0]
stmt, err := db.Prepare("INSERT INTO users(username) VALUES(?)")
if err != nil {
panic(err)
}
_, err = stmt.Exec(username)
if err != nil{
panic(err)
}
http.Redirect(w, r, "/list", 301)
}
}
// 修改用户信息
func updateHandle(w http.ResponseWriter, r *http.Request) {
r.ParseForm()
if r.Method == "GET" {
id := r.Form["id"][0]
var user User
row := db.QueryRow("SELECT * FROM users WHERE id = ?", id)
row.Scan(&user.Id , &user.Username)
t, err := template.New("update.html").ParseFiles("tpl/update.html")
if err != nil {
panic(err)
}
t.Execute(w, user)
}
if r.Method == "POST" {
id := r.Form["id"][0]
username := r.Form["username"][0]
stmt, err := db.Prepare("UPDATE users SET username = ? WHERE id = ?")
if err != nil {
panic(err)
}
_,err = stmt.Exec(username, id)
if err != nil {
panic(err)
}
http.Redirect(w, r, "/list", http.StatusMovedPermanently)
}
}
// 删除用户
func deleteHandle(w http.ResponseWriter, r *http.Request) {
if r.Method != "GET" {
http.Error(w, "请求方式错误", http.StatusMethodNotAllowed)
}
r.ParseForm()
id := r.Form["id"][0]
stmt, err := db.Prepare("DELETE FROM users WHERE id = ?")
if err != nil {
panic(err)
}
_,err = stmt.Exec(id)
if err != nil {
panic(err)
}
http.Redirect(w, r, "/list", http.StatusMovedPermanently)
}
4.models.go
package main
type User struct {
Id int64 `json:"id"`
Username string `json:"username"`
}
5.执行go run *.go运行或者go build来打包
6.在页面输入localhost:8888/ 进行操作
go+mysql实现页面的增删改查练习的更多相关文章
- MySQL数据库安装,MySQL数据库库的增删改查,表的增删改查,表数据的基本数据类型
一 MySQL的安装 MySQL现在属于甲骨文公司,所以和java语言匹配度较高,同时甲骨文公司的另一种数据库为Oracle,两者同为关系型数据库,即采用关系模型来组织数据,以行和列的方法来存储数据的 ...
- Vc数据库编程基础MySql数据库的表增删改查数据
Vc数据库编程基础MySql数据库的表增删改查数据 一丶表操作命令 1.查看表中所有数据 select * from 表名 2.为表中所有的字段添加数据 insert into 表名( 字段1,字段2 ...
- python操作三大主流数据库(2)python操作mysql②python对mysql进行简单的增删改查
python操作mysql②python对mysql进行简单的增删改查 1.设计mysql的数据库和表 id:新闻的唯一标示 title:新闻的标题 content:新闻的内容 created_at: ...
- 使用 NodeJS+Express+MySQL 实现简单的增删改查
关于node.js暂时记录如下,以后有时间一定学习 文章来自简书,作者:sprint,2016-07 使用 Node.js + Express+MySQL 实现简单的增删改查 https://www. ...
- mysql 的基本操作总结--增删改查
本文只是总结一下mysql 的基本操作,增删改查,以便忘记的时候可以查询一下 1.创建数据库 语法:CREATE DATABASES 数据库名; 例子: CREATE DATABASES studen ...
- Mysql数据表的增删改查
---恢复内容开始--- Mysql数据表的增删改查 1.创建表 语法:CREATE TABLE 表名(字段1,字段2,字段3.......) CREATE TABLE `users` ( `us ...
- Python进阶----数据库的基础,关系型数据库与非关系型数据库(No SQL:not only sql),mysql数据库语言基础(增删改查,权限设定)
day37 一丶Python进阶----数据库的基础,mysql数据库语言基础(增删改查,权限设定) 什么是数据库: 简称:DataBase ---->DB 数据库即存放数据的仓库, ...
- Node.js + MySQL 实现数据的增删改查
通过完成一个 todo 应用展示 Node.js + MySQL 增删改查的功能.这里后台使用 Koa 及其相应的一些中间件作为 server 提供服务. 初始化项目 $ mkdir node-cru ...
- 基于nodejs+express+mysql+webstorm+html的 增删改查
一.工具准备 Nodejs框架,WebStorm.Mysql服务.Navicat.此篇文章只讲项目的搭建过程,至于Nodejs,WebStorm.Mysql的下载.安装与配置网上资源很多,请自行查阅, ...
随机推荐
- Java8并行流使用注意事项
对于从事Java开发的童鞋来说,相信对于Java8的并行流并不陌生,没错,我们常常用它来执行并行任务,但是由于并行流(parallel stream)采用的是享线程池,可能会对我们的性能造成严重影响, ...
- 【Luogu】P3760异或和(权值树状数组)
题目链接 再次声明以后我见到位运算一定第一时间想把它拆成每一位算 本题就是有个前缀和sum[],然后让你求每一位有多少对i,j满足sum[i]-sum[j]在那一位上是1 考虑怎样才能减出1来 如果s ...
- hdu 1426 Sudoku Killer (dfs)
Sudoku Killer Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
- poj 1062 昂贵的聘礼 (最短路径)
昂贵的聘礼 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 33365 Accepted: 9500 Descriptio ...
- HDU 6034 Balala Power!(贪心+排序)
Balala Power! Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) ...
- 雅礼集训 Day7 T1 Equation 解题报告
Reverse 题目背景 小\(\text{G}\)有一个长度为\(n\)的\(01\)串\(T\),其中只有\(T_S=1\),其余位置都是\(0\).现在小\(\text{G}\)可以进行若干次以 ...
- 静态区间第k大 树套树解法
然而过不去你谷的模板 思路: 值域线段树\([l,r]\)代表一棵值域在\([l,r]\)范围内的点构成的一颗平衡树 平衡树的\(BST\)权值为点在序列中的位置 查询区间第\(k\)大值时 左区间在 ...
- 【CF edu 27 G. Shortest Path Problem?】
time limit per test 3 seconds memory limit per test 512 megabytes input standard input output standa ...
- 【CZY选讲·最大子矩阵和】
题目描述 有一个n*m的矩阵,恰好改变其中一个数变成给定的常数P,使得改变后的这个矩阵的最大子矩阵最大. 数据范围 n,m<=300. 题解: ①如果没有p,那么二维矩阵和就是一维最长 ...
- 水(NOIP模拟赛Round #10)
题目描述: 小Z有一个长度为的数列.他有次令人窒息的操作,每次操作可以使某个数字或.他当然是希望这些数字的乘积尽量小了.为了简化题目,你只需输出操作完成后的数列即可. ———————————————— ...