xorm -Exist方法实例
判断某个记录是否存在可以使用
Exist
, 相比Get
,Exist
性能更好。package main import (
"fmt"
_ "github.com/go-sql-driver/mysql"
"github.com/go-xorm/xorm"
"log"
"time"
) var engine *xorm.Engine type User struct {
Name string `xorm:"varchar(25) 'name'"`
Id int `xorm:"pk 'id' autoincr"`
CreatedAt time.Time `xorm:"created"`
} func main() {
var err error
engine, err = xorm.NewEngine("mysql", "root:123456@/test")
if err != nil {
log.Fatal(err)
return
} err = engine.CreateTables(User{})
if err != nil {
log.Fatal(err)
return
} u := make([]User, 5)
u[0].Name = "abcd"
u[1].Name = "acbd"
u[2].Name = "dbac"
u[3].Name = "cbda"
u[4].Name = "bdca" _, err = engine.Insert(u)
if err != nil {
log.Fatal(err)
return
}
/*
has, err := testEngine.Exist(new(RecordExist))
// SELECT * FROM record_exist LIMIT 1、
*/
uu := new(User)
uu.Name = "abcd"
has, err := engine.Exist(uu)
if err != nil {
log.Fatal(err)
return
}
if has {
fmt.Println("uu ",uu.Name, uu.Id, uu.CreatedAt)
} /*
has, err = testEngine.Exist(&RecordExist{
Name: "test1",
})
// SELECT * FROM record_exist WHERE name = ? LIMIT 1
*/
uu0 := &User{Name: "abcd"}
has, err = engine.Exist(uu0)
if err != nil {
log.Fatal(err)
return
}
if has {
fmt.Println("uu0 ",uu0.Name, uu0.Id, uu0.CreatedAt)
} /*
has, err = testEngine.Where("name = ?", "test1").Exist(&RecordExist{})
// SELECT * FROM record_exist WHERE name = ? LIMIT 1
*/
uu1 := &User{Name: "abcd"}
has, err = engine.Where("id =?", 1).Exist(uu1)
if err != nil {
log.Fatal(err)
return
}
if has {
fmt.Println("uu1 ",uu1.Name, uu1.Id, uu1.CreatedAt)
} /*
has, err = testEngine.SQL("select * from record_exist where name = ?", "test1").Exist()
// select * from record_exist where name = ? */ uu2 := new(User)
has, err = engine.SQL("select * from user where id =?", 2).Exist(uu2)
if err != nil {
log.Fatal(err)
return
}
if has {
fmt.Println("uu2 ",uu2.Name, uu2.Id, uu2.CreatedAt)
} /*
has, err = testEngine.Table("record_exist").Exist()
// SELECT * FROM record_exist LIMIT 1
*/ uu3 := new(User)
has, err = engine.Table(User{}).Exist(uu3)
if err != nil {
log.Fatal(err)
return
}
if has {
fmt.Println("uu3 ",uu3.Name, uu3.Id, uu3.CreatedAt)
} /*
has, err = testEngine.Table("record_exist").Where("name = ?", "test1").Exist()
// SELECT * FROM record_exist WHERE name = ? LIMIT 1
*/
uu4 := new(User)
has, err = engine.Table(User{}).Where("name =?", "abcd").Exist(uu4)
if err != nil {
log.Fatal(err)
return
}
if has {
fmt.Println("uu4 ",uu4.Name, uu4.Id, uu4.CreatedAt)
} } /*
输出:
uu abcd 0 0001-01-01 00:00:00 +0000 UTC
uu0 abcd 0 0001-01-01 00:00:00 +0000 UTC
uu1 abcd 0 0001-01-01 00:00:00 +0000 UTC
uu2 0 0001-01-01 00:00:00 +0000 UTC
uu3 0 0001-01-01 00:00:00 +0000 UTC
uu4 0 0001-01-01 00:00:00 +0000 UTC
可以发现体存在的情况下,Exist方法不会将查到的实体赋值给参数
*/与Get的区别
Get与Exist方法返回值都为bool和error,如果查询到实体存在,则Get方法会将查到的实体赋值给参数
user := &User{Id:1}
has,err := testEngine.Get(user)
// 执行结束后,user会被赋值为数据库中Id为1的实体
has,err = testEngine.Exist(user)
// user中仍然是初始声明的user,不做改变
如果你的需求是:判断某条记录是否存在,若存在,则返回这条记录。
建议直接使用Get方法。
如果仅仅判断某条记录是否存在,则使用Exist方法,Exist的执行效率要比Get更高。
xorm -Exist方法实例的更多相关文章
- xorm -Find方法实例
查询多条数据使用Find方法,Find方法的第一个参数为slice的指针或Map指针,即为查询后返回的结果,第二个参数可选,为查询的条件struct的指针. package main import ( ...
- xorm -Get方法实例
查询单条数据使用Get方法,在调用Get方法时需要传入一个对应结构体的指针,同时结构体中的非空field自动成为查询的条件和前面的方法条件组合在一起查询 package main import ( & ...
- XQuery的 value() 方法、 exist() 方法 和 nodes() 方法
Xml数据类型 /*------------------------------------------------------------------------------+ #| = : = : ...
- JDBC连接MySQL 方法 实例及资料收集
JDBC连接MySQL 方法 实例及资料收集 准备工作 首先,安装MySQL,配置用户名和密码,创建数据库. 可参见之前的文章: http://www.cnblogs.com/mengdd/p/315 ...
- [原创]java WEB学习笔记102:Spring学习---Spring Bean配置:bean配置方式(工厂方法(静态工厂方法 & 实例工厂方法)、FactoryBean) 全类名
本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...
- Java中==、equals、hashcode的区别与重写equals以及hashcode方法实例(转)
Java中==.equals.hashcode的区别与重写equals以及hashcode方法实例 原文地址:http://www.cnblogs.com/luankun0214/p/4421770 ...
- 【转】Java中==、equals、hashcode的区别与重写equals以及hashcode方法实例
原文地址:http://www.cnblogs.com/luankun0214/p/4421770.html 感谢网友的分享,记录下来只为学习. 1.重写equals方法实例 部分代码参考http ...
- php后台如何避免用户直接进入方法实例
这篇文章介绍了php后台如何避免用户直接进入方法实例,有需要的朋友可以参考一下 1)创建BaseController控制器继承Controller(后台的一切操作要继承BaseController): ...
- 转载---SQL Server XML基础学习之<6>--XQuery的 value() 方法、 exist() 方法 和 nodes() 方法
/*------------------------------------------------------------------------------+ #| = : = : = : = : ...
随机推荐
- 【叔小生】JavaScript进阶篇
如何插入JS JS基础语法 语法.函数.方法 提取字符串substring() substring() 方法用于提取字符串中介于两个指定下标之间的字符. <!DOCTYPE HTML> & ...
- Codeforces - 1264C - Beautiful Mirrors with queries - 概率期望dp
一道挺难的概率期望dp,花了很长时间才学会div2的E怎么做,但这道题是另一种设法. https://codeforces.com/contest/1264/problem/C 要设为 \(dp_i\ ...
- Sql注入基本思路
Sql注入基本思路 利用mysql自己动手 登录 使用show databases;查看数据库,sql注入主要用到的是information_schema这个库(mysql中大小写不敏感) infor ...
- Java的死锁及解决思路(延伸: 活锁,饥饿,无锁)
死锁: A线程持有 锁1,接下来要获取锁2:与此同时,B线程持有锁2,要获取锁1.两个线程都在等对方释放自己需要的锁,这时两方会永远等待下去,就形成了死锁. 死锁的四个必要条件: 1.互斥:资源(锁) ...
- [web 前端] Npm package.json与package-lock.json文件的作用
本文链接:https://blog.csdn.net/u013992330/article/details/81110018 最新版nodejs中,多了一个package-lock.json文件,刚开 ...
- gmake: Nothing to be done for `all'.
安装gc_buffercache的时候报错: [root@~ pg_buffercache]# gmake gmake: Nothing to be done for `all'. 解决方法: > ...
- 007 SpringBoot的@EnableAutoConfiguration注解
一:原理 1. 首先Spring Boot项目中都会如下启动类: @SpringBootApplication public class Application { public static voi ...
- Maven构建报错问题解决
[ERROR] Failed to execute goal on project zepeto-admin: Could not resolve dependencies -SNAPSHOT: Fa ...
- C# Newtonsoft.Json解析json字符串处理(最清晰易懂的方法)
需求: 假设有如下json字符串: { ", "employees": [ { "firstName": "Bill", &quo ...
- 013-centos7 常用命令--查看当前用户的4种方法
一.概述 4种查看系统用户信息(通过编号(ID))的方法. 1.1. 使用w命令查看登录用户正在使用的进程信息 w命令用于显示已经登录系统的用户的名称,以及他们正在做的事.该命令所使用的信息来源于/v ...