首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql数据库时间类型datetime、bigint、timestamp的查询效率比较

作者 | 哒波甜 来源 | https://juejin.cn/post/6844903701094596615 数据库中可以用datetime、bigint、timestamp来表示时间,那么选择什么类型来存储时间比较合适呢...sql查询速率测试 通过datetime类型查询: select count(*) from users where time_date >="2018-10-21 23:32:44" and time_date...> timestamp sql分组速率测试 使用bigint 进行分组会每条数据进行一个分组,如果将bigint做一个转化在去分组就没有比较的意义了,转化也是需要时间的 通过datetime类型分组:...小结 如果需要对时间字段进行操作(如通过时间范围查找或者排序等),推荐使用bigint,如果时间字段不需要进行任何操作,推荐使用timestamp,使用4个字节保存比较节省空间,但是只能记录到2038...年记录的时间有限 - END -

2.6K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    用事实说话,成熟的ORM性能不是瓶颈,灵活性不是问题:EF5.0、PDF.NET5.0、Dapper原理分析与测试手记

    SQL还是导致工作量很大,于是拿起ORM并发明了查询部分实体类属性的查询API:OQL;最后,觉得有些地方用ORM还是麻烦,比如处理一个表单的CRUD,如果用ORM也得收集或者填充数据到实体类上,还不如直接发出...2,Linq2Sql&EF:   2008年,随着.NET 3.5和VS2008发布,MS的官方ORM框架Linq2Sql也一同发布了,它采用Linq语法来查询数据库,也就是说Linq是MS的ORM查询...由于Linq语法跟SQL语法有较大的区别,特别是Linq版本的左、又连接查询语法,跟SQL的Join连接查询,差异巨大,因此,学习Linq需要一定的成本。...SQL来的好;而对于复杂查询效率低的问题,这个跟ORM没有太大关系,复杂查询哪怕用SQL写,DB执行起来也低的,ORM只不过自动生成SQL让DB去执行而已,问题可能出在某些ORM框架输出的SQL并不是开发人员预期的...另外,有的ORM语言可以做到查询透明化的,即按照你用ORM的预期去生成对应的SQL,不会画蛇添足,PDF.NET的ORM查询语言OQL就是这样的。

    4.2K90

    LINQ能不能用系列(二)LINQ to SQL 效率比对

    前言 很多人听说过LINQ TO SQL与ADO.NET传统方式用于不同的环境,LINQ TO SQL与ADO.NET传统方式也没有可比性,就像公交车与私家车一样,虽然是车但用途完全不同,但很少有人去探究...,究竟为什么他们不同,他们不同的原因是什么,这我觉得是一个好的程序和一个普通程序最主要的区别之一。...内容 测试环境:net framework 4.0 + Sql Server 2008 测试用途:100w条数据 like 查询,原因添加、修改、删除消耗资源与时间相对较少,不易测试,查询里面最消耗时间的无非就是...like 与 in查询,我们就采用like 相对比较耗时与耗时间的典型来测。...LINQ TO SQL第一次的时候比较消耗资源,原因LINQ第一次初始化比较耗时,之后LINQ查询与ADO.NET几乎一样,在100w条数据下随然数据大同小异,但已经足够说明问题,LINQ TO SQL

    1.2K50

    List,DataTable实现行转列的通用方案

    根据以往经验使用SQL可以比较容易完成,这次决定挑战一下直接通过代码方式完成行转列。期间遇到几个问题和用到的新知识这里整理记录一下。...回到顶部 动态Linq    下面使用System.Linq.Dynamic完成行转列功能,Nuget上搜索System.Linq.Dynamic即可下载该包。    ...回到顶部 System.Linq.Dynamic其它用法     上面行转列代码见识了System.Linq.Dynamic的强大,下面再介绍一下会在开发中用到的方法。    ...上面用到了参数化查询,实现了查找姓名是张三的数据,通过这段代码你或许感受不到它的好处。但是和EntityFramework结合起来就可以实现动态拼接SQL的功能了。...item.IsDateTime) { //2016-07-19添加查询时忽略大小写比较

    2K70

    .NET深入解析LINQ框架(四:IQueryable、IQueryProvider接口详解)

    2】.扩展Linq to Object (应用框架具有查询功能) 我们知道LINQ所支持的查询范围主要在IEnumerable、IQueryable这两个方面,对于我们想要扩展LINQ的查询能力也主要集中在这两块...比如你在开发一个关于数据密集性的框架,可能不是实时的持久化,但是能在外部提供某种查询工具来查询内存中的数据,所以这个时候需要我们能扩展LINQ的Object查询能力。...对于IEnumerable对象的LINQ查询是Enumerable静态对象在支撑着,然后通过匿名表达式来表示逻辑,这样就能顺其自然的查询集合。那么我们该如何下手扩展Linq to Object?...顺着数字序号理解,IEnumerable是Linq to Object的数据源,而Enumerable静态类是专门用来扩展Linq查询表达式中的查询方法的,所以当我们编写Linq查询IEnumerable...由于问题比较复杂,这里不做全面的IQueryable的上下文分析,只保证本节的完整性。

    1.5K11

    .NET重构—单元测试的代码重构

    2.1.2.公用的MOCK行为; 2.1.3.公用的MOCK数据; 3.LINQ表达式的重构写法(将必要的LINQ写成普通的Function穿插在LINQ表达式中) 4.面向特定领域的单元测试框架(一切原则即是领域驱动...,尽管一开始很别扭,将一些直观的对象提取出来放入一眼看不见的地方是有点不太舒服,但是长远看来值得这么做; 3】LINQ表达式的重构写法(将必要的LINQ写成普通的Function穿插在LINQ表达式中)...,所以需要我们平衡一下在什么情况下需要将LINQ表达式替换成普通的Function来支持; LINQ在面对集合类型的时候,能发挥很大的作用;不仅在Linq to Object中,在其他的Linq to...Provider中都能在LINQ中找到了合适的使用之地;比如在对远程Service进行LINQ设计的时候,我们都是按照这样的方式进行编写,但是就怕LINQ中带有逻辑判断的表达式,这个时候就会在单元测试中总是无法覆盖到的情况出现...; 4.2.测试用例的数据重用(为自动化测试准备固定数据,建立Assert的比较测试数据) 同样比较重要的领域概念就是领域数据,领域数据也是单元测试中用例数据;为了能让测试进行自动化测试,我们需要维护一组相对固定的测试数据来供测试程序运行

    1.3K60

    由浅入深表达式树(完结篇)重磅打造 Linq To 博客园

    :) 实现目标   我们实现的目标就像Linq to SQL一样,可以用Linq查询语句来查询数据,我们这里面的数据用到了博客园官方的Service去查询到最新的发布到首页的博客信息。...,实际上我们有了IEnumrable的数据就可以直接在本地用Linq去查询它了。...为什么要通过Url来查询?因为我们最后会通过我们自己的LinqProvider将Linq查询语句直接翻译成Url这样就能够实现远程的返回数据了。来看看我们对Url参数的定义: ?...当然实现这个需求的方法有很多种,我们这里面有选了一种最简单方便又比较适合我们需求方式。...解析成我们要的对象 实现PostExpressionVisitor   关于表达式树的访问,我们在第二篇中已经有了比较详细的介绍。

    1.7K60

    ASP.NET MVC5+EF6+EasyUI 后台管理系统(90)-EF 扩展操作

    进行扩展的类库.支持EF EF5, EF6, EF Core,来弥补EF目前的短板 代码下载地址 支持功能: 批量删除 批量更新 Linq表达式 从缓存查询 延迟加载 过滤查询 组合查询功能 1.从NUGET...当然你要选择你对应的版本,并且同时你也安装了对应版本的EF版本(我选择EF6的扩展,那么我应该也对应现有的EF6)  2.操作(批量删除) 安装nuget包之后我们会发现我们平时惯用的linq表达式多了一些智能提示...var list2 = ctx.Spl_Product.Where(x => x.Code=="red").FromCache(DateTime.Now.AddHours(2)); } 我们在查询的最后加上....FromCache和.FromCache(DateTime.Now.AddHours(2))来分别设置缓存,所以我们在第一次查询之后就可以设置缓存 using (DBContainer ctx =...FutureValue(); } 似乎上面的七点,看起来使用方式都非常简单易懂,扩展自EF当然只是需要在后面.一下就出来,只需要记得Delete,Update,FromCaChe 下面来说最后一点,这一点比较有趣的

    96000

    LINQ分页和排序,skip和Take 用法

    说一下问什么这样做 dbconn 是Modle的对象 BidRecord 是一个实体 P=〉p.bid_id 是排序的条件 OrderBy 是排序(后面是条件)然后要查询所有的,在所有的数据中在查询你要分页的数据...,skip是在分页在前有多少条数据,也就是在当前页数据之前的数据总和, (跳过序列中指定数量的元素,然后返回剩余的元素。)...2.关于Linq排序的问题: linq中orderby 默认是升序(A-〉Z),可以添加 descending指定为降序(Z-〉A) order by n descending 3.对出错信息:LINQ...解决方案 DateTime date=DateTime.Parse(transDate); data = data.Where(p => EntityFunctions.DiffDays...(p.TranDate,date)==0);  4.linq里不能有方法 5.datatable使用groupby进行分组统计 [2] 如果要使用group by的话,可以使用linq,这是C#3.0

    1.9K90

    【asp.net core】7 实战之 数据访问层定义

    常见数据操作接口 在正常开发中,一个完整的数据操作接口会有很多分类,但是很多时候我们需要分开增删改和查询这两种操作。...对于数据库而言,视图和有些数据表都是不被允许改变的,这时候就需要我们只对调用方开放查询接口,而不开放修改接口。...,查询接口的方法有很多。...,如果没有这两个类,接口的定义会变得十分复杂,不利于代码的可读性: using System; using System.Collections.Generic; using System.Linq.Expressions...总结 在这一篇带领大家梳理了一下数据访问的接口定义,对一个系统来说,这些方法都是有必要的(但不是每个方法使用频率都一样高)。也是简单的跟大家分享一下我在实际工作中写代码的总结。

    75740

    ExtJs+WCF+LINQ实现分页Grid

    上篇文章《用ExtJs+Linq+Wcf打造简单grid 》,这个网格控件不带分页,本文在上文的基础上添加分页功能,文中会着重介绍如何在用LINQ返回分页数据,如何使ExtJs与WCF进行Restful...交互,如何在页面中添加一个带有分页功能的ExtJS的Grid控件。...第一步:在vs2008中创建一个支持.Net Framework 3.5,名称为:ExtJs_Wcf_Linq_PageGrid的Asp.Net网站, ?...第三步:在本文的示例中,我们使用SQL2005自带的示例数据库AdventureWorks中的数据表Product,默认情况下该示例数据库可能未安装,要安装此数据库,可以查阅SQL2005中文档与教程中的...、 拖动成功之后,便有vs2008的IDE自动生成了有关Product的实体类和linq操作数据表Product的操作类:ProductsDataContext,在可视化界面中也能有如下的显示: ?

    1.9K70

    .NET深入解析LINQ框架(六:LINQ执行表达式)

    阅读目录: 1.LINQ执行表达式 在看本篇文章之前我假设您已经具备我之前分析的一些原理知识,因为这章所要讲的内容是建立在之前的一系列知识点之上的,为了保证您的阅读顺利建议您先阅读本人的LINQ系列文章的前几篇或者您已经具备比较深入的...之前我一直以为VS只负责将LINQ的表达式翻译成等价的扩展方法调用,后来发现VS为了满足我们在前期无法确定对象条件的情况下进行Where字句的拼接,允许我们在编写LINQ语句的时候带有逻辑判断表达式在里面...追求优雅代码的同志很不希望在一个既有LINQ查询又带有链式查询的方法中用两种查询方式,如果LINQ能满足大部分的查询功能那最完美; 为了说明LINQ在编译时会被VS执行,我们用LINQPad工具看一下便知...我们还是来看一个比较简单的LINQ解析后的SQL和链式方法; LINQ查询表达式:from truck in TB_CX_TRUCKs where 1==1 ||truck.LICENSE_NUMBER.Length...(注:查看大图) 多条件之间的OR查询 尽管很多场合下我们都是使用Linq中的where关键字来拼接查询条件,但是有一种需求Linq查询确实满足不了我们,那就是多条件之间是OR的关系。

    1.3K10
    领券