• 判断某个记录是否存在可以使用Exist, 相比GetExist性能更好。

    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方法实例的更多相关文章

  1. xorm -Find方法实例

    查询多条数据使用Find方法,Find方法的第一个参数为slice的指针或Map指针,即为查询后返回的结果,第二个参数可选,为查询的条件struct的指针. package main import ( ...

  2. xorm -Get方法实例

    查询单条数据使用Get方法,在调用Get方法时需要传入一个对应结构体的指针,同时结构体中的非空field自动成为查询的条件和前面的方法条件组合在一起查询 package main import ( & ...

  3. XQuery的 value() 方法、 exist() 方法 和 nodes() 方法

    Xml数据类型 /*------------------------------------------------------------------------------+ #| = : = : ...

  4. JDBC连接MySQL 方法 实例及资料收集

    JDBC连接MySQL 方法 实例及资料收集 准备工作 首先,安装MySQL,配置用户名和密码,创建数据库. 可参见之前的文章: http://www.cnblogs.com/mengdd/p/315 ...

  5. [原创]java WEB学习笔记102:Spring学习---Spring Bean配置:bean配置方式(工厂方法(静态工厂方法 & 实例工厂方法)、FactoryBean) 全类名

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  6. Java中==、equals、hashcode的区别与重写equals以及hashcode方法实例(转)

    Java中==.equals.hashcode的区别与重写equals以及hashcode方法实例  原文地址:http://www.cnblogs.com/luankun0214/p/4421770 ...

  7. 【转】Java中==、equals、hashcode的区别与重写equals以及hashcode方法实例

    原文地址:http://www.cnblogs.com/luankun0214/p/4421770.html 感谢网友的分享,记录下来只为学习. 1.重写equals方法实例   部分代码参考http ...

  8. php后台如何避免用户直接进入方法实例

    这篇文章介绍了php后台如何避免用户直接进入方法实例,有需要的朋友可以参考一下 1)创建BaseController控制器继承Controller(后台的一切操作要继承BaseController): ...

  9. 转载---SQL Server XML基础学习之<6>--XQuery的 value() 方法、 exist() 方法 和 nodes() 方法

    /*------------------------------------------------------------------------------+ #| = : = : = : = : ...

随机推荐

  1. 使用for循环签到嵌套制作直角三角形

    注意代码的运行顺序: for(i = 0 ; i<9 ; i++){ for(j = 0 ; j<i-1 ; j++){ document.write("*")//** ...

  2. hhhhh臭不要脸//捂脸)多不好意思啊you进步惹

    如题↑↑↑ 千万不要相信题目 还是看图说话吧↓↓↓ 我真的蒟蒻啊,,,准确率在70边缘徘徊,卑微☹ 不过还是侥幸地进入了前 30 名! 今天七夕欸,然鹅,,, qq空间里面弥漫着恋爱的酸臭味 香气,‘ ...

  3. nRF51822 的两路 PWM 极性

    忙了一阵这个PWM,玩着玩着终于发现了些规律.Nordic 也挺会坑爹的. nRF51822 是没有硬件 PWM 的,只能靠一系列难以理解的 PPI /GPIOTE/TIMER来实现,其实我想说,我醉 ...

  4. nRF51822 Beacon 扫描请求包的设置

    Nordic 公司自己做有 iBeacon的板子和 SDK,很少有人拥有这个SDK,我最近在朋友那也拿到了一个,但是还没有时间看. 现在我们用普通的SDK自带的 Beacon 例程来做开发,开发的时相 ...

  5. hosts 屏蔽定位域名

    通过修改hosts屏蔽定位服务的域名 #屏蔽百度地图 1.0.0.1 api.map.baidu.com 1.0.0.1 ps.map.baidu.com 1.0.0.1 sv.map.baidu.c ...

  6. Laravel模型事件的实现原理详解

    模型事件在 Laravel 的世界中,你对 Eloquent 大多数操作都会或多或少的触发一些模型事件,下面这篇文章主要给大家介绍了关于Laravel模型事件的实现原理,文中通过示例代码介绍的非常详细 ...

  7. 解决用官方容器启动redmine无法插入中文字符的问题

    jiangzhaowei@kitking:/kitking/redmineIot$ sudo docker-compose up -d Creating network "redmineio ...

  8. 手把手教你 GitLab 的安装及使用

    前言 新入职公司,发现公司还在使用落后生产工具 svn,由于重度使用过 svn 和 git ,知道这两个工具之间的差异,已经在使用 git 的路上越走越远. 于是,跟上级强烈建议让我在公司推行 git ...

  9. MYSQL事务的开启与提交

    MYSQL 事务处理主要有两种方法: 1.用 BEGIN, ROLLBACK, COMMIT来实现 BEGIN 开始一个事务 ROLLBACK 事务回滚 COMMIT 事务确认 2.直接用 SET 来 ...

  10. Angularjs 标签使用整理

    持续更新..... 一.select setmealList为接收到的集合数据,sname 是要显示的字段,Object属性 套餐类型:<select style="width: 15 ...