下面员工3的薪水大于其主管的薪水,一条SQL找到薪水比下属低的主管

id username salary pid
1 a 3000 null
2 b 8000 null
3 c 5000 1
4 d 6000 3
  1. SELECT a.*, b.*
  2. FROM `user` as a
  3. LEFT JOIN `user` as b ON a.pid = b.id AND a.salary > b.salary
  4. WHERE b.id > 0;

事务有几种隔离级别?事务的隔离级别是怎么实现的?

  • 读未提交(read-uncommitted)
  • 不可重复读(read-committed)
  • 可重复读(repeatable-read)
  • 串行化(serializable)
  1.  、抽象类和接口的概念以及区别?

抽象类:它是一种特殊的,不能被实例化的类,只能作为其他类的父类使用。使用abstract关键字声明。

接口:它是一种特殊的抽象类,也是一个特殊的类,使用interface声明。

区别:

(1)抽象类的操作通过继承关键字extends实现,而接口的使用是通过implements关键字来实现。

(2)抽象类中有数据成员,可以实现数据的封装,但是接口没有数据成员。

(3)抽象类中可以有构造方法,但是接口没有构造方法。

(4)抽象类的方法可以通过private、protected、public关键字修饰(抽象方法不能是private),而接口中的方法只能使用public关键字修饰。

(5)一个类只能继承于一个抽象类,而一个类可以同时实现多个接口。

(6)抽象类中可以有成员方法的实现代码,而接口中不可以有成员方法的实现代码。

__autoload()方法的工作原理是什么?

使用这个魔术函数的基本条件是类文件的文件名要和类的名字保持一致。

当程序执行到实例化某个类的时候,如果在实例化前没有引入这个类文件,那么就自动执行__autoload()函数。

这个函数会根据实例化的类的名称来查找这个类文件的路径,当判断这个类文件路径下确实存在这个类文件后

就执行include或者require来载入该类,然后程序继续执行,如果这个路径下不存在该文件时就提示错误。

使用自动载入的魔术函数可以不必要写很多个include或者require函数。

PHP sprintf() 函数

把百分号(%)符号替换成一个作为参数进行传递的变量:

  1. <?php
  2. $number = 2;
  3. $str = "Shanghai";
  4. $txt = sprintf("There are %u million cars in %s.",$number,$str);
  5. echo $txt;
  6. ?>
    There are 2 million cars in Shanghai.

定义和用法

sprintf() 函数把格式化的字符串写入变量中。

arg1arg2++ 参数将被插入到主字符串中的百分号(%)符号处。该函数是逐步执行的。在第一个 % 符号处,插入 arg1,在第二个 % 符号处,插入 arg2,依此类推。

注释:如果 % 符号多于 arg 参数,则您必须使用占位符。占位符位于 % 符号之后,由数字和 "\$" 组成。请参见例子 2。

提示:相关函数:printf()、 vprintf()、 vsprintf()、 fprintf() 和 vfprintf()

format

必需。规定字符串以及如何格式化其中的变量。

可能的格式值:

  • %% - 返回一个百分号 %
  • %b - 二进制数
  • %c - ASCII 值对应的字符
  • %d - 包含正负号的十进制数(负数、0、正数)
  • %e - 使用小写的科学计数法(例如 1.2e+2)
  • %E - 使用大写的科学计数法(例如 1.2E+2)
  • %u - 不包含正负号的十进制数(大于等于 0)
  • %f - 浮点数(本地设置)
  • %F - 浮点数(非本地设置)
  • %g - 较短的 %e 和 %f
  • %G - 较短的 %E 和 %f
  • %o - 八进制数
  • %s - 字符串
  • %x - 十六进制数(小写字母)
  • %X - 十六进制数(大写字母)

附加的格式值。必需放置在 % 和字母之间(例如 %.2f):

  • + (在数字前面加上 + 或 - 来定义数字的正负性。默认情况下,只有负数才做标记,正数不做标记)
  • ' (规定使用什么作为填充,默认是空格。它必须与宽度指定器一起使用。例如:%'x20s(使用 "x" 作为填充))
  • - (左调整变量值)
  • [0-9] (规定变量值的最小宽度)
  • .[0-9] (规定小数位数或最大字符串长度)

注释:如果使用多个上述的格式值,它们必须按照以上顺序使用。

arg1 必需。规定插到 format 字符串中第一个 % 符号处的参数。
arg2 可选。规定插到 format 字符串中第二个 % 符号处的参数。
arg++ 可选。规定插到 format 字符串中第三、四等 % 符号处的参数

使用格式值 %f:

  1. <?php
  2. $number = 123;
  3. $txt = sprintf("%f",$number);
  4. echo $txt;
  5. ?>
    123.000000

例子 2

使用占位符:

  1. <?php
  2. $number = 123;
  3. $txt = sprintf("带两位小数:%1\$.2f
  4. <br>不带小数:%1\$u",$number);
  5. echo $txt;
  6. ?>

例子 3

对所有可能的格式值的演示:

  1. <?php
  2. $num1 = 123456789;
  3. $num2 = -123456789;
  4. $char = 50; // ASCII 字符 50 是 2
  5.  
  6. // 注释:格式值 "%%" 返回百分号
  7. echo sprintf("%%b = %b",$num1)."<br>"; // 二进制数
  8. echo sprintf("%%c = %c",$char)."<br>"; // ASCII 字符
  9. echo sprintf("%%d = %d",$num1)."<br>"; // 带符号的十进制数
  10. echo sprintf("%%d = %d",$num2)."<br>"; // 带符号的十进制数
  11. echo sprintf("%%e = %e",$num1)."<br>"; // 科学计数法(小写)
  12. echo sprintf("%%E = %E",$num1)."<br>"; // 科学计数法(大写)
  13. echo sprintf("%%u = %u",$num1)."<br>"; // 不带符号的十进制数(正)
  14. echo sprintf("%%u = %u",$num2)."<br>"; // 不带符号的十进制数(负)
  15. echo sprintf("%%f = %f",$num1)."<br>"; // 浮点数(视本地设置)
  16. echo sprintf("%%F = %F",$num1)."<br>"; // 浮点数(不视本地设置)
  17. echo sprintf("%%g = %g",$num1)."<br>"; // 短于 %e 和 %f
  18. echo sprintf("%%G = %G",$num1)."<br>"; // 短于 %E 和 %f
  19. echo sprintf("%%o = %o",$num1)."<br>"; // 八进制数
  20. echo sprintf("%%s = %s",$num1)."<br>"; // 字符串
  21. echo sprintf("%%x = %x",$num1)."<br>"; // 十六进制数(小写)
  22. echo sprintf("%%X = %X",$num1)."<br>"; // 十六进制数(大写)
  23. echo sprintf("%%+d = %+d",$num1)."<br>"; // 符号说明符(正)
  24. echo sprintf("%%+d = %+d",$num2)."<br>"; // 符号说明符(负)
  25. ?>

例子 4

对字符串说明符的演示:

  1. <?php
  2. $str1 = "Hello";
  3. $str2 = "Hello world!";
  4.  
  5. echo sprintf("[%s]",$str1)."<br>";
  6. echo sprintf("[%8s]",$str1)."<br>";
  7. echo sprintf("[%-8s]",$str1)."<br>";
  8. echo sprintf("[%08s]",$str1)."<br>";
  9. echo sprintf("[%'*8s]",$str1)."<br>";
  10. echo sprintf("[%8.8s]",$str2)."<br>";
  11. ?>
  1.  

PHPsql的更多相关文章

  1. PHPSQL注入

    什么是SQL注入? 就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令. 例如一个简单的登录表单(这里把密码写成明文方便说明):  当在表 ...

  2. PHP SQL写法 积累(注:PHPSQL与LINQ SQL相似)

    1: $data ['parentid'] = $pid; M('menu')->where($data)->order(' id asc  ')-> select();   // ...

  3. PHP-SQL查询上升的温度

    给定一个 Weather 表,编写一个 SQL 查询,来查找与之前(昨天的)日期相比温度更高的所有日期的 Id. +---------+------------------+------------- ...

  4. php date("Y-m-d H:i:s") 出现警告信息

    使用: $createtime=date("Y/m/d H:i:s", time()+16*60*60); $createtime=date("Y-m-d H:i:s&q ...

  5. WordPress网站搭建

    . 1.进入 var/www/html中放入里的文件 2.. 安装http php php-sql [root@jw38 yum.repos.d]# systemctl restart httpd.s ...

  6. php 和mysql httpd 简单网页的搭建

    使用两台服务器 Centos 7 做 php和httpd和php-sql 服务的安装  CentOS 5 做php 和 mysql 的安装 1.搭建本地yum源 两台服务器  都是 2.关闭防火墙和s ...

  7. 2012 PHP热门资料64个+经典源码50个——下载目录 :

    完整附件0豆下载:http://down.51cto.com/data/419216 附件部分预览: PHP精彩应用实例程序源码集锦 http://down.51cto.com/zt/39 无师自通: ...

  8. 转:攻击JavaWeb应用[1]-javaEE基础

    http://www.cnblogs.com/oh3o/p/3224562.html JSP: 全名为java server page,其根本是一个简化的Servlet. Servlet:Servle ...

  9. 关于ECSHOP中sql注入漏洞修复

    标签:ecshop sql注入漏洞修复 公司部署了一个ecshop网站用于做网上商城使用,部署在阿里云服务器上,第二天收到阿里云控制台发来的告警信息,发现ecshop网站目录下文件sql注入漏洞以及程 ...

随机推荐

  1. css 性能优化小结

    1.能用css不用js 1.鼠标悬浮展示              2.自定义radio.checkbox的样式 3.巧用css伪类 当input获取焦点时候,把右边的按钮改变样式 检测用户输入:如果 ...

  2. 运营商专线服务的基本原理(BGP传递私网路由)

  3. Conccrent中 Unsafe类原理 以及 原子类AutomicXX的原理以及对Unsafe类的使用

    Unsafe类的介绍 Java中基于操作系统级别的原子操作类sun.misc.Unsafe,它是Java中对大多数锁机制实现的最基础类.请注意,JDK 1.8和之前JDK版本的中sun.misc.Un ...

  4. Android为TV端助力 事件分发机制

    android事件分发机制,给控件设置ontouch监听事件,当ontouch返回true时,他就不会走onTouchEvent方法,要想走onTouchEvent方法只需要返回ontouch返回fa ...

  5. drawable自定义字体颜色

    一个很基础简单的问题,但是以前没用过,都是代码控制效果的,最近新的项目发现设置了color属性没效果,后来查了会资料才发现得单独设置,记录一下,虽然是小问题 上面的xml控制背景的变化,一开始我设置在 ...

  6. 五. Redis持久化

    Redis是一个支持可持久化的内存数据库,也就是说Redis可以将数据保存到硬盘当中. 目前Redis支持两种持久化方式: 1. snapshotting 快照方式(默认方式). 2. append- ...

  7. OkHttp的缓存

    看到很多小伙伴对OkHttp的缓存问题并不是十分了解,于是打算来说说这个问题.用好OkHttp中提供的缓存,可以帮助我们更好的使用Retrofit.Picasso等配合OkHttp使用的框架.OK,废 ...

  8. java抓取网页或者文件的邮箱号码

    抓文件的 package reg; import java.io.BufferedReader; import java.io.FileNotFoundException; import java.i ...

  9. java国际化---native2ascii.exe 的使用方法

    从另一个博客迁移 native2ascii.exe使用方法: 命令的语法格式: native2ascii -[options] [inputfile [outputfile]] 说明: -[optio ...

  10. sqlserver中分区函数 partition by与 group by 区别 删除关键字段重复列

    partition  by关键字是分析性函数的一部分,它和聚合函数(如group by)不同的地方在于它能返回一个分组中的多条记录,而聚合函数一般只有一条反映统计值的记录, partition  by ...