灵感来了也记不住,在这里记录一下一些sql查询,方便以后复制粘贴 往角色为st_admin的用户的user_msg表中插入一条记录。...on ur.role_id=r.id where r.role_name=#{role} ) tmp 往ids这一群用户的user_msg表中插入一条记录
确保某列(或两个列多个列的结合)有唯一标识,有助于更容易更快速地找到表中的一个特定的记录。 FOREIGN KEY - 外键,保证一个表中的数据匹配另一个表中的值的参照完整性。...LIKE:取匹配的数据;NOT LIKE:取不匹配的数据;通过通配符-、%操控模糊查询部分。...SQL JOIN INNER JOIN:如果表中有至少一个匹配,则返回行 LEFT JOIN:即使右表中没有匹配,也从左表返回所有的行 RIGHT JOIN:即使左表中没有匹配,也从右表返回所有的行...修改 请注意 SQL UPDATE 语句中的 WHERE 子句! WHERE 子句规定哪条记录或者哪些记录需要更新。如果您省略了 WHERE 子句,所有的记录都将被更新!...删除 请注意 SQL DELETE 语句中的 WHERE 子句! WHERE 子句规定哪条记录或者哪些记录需要删除。如果您省略了 WHERE 子句,所有的记录都将被删除!
[ 和 ] 不匹配任何字符,它们只负责定义一个字符集合。接下来,正则表达式里的普通字符 a 匹配字符 a ,. 匹配一个任意字符,\\. 匹配 . 字符本身,普通字符 xls 匹配字符串 xls。...这个模式可以匹配 RegEx 和 regex,但不匹配 REGEX。如果打算进行一次不需要区分字母大小写的匹配,不使用这个技巧也能达到目的。...A-Z:匹配从 A 到 Z 的所有大写字母。 a-z:匹配从 a 到 z 的所有小写字母。 A-F,匹配从 A 到 F 的所有大写字母。...这将匹配一个由字符 # 开头,然后是 6 个数字或字母 A 到 F (大小写均可)的字符串。 三、排除 字符集合通常用来指定一组必须匹配其中之一的字符。...但在某些场合,我们需要反过来做,即指定一组不需要匹配的字符。换句话说,就是排除字符集合里指定的那些字符。不用逐个列出要匹配的字符,如果只是要把一小部分字符排除在外的话,这种写法就太冗长了。
防sql注入之模糊匹配中%、_处理: StringBuilder sbSql = new StringBuilder(); sbSql.Append(@"SELECT...sbSql.AppendFormat(@" AND t.Name like '%{0}%'", name); } 上述采用的是拼接字符串,现改为参数化,防止sql
在这里,INNER JOIN(内连接,或等值连接):取得两个表中存在连接匹配关系的记录。...join 来联合table1和table2 在使用INNER jion时,on和where条件的区别如下: 1、 on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录...这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。
Laravel 默认只在sql语法错误时提示完整的sql日志,但实际情况接口慢,筛选条件和预期不符等,都需要看到sql语句,通过sql语句判断问题所在 下面介绍实现方式 第一步 修改 AppServiceProvider.php.../', (string) $value, $sql, 1); } $sql = sprintf('【%s】 %s...', $this->format_duration($query->time / 1000), $sql); Log::channel('sql')->debug($sql...'s'; } } 第二步 修改 config/logging.php 增加sql日志开关 /** * 开启sql日志 */ 'enable_log_sql'...=> env('LOG_SQL_ENABLED', true), 日志默认输出到 storage/logs/laravel.log文件,为了区分开,增加以下配置 'sql'
在SQL Server中经常会用到模糊匹配字符串的情况,最简单的办法就是使用like关键字(like语法http://msdn.microsoft.com/en-us/library/ms179859....但是如果我们使用的前后都加%的方式,是没办法用到索引进行快速查询的,所以很多情况下我们使用左匹配的方式。...使用左匹配的好处是可以使用到SQL Server中对该字段建立的索引,使得查询效率很高,但是不好的SQL语句仍然会导致索引无法使用。...Where条件: WHERE this_.Matnr like @p0 escape '~';@p0 = '~%00%' 以上说的都是在ORMapping的工具中进行左匹配查询,如果我们要在SQL语句中直接进行查询还有一种写法就是用...同样以YCMRSALE表举例,如果我们有另一表matnr,该表中的matnr列存储了不完整的料号,现在需要将两个表join起来,使用matnr列进行左匹配,那么我们的SQL可以写成: select *
一、前言 本博客只记录工作中的一次oracle sql调优记录,因为数据量过多导致的查询缓慢,一方面是因为业务太过繁杂,关联了太多表。面对复杂的业务场景,确实有些情况是需要关联很多表的。...三、Oracle执行计划 对于SQL调优,可以通过Oracle的执行计划来分析。oracle的执行计划确实是对sql进行分析的一种很好的方法。 下面介绍一下oracle的执行计划。...找个SQL,用PLSQL执行一下,这是plsql的简单使用 ?...下面给出一篇很详细介绍oracle执行计划的博客 https://www.cnblogs.com/Dreamer-1/p/6076440.html 四、调优记录 4.1 强制索引 在加一些索引的过程,...原来SQL,简单写一下,举个例子,实际的业务场景不是这么简单的sql select max(to_number(aa.seq)) from t_info aa where aa.id = ?
gorm可以方便的输出执行的sql或慢查询。logrus是常用的日志组件,如何将gorm输出的sql通过logrus记录到日志中呢? 如果你还不知道如何让gorm输出sql,请猛击这里。 1....//利用loggus记录日志 m.mlog.Info(logstr) } func NewMyWriter() *MyWriter{ log := logrus.New() //配置logrus...true&loc=Local" slowLogger := logger.New( //设置Logger NewMyWriter(), logger.Config{ //慢SQL...阈值 SlowThreshold: time.Millisecond, //设置日志级别,只有Warn以上才会打印sql LogLevel: logger.Warn, }...LoginTime:time.Now(), } DB.Create(&d) } 输出 {"level":"info","msg":"/home/ballqiu/go/gorm/main.go:90 SLOW SQL
用SQL语句,删除掉重复项只保留一条 在几千条记录里,存在着些相同的记录,如何能用SQL语句,删除掉重复的呢 1、查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断 select...peopleId in (select peopleId from people group by peopleId having count(peopleId) > 1) 2、删除表中多余的重复记录...,重复记录是根据单个字段(peopleId)来判断,只留有rowid最小的记录 delete from people where peopleName in (select peopleName...in (select min(peopleId) from people group by peopleName having count(peopleName)>1) 3、查找表中多余的重复记录...(多个字段),只留有rowid最小的记录 delete from vitae a where (a.peopleId,a.seq) in (select peopleId,seq from vitae
前言 本文章主要记录下常用的sql查询,简单的直接展示语句,复杂的做一下解释。 1、sql按月统计每月订单数量要按月统计每月的订单数量,您可以使用MySQL中的日期函数和聚合函数。...执行此查询后,您将获得一个结果集,其中包含每个月的订单数量2、sql按升序排列SELECT column1, column2, ......进行不区分大小写的模糊查询SELECT column_name FROM table_name WHERE column_name ILIKE pattern;下述查询将返回以 "john" 开头的所有客户记录...--------------- 2024-01-29 10:56:53在正则表达式 (\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}) 中:\d{4}-\d{2}-\d{2} 匹配日期部分...匹配空格。\d{2}:\d{2}:\d{2} 匹配时间部分(时:分:秒)。请注意,这种方法假设日期和时间之间只有一个空格,并且时间部分始终紧跟在日期之后。
SQL通配符字符 通配符字符用于替代字符串中的一个或多个字符。通配符字符与LIKE运算符一起使用。LIKE运算符用于在WHERE子句中搜索列中的指定模式。..."on" 结尾的城市的客户: SELECT * FROM Customers WHERE City LIKE 'L___on'; 使用 [] 通配符 [] 通配符返回一个结果,如果括号内的任何字符都匹配...; 示例 返回第二个位置有 "r" 的客户: SELECT * FROM Customers WHERE CustomerName LIKE '_r%'; 没有通配符 如果没有指定通配符,短语必须精确匹配才能返回结果
很多时候,都需要对数据表进行历史记录。比如每修改一次表单,之前的表单数据都需要计入历史。当表单比较多的时候,记录历史是一件比较麻烦的事情。又要建日志表,又要写存储过程,又要写页面逻辑等等。...最近做项目时碰到了,要求每次审核、退回等操作时就要记录表历史。于是,笔者就想到了以下方案。在此与大家分享了,如果有更合适的或合理的建议,请回复本帖。...SQL里面实现遍历数据集不方便,不想用游标,于是采用了以下方式。具体存储过程如下: USE [NbShop] GO /****** Object: StoredProcedure [dbo]....3)记录日志 日志表有了,还得记录日志呢。为每个表写个存储过程会过于繁琐,而且改动了就得跟着改动。就是码农也吃不消。...========================================= -- Author: LWQ -- Create date: 2011-6-29 -- Description: 记录日志
一、余弦相似度的原理 在利用sql实现余弦相似度匹配之前,先讲一讲实现余弦相似度的原理,相信搞清楚原理之后,你可以用多种方法计算出两个向量之间的余弦相似度。...二、利用SQL计算相似度 通过上面的学习你应该已经搞清楚了余弦相似度的基本原理,接下来我们就开始利用sql来进行余弦相似度的计算。...上述可知,我们通体进行的都是向量的计算,所以在进行相似度计算之前,要先将数据转换成向量的形式,这里以 My sql 为例(以下简称为sql),而sql并不会直接将数据转换为向量形式,所以我们也不能真正的进行向量之间的运算...可以分别看做是三个向量,则由点积计算的公式可以知道他们的点积为: select sum(field1 * field2 * field3) as dot_product from table_b; 这里先将每行记录的... field1、field2 和 field3 三个字段的值相乘,对于每一行记录都会进行这样的操作,得到该行三个字段的乘积结果。
现在越来越多人用plsql 查询和执行sql,因为该工具很方便,不仅可以执行sql、以及命令窗口,但是呢,有时候我们执行完sql,可能忘记保存或者当时觉得可能不怎么重要,就没有保存, 等到了第二天或者过段时间...,想看看之前执行的sql,这时候怎么办呢?...首先打开sql窗口,如图所示 ? 然后,按住 CTRL+E,就会显示之前执行过的sql语句啦 ?...但是显示的好像只有最近200条的,,所以大家在执行sql 的时候,最好还是每天可以备份一下自己执行过的sql语句,毕竟好记性不如烂笔头
前言 本篇文章是在做ctf bugku的一道sql 盲注的题(题目地址:注入题目)中运用了fuzz的思路,完整记录整个fuzz的过程,给师傅们当点心,方便大家加深对web sql注入 fuzz的理解。...2.尝试输入admin/123456,提示密码错误,因此可以确定存在用户admin,这里可能会有师傅要爆破了,但这里题目要求sql注入,我们就按照预期解来吧。 ?...可以看到结果是确实不行,并不能产生延时(有的直接被wa,有的没被wa但sql语句无法生效),因此基本可以确认不能用时间盲注跑数据,于是我们只能考虑布尔盲注 (6)尝试布尔盲注 由于无法使用if或者case
CTFHUB 解题记录-SQL基础 本文是在做ctfhub时的记录笔记。这应该是SQL注入的入门题目,所以是一定要会的。...关于什么SQL注入我就详细解释了,咱就直接上题目。题目有的过程和步骤都是相同的或者是相似的,我就直接跳过了,望周知。 第一题:整数型注入 整形注入就是数字型注入,不需要 ’,“ 符号做截断。...第五题:延时盲注 第六题:SQL结构 第七题:Cookie注入 通过burp抓包,在Cookie字段观察尝试,就会发现有注入点。
QS.max_worker_time, QS.min_worker_time FROM sys.dm_exec_query_stats QS CROSS APPLY sys.dm_exec_sql_text...(QS.sql_handle) ST WHERE QS.creation_time BETWEEN '2017-09-09 10:00:00' AND '2017-09-11 18:00:00'
删除表中多余的重复记录,重复记录是根据单个字段(id)来判断,只留有rowid最小的记录 //删除用户 根据用户名,并且不包括最小ID delete from users where username
执行数据库查询时,有完整查询和模糊查询之分,一般模糊语句如下: SELECT 字段 FROM 表 WHERE 某字段 Like 条件 一、四种匹配模式 关于条件,SQL提供了四种匹配模式: 1、% 表示任意...0个或多个字符,可匹配任意类型和长度的字符。...需用两个百分号(%%)表示: SELECT * FROM [user] WHERE u_name LIKE ‘%三%’ 将会把 u_name 为“张三”、“张猫三”、“三脚猫”、“唐三藏”等有“三”的记录全找出来...另外,如果须要找出 u_name 中既有“三”又有“猫”的记录,请运用 and 条件 SELECT * FROM [user] WHERE u_name LIKE ‘%三%’ AND u_name...匹配单个任意字符,它常用来限定表达式的字符长度语句: SELECT * FROM [user] WHERE u_name LIKE ‘三’ 只找出“唐三藏”这样 u_name 为三个字且中间一个字是“三
领取专属 10元无门槛券
手把手带您无忧上云