现在如果想要使用过程式的代码来操作数据库,只能使用 mysqli 扩展了。当然,mysqli 扩展也是支持面向对象式的写法的。...什么是 MySQLi MySQLi 扩展允许我们访问 MySQL4.1 及以上版本的数据库所提供的功能。...而一些小型的框架或项目中,还是能够见到 MySQLi 的身影。...扩展的安装及 MySQL8 需要注意的地方 MySQLi 的扩展是随 PHP 源码一起发布的,我们在编译 PHP 的时候加上 --with-mysqli 就可以了。...在接下来的文章中,我们将默认只使用 面向对象 式的写法来继续学习 MySQLi 扩展相关的知识。
字符串int 拼接 SELECT ‘a-‘ + CONVERT(varchar(50), log_ID) AS Expr1, log_Title, log_Ur...
执行 SQL 语句 对于 PDO 来说,如果是查询语句,我们需要使用 query() 方法,如果是增、删、改之类的其它语句,我们要使用 exec() ,通过这两个方法分别执行不同的 SQL 语句。...如果执行的是 SELECT 语句,那么 query() 返回的就是一个 mysqli_result 对象,它代表从一个数据库查询中获取的结果集。关于这个对象的内容我们将在后面的文章中进行详细的说明。...这就是它的特点,它也并没有直接将结果集的信息保存在程序的内存中。所以,use_result() 方法最大的好处就是占用内存小,适合大量查询的遍历,缺点则是每次都要去数据库查询,速度慢。...store_result 除了 use_result() 之外,还有一个 store_result() 方法可以帮助我们获得查询的结果集。...int(0) // } // int(1) // array(1) { // ["now()"]=> // string(19) "2020-09-14 10:31:37" // } 不仅查询结果中的
PHP中的MySQLi扩展学习(一)MySQLi介绍 关于 PDO 的学习我们告一段落,从这篇文章开始,我们继续学习另外一个 MySQL 扩展,也就是除了 PDO 之外的最核心的 MySQLi 扩展。...现在如果想要使用过程式的代码来操作数据库,只能使用 mysqli 扩展了。当然,mysqli 扩展也是支持面向对象式的写法的。...什么是 MySQLi MySQLi 扩展允许我们访问 MySQL4.1 及以上版本的数据库所提供的功能。...而一些小型的框架或项目中,还是能够见到 MySQLi 的身影。...扩展的安装及 MySQL8 需要注意的地方 MySQLi 的扩展是随 PHP 源码一起发布的,我们在编译 PHP 的时候加上 --with-mysqli 就可以了。
对于 MySQLi 来说,事务和预处理语句当然是它之所以能够淘汰 MySQL(原始) 扩展的资本。我们之前也已经学习过了 PDO 中关于事务和预处理语句相关的内容。...所以在这里,我们就不再多讲理论方面的东西了,直接上代码来看看 MySQLi 中这两大特性与 PDO 在使用上的区别。 事务处理 首先,我们还是要让 MySQLi 对于错误的语句也报出异常来。...而在 MySQLi 中,我们则需要指定 MySQLi_Driver 对象中的报错属性为抛出异常,很明显,MySQLi_Driver 就是 MySQLi 的驱动对象。...预处理语句 总体来说,事务的处理和 PDO 的区别不大,但是预处理语句和 PDO 中的使用的区别就有一些了。首先是我们的 MySQLi 中的占位符只有 ? 问号占位。...这个参数表明的是绑定数据的类型,s 就是字符串类型。其它的类型我们在学习 MySQLi_STMT 相关的内容时再深入的了解。
执行 SQL 语句 对于 PDO 来说,如果是查询语句,我们需要使用 query() 方法,如果是增、删、改之类的其它语句,我们要使用 exec() ,通过这两个方法分别执行不同的 SQL 语句。...如果执行的是 SELECT 语句,那么 query() 返回的就是一个 mysqli_result 对象,它代表从一个数据库查询中获取的结果集。关于这个对象的内容我们将在后面的文章中进行详细的说明。...这就是它的特点,它也并没有直接将结果集的信息保存在程序的内存中。所以,use_result() 方法最大的好处就是占用内存小,适合大量查询的遍历,缺点则是每次都要去数据库查询,速度慢。...store_result 除了 use_result() 之外,还有一个 store_result() 方法可以帮助我们获得查询的结果集。...]=>// int(0)// }// int(1)// array(1) {// ["now()"]=>// string(19) "2020-09-14 10:31:37"// } 不仅查询结果中的
PHP中的MySQLi扩展学习(六)MySQLI_result对象操作 在之前的文章中,我们就已经接触过 MYSQLI_result 相关的内容。它的作用其实就是一个查询的结果集。...但在 MySQLi 中,会把查询到的结果也放入一个对象中,这就是 MySQLI_result 对象。...MySQLI_result 对象属性 首先,我们要通过一段查询来获得一个 MySQLI_result 对象。...查询结果集获取 MySQLI_result 对象的可见属性中,我们只能看到上面的那些信息。...我们可以直接获取到当前查询的结果集中的所有字段信息。
一、基础查询 1、多个字段的查询 select 字段1,字段2...字段n from 表名; -- 如果要查询所有字段,可以用*代替 2、去除重复 select distinct 字段1 from 表名...实例: -- 查询年龄大于等于20的学生 SELECT * FROM student WHERE age >= 20; -- 查询年龄等于20的学生 SELECT * FROM student WHERE...age = 20; -- 查询年龄不等于20的学生 SELECT * FROM student WHERE age !...NULL; 三、模糊查询 LIKE-模糊查询 占位符: _:单个任意字符; %:多个任意字符; 例如: -- 查询姓马的同学 SELECT * FROM student WHERE name LIKE...,having后可以进行聚合函数的判断; 七、分页查询 1、语法 limit 开始的索引,每页查询的条数; 2、示例 -- 每页查3条数据 SELECT * FROM student LIMIT 0,3
阅读更多 Struts中用bean:size/bean:write来显示查询结果集合之总记录数 并使用Struts的logic标签,遍历List时使用indeId来自动输出序号并加一 例子如下: 查询结果共有
常见的DNS记录类型 1.1 A记录(默认) $ dig dhcp.cn ; > DiG 9.10.6 > dhcp.cn ;; global options: +cmd ;; Got answer...MX 的记录为 ;; ANSWER SECTION: dhcp.cn. 600 IN MX 5 mxbiz1.qq.com. dhcp.cn. 600 IN MX 10 mxbiz2.qq.com...IN MX 10 mxbiz2.qq.com. 1.3 TXT 验证域名所有权会经常使用 DNS 解析 TXT记录的方式,比如申请 SSL 证书或 Google、百度站长认证时; $ dig +nocmd...其他查询 2.1 反向查询 通过 IP 查询域名,一般会把邮件服务器的IP转成域名,减少被当成垃圾邮件的可能性; $ dig -x 114.114.114.114 +short public1.114dns.com...Linux dig 2 sysgeek.cn 如何使用Dig命令在Linux中查询DNS记录 3 k8s入门教程. dig
在 MySQL中,慢查询日志是经常作为我们优化数据库的依据,那在MongoDB中是否有类似的功能呢?...Profiling 记录 与MySQL的慢查询日志不同,Mongo Profile 记录是直接存在系统db里的,记录位置 system.profile,所以,我们只要查询这个Collection的记录就可以获取到我们的...ntoreturn-本次查询客户端要求返回的记录数.比如, findOne()命令执行时 ntoreturn 为1.有limit(n) 条件时ntoreturn为n. ...query-具体的查询条件(如x>3). nscanned-本次查询扫描的记录数. reslen-返回结果集的大小. nreturned-本次查询实际返回的结果集. ...MongoDB 查询优化 如果nscanned(扫描的记录数)远大于nreturned(返回结果的记录数)的话,那么我们就要考虑通过加索引来优化记录定位了。
可以看出,MySQLI_STMT 的错误属性和信息基本和 MySQLi 对象的是一样的。 列绑定 除了请求查询语句参数的绑定之外,MySQLI_STMT 也是支持直接绑定列的。...MySQLI_STMT 中绑定列的方法名为 bind_result() ,虽说名字不一样,但功能其实都是差不多的,查询语句中是几个列名,就要绑定几个列名。...在这个表中,我们有四个字段,所以通过引用传递的方式绑定了 4 个列变量。当使用 fetch() 进行查询结果对象的遍历时,就像使用引用的方式为这 4 个列变量赋值。...在这段代码中,我们使用了 num_rows 这个属性来获得查询结果的行数量,这个属性是只针对 SELECT 语句的。...保存结果集及游标移动 最后就是关于游标的移动,上面的测试数据中我们可以查询到 7 条数据,并且第一条数据的 id 是 42 ,通过游标,我们可以不在 SQL 语句中使用 limit 而直接操作结果集来获取需要的数据
PHP中的MySQLi扩展学习(四)mysqli的事务与预处理语句 对于 MySQLi 来说,事务和预处理语句当然是它之所以能够淘汰 MySQL(原始) 扩展的资本。...事务处理 首先,我们还是要让 MySQLi 对于错误的语句也报出异常来。关于这个功能就和 PDO 很不一样了。在 PDO 中,我们直接指定连接的报错属性就可以了。...而在 MySQLi 中,我们则需要指定 MySQLi_Driver 对象中的报错属性为抛出异常,很明显,MySQLi_Driver 就是 MySQLi 的驱动对象。...预处理语句 总体来说,事务的处理和 PDO 的区别不大,但是预处理语句和 PDO 中的使用的区别就有一些了。首先是我们的 MySQLi 中的占位符只有 ? 问号占位。...这个参数表明的是绑定数据的类型,s 就是字符串类型。其它的类型我们在学习 MySQLi_STMT 相关的内容时再深入的了解。
目录 子域名信息查询 Layer子域名爆破机 subDomainBrute 利用google查询 HTTP证书查询 DNS记录查询脚本 IP转换为经纬度 利用网页获取对方经纬度信息 首先关于DNS域名解析的一些知识...一些和域名查询相关的网站: · DNS查询:https://dnsdb.io/ · 微步在线:https://x.threatbook.cn/ · 在线域名信息查询: http://toolbar.netcraft.com...通过查询DNS服务器,查询该域下的解析记录 3. 通过HTTPS证书来查询(只适用于https网站) ,如:https://crt.sh/ 就是通过https证书查询子域名 4....利用google查询 指定站点,然后-就是不包含这个,来查询 site:baidu.com -www HTTP证书查询 证书透明度(Certificate Transparency)是证书授权机构的一个项目...--------------------") #domain=input("请输入要查询的主域名(例如:baidu.com):") #查询MX记录 try: MX=dns.resolver.query
三.问题原因wildcard通配符模糊匹配查询需要使用正排索引,类似于关系型数据库中的“like”操作。在wildcard查询对数据进行匹配的过程中需要匹配很多类型的数据,所以整体耗时都会很长。...通过匹配字符串的方式对数据进行过滤查询。与elasticsearch使用倒排索引加速查询的理念背道而驰。...1.使用wildcard查询可能造成的潜在问题性能问题:通配符查询需要扫描所有的文档,因此对于大型索引,这可能会导致查询变慢。...精度问题:由于通配符查询会匹配所有符合条件的结果,因此可能会返回很多不相关的结果。内存问题:通配符查询需要在内存中维护正则表达式,如果正则表达式太复杂,可能会导致内存不足。...因此,通配符查询应该谨慎使用,尽量避免在大型索引上使用,并且应该使用更精确的查询方式来提高查询性能和结果的准确性。
PHP中的MySQLi扩展学习(二)mysqli类的一些少见的属性方法 虽说是少见的一些属性方法,但是可能还是有不少同学在日常的开发中使用过,这里只是学习了可能相对来说我们用得比较少的一些 mysqli...在这段代码中,我们的 root2 用户没有 blog_test 表的 SELECT 权限,所以返回的 query() 查询结果是空的。...通过打印 mysqli 的 error_list 属性就可以看到当前的错误信息。 错误信息 紧接着上一段,对于执行语句的错误信息,我们可以通过几个 mysqli 中的属性来获得。...stat 简单的统计信息,里面能看到有 4 个线程,没有慢查询等等。大家可以仔细地研究一下这个对象中的这些属性,或许某些内容就是你在实际项目中所需要的。...我们还没有正式开始学习查询之类的语句,不过从这些属性方法就可以看出,相对于 PDO 来说,mysqli 提供的功能确实更加的全面一些。后面我们将继续深入地学习和探索 mysqli 的各种方法和使用。
,不是queryset类型,是行记录对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误。...first() queryset类型的数据来调用,返回第一条记录。...Book.objects.all()[0] = Book.objects.all().first()得到的都是model对象,不是queryset last() queryset类型的数据来调用,返回最后一条记录...objects Model(行记录对象) exclude 匹配非条件的对象 objects QuerySet order_by 对查询结果进行排序 QuerySet QuerySet reverse...对查询结果反向排序 QuerySet QuerySet count 返回匹配查询的对象数量 QuerySet int first 返回第一条记录 QuerySet Model last 返回最后一条记录
前言 本文章主要记录下常用的sql查询,简单的直接展示语句,复杂的做一下解释。 1、sql按月统计每月订单数量要按月统计每月的订单数量,您可以使用MySQL中的日期函数和聚合函数。...开头的所有客户记录。...FROM table_name WHERE column_name ILIKE pattern;下述查询将返回以 "john" 开头的所有客户记录,不区分大小写SELECT * FROM customers...employees;在这个例子中,如果"first_name"是非NULL的,那么查询就会返回"first_name"的值。...如果"first_name"是NULL,但"last_name"是非NULL的,那么查询就会返回"last_name"的值。如果两列都是NULL,那么查询就会返回NULL。
在生产环境中,通常有DBA同事对数据库进行监控,在发现如慢查询等问题时反馈给开发团队进行解决。....NET平台提供了诊断机制,借助该机制可以实现EFCore记录慢查询日志功能,这样开发团队就可以通过日志告警发现慢查询问题而无需被动依赖DBA同事的反馈。...记录慢查询日志 基于.NET6创建API项目,安装WJChi.Net.EFCoreSlowQuery包,示例代码如下: using Api.Database; using EFCoreExtensions.Middlewares
领取专属 10元无门槛券
手把手带您无忧上云