-
探讨selectin在postgresql的效率问题
在知乎上看到这样一个问题:MySQL查询select*fromtablewhereidin(几百或几千个id)如何提高效率?修改电商网站,一个商品属性表,几十万条记录,80M,索引只有主键id,做这样的查询如何提高效率?select*fromtablewhereidin(几百或几千个id)这些id没啥规律,分散的。...
数据库操作教程 2022-09-23 16:44:40 -
SQLServer2016里的sys.dm_exec_input_buffer的问题
我们都知道DBCC命令有点尴尬,因为你不能在T-SQL查询里调用它们,你也不能关联它们的输出到其它DMV/DMF。例如你想为每个用户会话返回最后一个执行的SQL语句....sys.dm_exec_input_buffer在SQLServer2016里,事情就变得简单多,因为微软为你提供了一个新DMFsys.dm_exec_input_buffer,它和DBCCINPUTBUFFER一样做同样的工作...
数据库操作教程 2022-09-23 16:44:14 -
sqlserver编写archive通用模板脚本实现自动分批删除数据
博主做过比较多项目的archive脚本编写,对于这种删除数据的脚本开发,肯定是一开始的话用最简单的一个delete语句,然后由于部分表数据量比较大啊,索引比较多啊,会发现删除数据很慢而且影响系统的正常使用。然后就对delete语句进行按均匀数据量分批delete的改写,这样的话,原来的删除一个表用一个语句,就可能变成几十行,如果archive的表有十几个甚至几十个,那我们的脚本篇幅就非常大了,增加了开发和维护的成本,不利于经验比较少的新入职同事去开发archive脚本,也容易把注意力分散到所谓分批逻辑中...
数据库操作教程 2022-09-23 16:43:38 -
mybatiscollection多条件查询的实现方法
mybatiscollection多条件查询的实现方法前言:业务需要通过mybatis查询返回嵌套集合,嫌多次查询太麻烦,用自带的高级查询解决问题,下边是代码,已测试通过。说下自己的理解,就是一个主查询结果集里面嵌套了子查询的结果集,可以是多个子查询,每个子查询的条件从主查询结果集中获取,返回值各自定义...
数据库操作教程 2022-09-23 16:43:37 -
SQLyog连接MySQL8.0报2058错误的完美解决方法
引言用SQLyog连接MySQL8.0(社区版:mysql-installer-community-8.0.15.0.msi),出现错误2058(Plugincaching_sha2_passwordcouldnotbeloaded:xxxx),通过查询资料了解了该错误的原因并在本文中提出了该问题的方案。原因该错误提示如下图所示:具体原因:新的MySQL8.0安装,在初始化数据目录时,将‘root'@'localhost'创建帐户,并且该帐户caching_sha2_password默认使用,密码的加密方法发生了改变,因此SQLyog不能正常解析,才报出如上错误...
数据库操作教程 2022-09-23 16:42:56 -
SQLServer查看login所授予的具体权限问题
在SQLServer数据库中如何查看一个登录名(login)的具体权限呢,如果使用SSMS的UI界面查看登录名的具体权限的话,用户数据库非常多的话,要梳理完它所有的权限,操作又耗时又麻烦,个人十分崇尚简洁、高效的方法,反感那些需要大量手工操作的UI界面操作方式,哪怕就是脚本,如果不能一次搞定,手工多操作几次(例如,切换数据库),都是不可接受的。最近遇到这个需求,就完善了一下之前的脚本get_login_rights_script.sql,输入登录名参数,将这个登录名所拥有的服务器角色、数据库角色、以及所授予具体对象的相关权限使用脚本查询出来,脚本分享如下:--==================================================================================================================--ScriptName:get_login_rights_script.sql--Author:潇湘隐者--CreateDate:2015-12-18--Description:查看某个登录名被授予的数据...
数据库操作教程 2022-09-23 16:42:55 -
SQLServer中的SELECT会阻塞SELECT吗
前言在SQLServer中,我们知道一个SELECT语句执行过程中只会申请一些意向共享锁(IS)与共享锁(S),例如我使用SQLProfile跟踪会话86执行SELECT*FROMdbo.TESTWHEREOBJECT_ID=1这个查询语句,其申请、释放的锁资源的过程如下所示:而且从最常见的锁模式的兼容性表,我们可以看到IS锁与S锁都是兼容的,也就是说SELECT查询是不会阻塞SELECT查询的。现有的授权模式请求的模式ISSUIXSIXX意向共享 (IS)是是是是是否共享 (S)是是是否否否更新 (U)是是否否否否意向排他 (IX)是否否是否否意向排他共享(SIX)是否否否否否排他 (X)否否否否否否但是在某些特殊场景...
数据库操作教程 2022-09-23 16:42:50 -
sqlserver使用公用表表达式CTE通过递归方式编写通用函数自动生成连续数字和日期
问题:在数据库脚本开发中,有时需要生成一堆连续数字或者日期,例如yearlyreport就需要连续数字做年份,例如dailyreport就需要生成一定时间范围内的每一天日期。而自带的系统表master..spt_values存在一定的局限性,只是从0到2047(验证脚本:select*frommaster..spt_valuesbwhereb.type='P'),也不能直接生成连续日期...
数据库操作教程 2022-09-23 16:42:36 -
sqlserver之datepart和datediff应用查找当天上午和下午的数据
DATEPART()函数用于返回日期/时间的单独部分,比如年、月、日、小时、分钟等等。DATEDIFF()函数返回两个日期之间的时间差...
数据库操作教程 2022-09-23 16:42:30 -
sqlserver中错误日志errorlog的深入讲解
一.概述SQLServer将某些系统事件和用户定义事件记录到SQLServer错误日志和MicrosoftWindows应用程序日志中。这两种日志都会自动给所有记录事件加上时间戳...
数据库操作教程 2022-09-23 16:42:27 -
SqlServer中批量update语句
现在我有两张表分别是S_PERSON,S_USERS_PERSON S_USER我现在想把S_USER表中的ACCOUNT批量修改成S_PERSON的ACCOUNT我们可以发现S_USER表中有个跟S_PERSON表关联的字段那就是PERSON_ID这也是我们要update的条件找到这个关系以后我们就不难写sql了updateS_USER setaccount=p.accountfromS_PERSON pwherep.id=S_USER.person_id;结果为:sqlserveras语法举例1、使用表名称别名有两个表分别是:"Persons"和"Product_Orders"。分别为它们指定别名"p"和"po"...
数据库操作教程 2022-09-23 16:42:12 -
余承东:华为会抓紧生产,保障Mate50/Pro系列供应
IT之家9月23日消息,9月22日,华为常务董事、终端业务CEO、智能汽车解决方案事业群CEO余承东在微博发文称,“9月21日,华为Mate50系列开启销售,大批热情的消费者前往华为门店购机。非常感谢大家对Mate50系列的喜爱与支持,华为会抓紧生产,保障产品供应,让更多消费者用上Mate50系列手机...
手机互联 2022-09-23 08:17:43