原文地址: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实现页面的增删改查练习的更多相关文章

  1. MySQL数据库安装,MySQL数据库库的增删改查,表的增删改查,表数据的基本数据类型

    一 MySQL的安装 MySQL现在属于甲骨文公司,所以和java语言匹配度较高,同时甲骨文公司的另一种数据库为Oracle,两者同为关系型数据库,即采用关系模型来组织数据,以行和列的方法来存储数据的 ...

  2. Vc数据库编程基础MySql数据库的表增删改查数据

    Vc数据库编程基础MySql数据库的表增删改查数据 一丶表操作命令 1.查看表中所有数据 select * from 表名 2.为表中所有的字段添加数据 insert into 表名( 字段1,字段2 ...

  3. python操作三大主流数据库(2)python操作mysql②python对mysql进行简单的增删改查

    python操作mysql②python对mysql进行简单的增删改查 1.设计mysql的数据库和表 id:新闻的唯一标示 title:新闻的标题 content:新闻的内容 created_at: ...

  4. 使用 NodeJS+Express+MySQL 实现简单的增删改查

    关于node.js暂时记录如下,以后有时间一定学习 文章来自简书,作者:sprint,2016-07 使用 Node.js + Express+MySQL 实现简单的增删改查 https://www. ...

  5. mysql 的基本操作总结--增删改查

    本文只是总结一下mysql 的基本操作,增删改查,以便忘记的时候可以查询一下 1.创建数据库 语法:CREATE DATABASES 数据库名; 例子: CREATE DATABASES studen ...

  6. Mysql数据表的增删改查

    ---恢复内容开始--- Mysql数据表的增删改查 1.创建表   语法:CREATE TABLE 表名(字段1,字段2,字段3.......) CREATE TABLE `users` ( `us ...

  7. Python进阶----数据库的基础,关系型数据库与非关系型数据库(No SQL:not only sql),mysql数据库语言基础(增删改查,权限设定)

    day37 一丶Python进阶----数据库的基础,mysql数据库语言基础(增删改查,权限设定) 什么是数据库:    简称:DataBase ---->DB    数据库即存放数据的仓库, ...

  8. Node.js + MySQL 实现数据的增删改查

    通过完成一个 todo 应用展示 Node.js + MySQL 增删改查的功能.这里后台使用 Koa 及其相应的一些中间件作为 server 提供服务. 初始化项目 $ mkdir node-cru ...

  9. 基于nodejs+express+mysql+webstorm+html的 增删改查

    一.工具准备 Nodejs框架,WebStorm.Mysql服务.Navicat.此篇文章只讲项目的搭建过程,至于Nodejs,WebStorm.Mysql的下载.安装与配置网上资源很多,请自行查阅, ...

随机推荐

  1. HS 光流法详解

    前言 本文较为详细地介绍了一种经典的光流法 - HS 光流法. 光流法简介 当人的眼睛与被观察物体发生相对运动时,物体的影像在视网膜平面上形成一系列连续变化的图像,这一系列变化的图像信息不断 &quo ...

  2. Scala 基础(1)—— 定义变量 & 定义函数

    1. 使用 val & var 定义变量 Scala 中的变量被分为2种:val 和 var.其含义于 Java 中的 final 关键字类似. val 等同于被 final 修饰过的变量, ...

  3. 【bzoj2506】calc 根号分治+STL-vector+二分+莫队算法

    题目描述 给一个长度为n的非负整数序列A1,A2,…,An.现有m个询问,每次询问给出l,r,p,k,问满足l<=i<=r且Ai mod p = k的值i的个数. 输入 第一行两个正整数n ...

  4. 灰姑娘的水晶鞋(NOIP模拟赛Round 7)

    [问题描述] 传说中的水晶鞋有两种颜色:左边的水晶鞋是红色,右边的是蓝色,据说穿上它们会有神奇的力量. 灰姑娘要找到她所有的n双水晶鞋,它们散落在一条数轴的正半轴上,坐标各不相同,每双水晶鞋还有一个权 ...

  5. zlib编译不过(Error A2070)解决方法(转)

    原文转自 http://dearymz.blog.163.com/blog/static/2056574200871010027435/ 1.zlib是个很牛的东东,从http://www.zlib. ...

  6. msvc交叉编译:使用vcvarsall.bat设置命令行编译环境

    一直以来我只知道vc设置命令行编译环境的批处理命令是%VS140COMNTOOLS%/Common7/Tools下的vsvars32.bat,(%VS140COMNTOOLS%为定义vs2015公共工 ...

  7. 获取URL中的文件的扩展名

    问题: 尽可能多地写出获取文件扩展名的方法: //方法一(分割数组) function getExt($url){ $arr = explode('.',$url); $len = count($ar ...

  8. Nodejs将Buffer转化成Stream

    编写接口的时候经常需要将上传的文件保存到数据库的情况,在nodejs中文件上传可以使用multer来接收上传的文件.如果不想保存到本地,而是直接保存到mongodb中,就要将buffer对象转化成流再 ...

  9. sysbench(mysql测试工具 )

    目录 一.基准测试简介 1.什么是基准测试 2.基准测试的作用 3.基准测试的指标 4.基准测试的分类 二.sysbench 1.sysbench简介 2.sysbench安装 3.sysbench语 ...

  10. MVC 视图与控制器传值的几种方法

    一.页面取值传给控制器 1.表单传值----利用Action   视图页:         <form action="方法名" method="post" ...