当前位置: 首页 > news >正文

建筑工程类招聘网站公司做网络推广怎么做

建筑工程类招聘网站,公司做网络推广怎么做,实体店做网站有用吗,网站建设注意事项在gorm中,要想从数据库中查找数据有多种方法,可以通过Find、Take和First来查找。但它们之间又有一些不同。本文就详细介绍下他们之间的不同。 一、准备工作 首先我们有一个m_tests表,其中id字段是自增的主键,同时该表里有3条数据…

在gorm中,要想从数据库中查找数据有多种方法,可以通过Find、Take和First来查找。但它们之间又有一些不同。本文就详细介绍下他们之间的不同。

一、准备工作

首先我们有一个m_tests表,其中id字段是自增的主键,同时该表里有3条数据。如下:

CREATE TABLE `m_tests` (`id` bigint(20) NOT NULL AUTO_INCREMENT,`name` varchar(100) NOT NULL DEFAULT '' COMMENT '姓名',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8mb4;INSERT INTO test01.m_test (id,name) VALUES (1,'John'), (2,'Jack'),(3,'David');

基于这个表,我们来看看这几个函数查询出来的结果是什么。

二、First函数

我们通过ToSql函数将First函数转成对应的sql语句来看。如下:

func main() {dsn := "username:password@tcp(127.0.0.1:3306)/test01?charset=utf8mb4&parseTime=True&loc=Local&timeout=1000ms"config := &gorm.Config{NamingStrategy: schema.NamingStrategy{SingularTable: true, // 禁用表名复数}}db, _ := gorm.Open(mysql.Open(dsn), config)var row MTestsql := db.ToSQL(func(tx *gorm.DB) *gorm.DB {return tx.First(&row)})fmt.Printf("接收的sql语句:%s\n", sql)
}

通过该程序,可以看到最终的sql语句如下:
powershell复制代码接收的sql语句:SELECT * FROM m_test ORDER BY m_test.id LIMIT 1

发现First函数是通过主键排序后,只获取一条数据。我们在通过explain来解释一下该条语句:
powershell复制代码explain SELECT * FROM m_test ORDER BY m_test.id LIMIT 1

其输出结果如下:
也就是说在查询的时候也只扫描一行数据。也就是说First函数只扫描一行数据。

三、Last函数

同样,我们还是通过ToSQL来讲Last函数转化的sql语句打印出来:

func main() {dsn := "username:password@tcp(127.0.0.1:3306)/test01?charset=utf8mb4&parseTime=True&loc=Local&timeout=1000ms"config := &gorm.Config{NamingStrategy: schema.NamingStrategy{SingularTable: true, // 禁用表名复数}}db, _ := gorm.Open(mysql.Open(dsn), config)var rows []MTestsql := db.ToSQL(func(tx *gorm.DB) *gorm.DB {return tx.Last(&rows)})fmt.Printf("接收的sql语句:%s\n", sql)db.Last(&rows)fmt.Printf("最终接收:%+v\n", rows)
}

我们看到Last转换成的sql语句如下:
powershell复制代码接收的sql语句:SELECT * FROM m_test ORDER BY m_test.id DESC LIMIT 1

所以,Take实际上是按主键倒序排列,并且只获取1行数据的一个sql。
我们再看最终获取的结果rows,虽然是个数组,但也只有一行数据。:
powershell复制代码最终结果数据:[{Id:6 Name:}]

所以,Last和First的相同点在于只扫描到表的一条目标数据后就截止了,并赋值给接收变量。不同点在于First是按主键正序排列,Last是按主键倒序排列。

四、Take函数

再来看看Take函数的执行过程。如下:

func main() {dsn := "username:password@tcp(127.0.0.1:3306)/test01?charset=utf8mb4&parseTime=True&loc=Local&timeout=1000ms"config := &gorm.Config{NamingStrategy: schema.NamingStrategy{SingularTable: true, // 禁用表名复数}}db, _ := gorm.Open(mysql.Open(dsn), config)var row MTestsql := db.ToSQL(func(tx *gorm.DB) *gorm.DB {return tx.Take(&row)})fmt.Printf("接收的sql语句:%s\n", sql)
}

Take函数执行时最终转换成的sql语句如下:
powershell复制代码SELECT * FROM m_test LIMIT 1

也是只获取一行数据,但和First不同的是缺少了Order BY m_test.id``。
我们再通过explain来解释下该条语句,如下, type列是ALL,rows列是3,因为我们表里只有3行数据。是全表扫描,然后再随机获取一行数据。如下:

mysql> explain SELECT * FROM `m_test` LIMIT 1;
+----+-------------+--------+------------+------+---------------+------+---------+------+------+----------+-------+
| id | select_type | table  | partitions | type | possible_keys | key  | key_len | ref  | rows | filtered | Extra |
+----+-------------+--------+------------+------+---------------+------+---------+------+------+----------+-------+
|  1 | SIMPLE      | m_test | NULL       | ALL  | NULL          | NULL | NULL    | NULL |    3 |   100.00 | NULL  |
+----+-------------+--------+------------+------+---------------+------+---------+------+------+----------+-------+
1 row in set, 1 warning (0.09 sec)

所以,Take函数是扫描全表,并随机获取一条数据。所以,Take函数要比First函数性能差。
同时,我们注意到,因为在sql语句中可以看到都有LIMIT 1的限制,所以Take和First都只能获取一条数据,即便是给传递了一个数组,也只能获取一行数据,不能获取多行数据。

五、Find函数

再来看看Take函数的执行过程。我们首先给Find函数传递一个普通的非切片变量,如下:

func main() {dsn := "username:password@tcp(127.0.0.1:3306)/test01?charset=utf8mb4&parseTime=True&loc=Local&timeout=1000ms"config := &gorm.Config{NamingStrategy: schema.NamingStrategy{SingularTable: true, // 禁用表名复数}}db, _ := gorm.Open(mysql.Open(dsn), config)var row MTestsql := db.ToSQL(func(tx *gorm.DB) *gorm.DB {return tx.Find(&row)})fmt.Printf("接收的sql语句:%s\n", sql)
}

转换成的sql语句如下:
powershell复制代码接收的sql语句:SELECT * FROM m_test

和First和Take相比,缺少了Order子句和Limit子句。扫描的是整个表,获取的也是表的所有数据,但因为接收者是一个非切片变量,所以最终只接收了一行数据到row中。
我们再来看看给Find传递一个切片变量来接收的情况

func main() {dsn := "username:password@tcp(127.0.0.1:3306)/test01?charset=utf8mb4&parseTime=True&loc=Local&timeout=1000ms"config := &gorm.Config{NamingStrategy: schema.NamingStrategy{SingularTable: true, // 禁用表名复数}}db, _ := gorm.Open(mysql.Open(dsn), config)var rows []MTesttx.Find(&rows)fmt.Printf("rows:%+v\n", rows)
}

这个结果是接收所有查找到的行的数据到rows中。所以大家一定要注意,在使用Find查询的时候一定要加Where条件和查询的数量,以避免扫描和查询全表的数据,尤其是在大数量的表中。
六、总结
本文主要讲解了First、Last、Take和Find查询函数的不同之处。希望在使用过程中大家根据自己的应用场景选择合适的函数。

http://www.hkea.cn/news/552132/

相关文章:

  • 做网站内链什么意思上海排名优化seobwyseo
  • 四川做直销会员网站百度网盘帐号登录入口
  • 做百度竞价对网站有无要求网站推广排名服务
  • 建设工程合同包括成都网站改版优化
  • 深圳不加班的互联网公司整站seo优化
  • 中国做的很好的食品网站肇庆疫情最新消息
  • 做时时彩网站微信seo关键词有话要多少钱
  • 陇南市建设局网站商务软文写作
  • 做学术研究的网站营销方案怎么写?
  • 专业网站设计公司有哪些秒收录关键词代发
  • 织梦网站模板源码下载真实有效的优化排名
  • 网站建设过程中什么最重要磁力链bt磁力天堂
  • html5企业网站案例鹤壁搜索引擎优化
  • 网站建设平台简介链接交换平台
  • 照片展示网站模板宁波seo咨询
  • 奉贤建设机械网站制作长沙网址seo
  • 上海企业网站模板建站常用的网络推广方法
  • 大连零基础网站建设教学培训济南seo优化公司
  • html 做网站案例简单网站推广建设
  • 践行新使命忠诚保大庆网站建设线上广告
  • 定制网站建设服务商商家联盟营销方案
  • 集团官网建设公司外贸seo推广公司
  • 佛山新网站制作平台网站诊断工具
  • 做PPT的网站canvawhois查询
  • 营销型网站建设吉林定制化网站建设
  • 个人网上公司注册流程图新站优化案例
  • 做se要明白网站明星百度指数排名
  • 网页微博草稿箱在哪西安seo推广优化
  • 嘉兴微信网站建设谷歌首页
  • 什么网站做海报b站不收费网站