发布网友 发布时间:2022-04-23 00:03
共3个回答
懂视网 时间:2022-04-07 20:45
.php 下插入
<?php namespace HomeController; use ThinkController; use ThinkModel; class UserController extends Controller { public function model() { $user = M(‘User‘); var_dump($user->where(‘id=1‘)->select()); } }
这是最基本的调用方法,更详细点则是
var_dump($user->where(‘id=1 and user = "蜡笔小新"‘)->select());
二、下面介绍数组查询方法:
就是将 var_dump($user->where(‘id=1‘)->select()); 这行用下面的代码替换
$condition[‘id‘]=1; $condition[‘user‘]="蜡笔小新"; var_dump($user->where($condition)->select());
这时使用调试工具在浏览器中看到的是:
这时使用where默认的是ADN,如果想换成OR的话,再加上一条语句即可:
$condition[‘_logic‘]=‘or‘;
三、使用对象查询
同样将 var_dump($user->where(‘id=1‘)->select()); 用下列代码替换:
$condition = new stdClass(); $condition->id=1; $condition->user = ‘蜡笔小新‘;
PS:stdClass 类是 PHP 内置的类,可以理解为一个空类,在这里可以理解为把条件的
字段作为成员保存到 stdClass 类里。而这里的‘‘是将命名空间设置为根目录,否则会导
致当前目录找不到此类。使用对象和数组查询,效果是一样的,可以互换。在大多数情况下,
ThinkPHP 推荐使用数组形式更加高效。
下面介绍表达式查询
对于那些要实现模糊判断的查询,比如大于、等于、小于之类的SQL查询,可以使用表达式查询方式。
查询表达式格式:$map[‘字段名‘] = array(‘表达式‘,‘查询条件‘);
表达式查询
表达式 | 含义 |
EQ | 等于(=) |
NEQ | 不等于(<>) |
GT | 大于(>) |
EGT | 大于等于(>=) |
LT | 小于(<) |
ELT | 小于等于(<=) |
[NOT]LIKE | 模糊查询 |
[NOT] BETWEEN | (不在)区间查询 |
[NOT] IN | (不在)IN查询 |
EXP | 表达式查询,支持SQL语法 |
在 Home/controller/UserController.class.php 中插入以下代码进行查询:
$user = M(‘User‘); $map[‘id‘] = array(‘eq‘,1); var_dump($user->where($map)->select());
查询id=1的数据;
从EQ到ELT的只需要改变array(‘eq‘,1)中的eq就行,
这是like 模糊查询的方式:
$map[‘user‘] = array(‘like‘,‘%小%‘); 查询用户名中带有“小”的数据,
$map[‘user‘] = array(‘notlike‘,‘%小%‘); 查询用户名中不带有“小”的数据,
$map[‘user‘] = array(‘like‘, array(‘%小%‘, ‘%蜡%‘), ‘AND‘); 查询用户名中带有“小”和"腊"的数据,这时后面加了AND,如果不加的话,默认的就是OR.
下面是between的用法:
$map[‘id‘] = array(‘between‘,‘1,3‘); 查询‘id‘在1到3之间的数据,
$map[‘id‘] = array(‘between‘,array(‘1‘,‘3‘)); 和上一句作用相同,
$map[‘id‘] = array(‘not between‘,‘1,3‘); 查询除了‘id‘不等于1到3之间的数据,这时not和between之间用空格,之前的notlike之间没空格
下面是in的用法:
$map[‘id‘] = array(‘in‘,‘1,2,4‘); 查询id为1,2,4的数据;
$map[‘id‘] = array(‘not in‘,‘1,2,4‘); 查询id不等于1,2,3的数据,且这时not和in之间也是有空格
EXP:自定义: (PS:使用 exp 自定义在第二个参数直接写 where 语句即可)
$map[‘id‘]=array(‘exp‘,‘=1‘); 查询id等于1的数据
$map[‘id‘] = array(‘exp‘,‘in (1,2,4)‘); 查询id为1,2,4的数据;
$map[‘id‘] = array(‘exp‘, ‘=1‘); $map[‘user‘] = array(‘exp‘, ‘="蜡笔小新"‘); $map[‘_logic‘] = ‘OR‘; //WHERE 为( (`id` =1) ) OR ( (`user` ="蜡笔小新") )
SQL查询语句
标签:
热心网友 时间:2022-04-07 17:53
SQL查询就是用的select相关的语句,根据不用的需求,设置关键属性值和查询区间即可完成一条查询语句
追问那个题目怎么打热心网友 时间:2022-04-07 19:11
SQL结构化查询字符串的改写,是实现数据库查询性能提升的最现实、最有效的手段,有时甚至是唯一的手段,比如在不允许大幅度修改现有数据库结构的情况下。
书写风格
1. 语句关键字应全部使用小写。
2. 引用字符时应使用单引号。如:update testable set idcol=’abcd’。
3. 连接符或运算符or、in、and、=、<=、>=, +,- 等前后宜加上一个空格。否则容易导致以下类似问题。例如在语句select a–b from table中,a,b均为变量,拼写该语句时,如果a = 6,b = -3,则语句变为select 6--3 from table。--被视为SQL的注释,结果语句报错。
4. 不得使用“select * from …”语法,必须标明字段名。即select col1, col2,… from tablea where …
5. 严禁使用“insert into table_name values (?,?,……)”语法,统一使用“insert into table_name (col1,col2,……) values (?,?,…...)”。
6. SQL语句包含多表连接时,必须加上表的别名,对每个字段的使用都要带上表别名。
select a.col1, a.col2, b.col3 from tablea a, tableb b where a.col4=b.col5
7. 应避免显式或隐含的类型转换。例如在where子句中numeric型和int型的列的比较。
8. 在子查询中前后必须加上括号。
select col1, col2 from tablea where col3 in ( select col4 from tableb where col4>0)
9. 执行SQL时一次应只执行一条,如果多条语句则应分开执行,但必须保持在一个事务中。不得一次执行通过分号等分开的多条语句,这样处理不清晰。
10. 如果能采用or代替,则不宜使用in 语句。in语句中的元素不得超过500个,如果超过,则应拆分为多条SQL语句。严禁使用xx in(‘’,’’….) or xx in(‘’,’’,’’)。
11. or连接条件不得超过 500,超过时应拆分为多条语句。
性能优化
1. 查询时应尽量减少多余数据的读取,通过使用where子句来减少返回的记录数。
2. 如果在语句中有not in(in)操作,应尽量用not exists(exists)来代替。特别对大数据量的两者检索速度有很明显的区别。
3. 不宜使用外连接。外连接效率低。
4. 一条SQL语句中不宜使用3层以上的嵌套查询。如果超过,则应在Java等应用服务器程序中处理。
5. 一条SQL语句中不得从4个及以上表中同时取数。仅作关联或过滤条件而不涉及取数的表不参与表个数计算;如果必须关联4个或4个以上表,应在Java等应用服务器程序中处理。
6. 应尽量避免使用order by和group by排序操作,如必须使用排序操作,尽量建立在有索引的列上。因为大量的排序操作影响系统性能。
7. 对索引列的比较,应尽量避免使用not 或 !=,可拆分为几个条件。因为“not”和“!=”不会使用索引。如col1 是索引列,条件col1 !=0 可以拆分为col1 >0 or col2 <0。
8. 应尽量将数据库函数、计算表达式写在逻辑操作符右边。因为这些对列的操作会将导致表扫描,影响性能。
9. 在where子句中,如果有多个过滤条件,应将索引列或过滤记录数最多的条件放在前面。
10. 能用连接方式实现的功能,不得用子查询。例如:select name from customer where customerId in ( select customerId from order where money > 1000)。 应该用如下语句代替:select name from customer inner join order on customer.customerId = order.customerId where order.money > 100。或 select name from customer where exists ( select 1 from order where money > 1000 and customer.customerId = order.customerId) <这里需要注意:使用exists的效率依赖于匹配度,inner join效率比较稳定>
11. 多表关联查询时,写法可遵循以下原则,这样做有利于建立索引,提高查询效率。格式如下:select sum (t1.je) from table1 t1, table2 t2, table3 t3 where (t1的等值条件(=)) and (t1的非等值条件) and (t2与t1的关联条件) and (t2的等值条件) and (t2的非等值条件) and (t3与t2的关联条件) and (t3的等值条件) and (t3的非等值条件)。
跨数据库支持
1. 对于跨数据库Java应用程序的VO映射数据库的数据格式建议:
1) 整型字段:字段设置保存为Integer或者Long
2) 数字型字段:若需要使用小数2位以上的精确计算,读取、插入、更新使用BigDecimal类型
3) 字符型字段:读取为String,并保存为String,插入或者更新为String 4) 时间字段:读取为String,插入或者更新时的时间格式使用中间件统一处理。
2. 字符串连接应使用“||”符号,而不应使用“+”。“+”是SQLServer语法,Oracle和DB2支持“||”,Hibernate转化为SQLServer时,会自动将“||”转为“+”。
3. 通配符不能使用‘[a-c]%’这种形式。应写成如:
select col1, col2 from table_name where col1 like ‘[a]%’ OR col1 like ‘[b]%’ OR col1 like ‘[c]%’
4. 截取字符串长度函数应使用substr,起始位置为1表示从头开始。因为db2中substr起点为1,0会报错;在SqlServer数据库中使用的是substring需要进行转换。
5. 不得通过select percent n和select top n*查询结果集的记录数。
6. join 与on 必须严格匹配,严禁出现没有on的join。
7. join…on 后面不宜使用or,如果使用则需将or的范围用( )括起来。
8. 不得使用select into 的格式。Select into是SQL Server特有语法,因为Oracle和DB2不支持。
9. 应将Null值与空字符串(长度为零的字符串)视为不同。虽然Oracle视Null与空字符串为相同,但DB2和SQL Server却视为不同。
原文来自:https://www.linuxidc.com/Linux/2019-11/161557.htm
本文地址:https://www.linuxprobe.com/sql-command.html
Linux命令大全:https://www.linuxcool.com/