㈠ 数据库 in 的用法
outid IN ('10002') 这样 因为这个是字符型
㈡ oracle数据库IN
有点麻烦,就是你要把你的ID重新组装一个sql,比如你的ID是:1,2,3,4,而查出来的只有1,2,3的数据,4没有数据,你可以这么做:
select * from (select 1 as id union select 2 as id union select 3 as id union select 4 as id) a where id not in
(select id a FROM VIN n where id in(1,2,3,4) group by id)
得到id:4
你那么多ID的话,建议建立一个临时表,把你的200个ID存到这个表里去,然后SQL和上面一样,把a表换成你的临时表就可以了。找到后清空或删除你的临时表(根据业务需要)
㈢ 数据库中in函数可以用什么代替
sql
aggregate
函数是什么数据库可以用
sql
拥有很多可用于计数和计算的内建函数。
[编辑本段]函数的语法
内建
sql
函数的语法是:
select
function(列)
from
表
[编辑本段]函数的类型
在
sql
中,基本的函数类型和种类有若干种。函数的基本类型是:
aggregate
函数
scalar
函数
㈣ Oracle语句中IN和=的区别有哪些
Oracle语句中IN和=的区别有:
1、首先应用范围不一样:in 可以理解为是范围内的选择;= 只有一个。例如:
select sno, sname from t1 where sno in ('sn1001','sn1002');
select sno, sname from t1 where sno in ('sn1001');
select sno, sname from t1 where sno ='sn1001';
select sno, sname from t1 where sno in (select sno from t2); --子查询结果可以不止一个结果
select sno, sname from t1 where sno =(select sno from t2); --子查询结果只能有一个。
2、其次性能也不一样;=的性能大于in的性能,因为=能较好的使用索引等。
3、in 表示在一个结合内进行查询,比如 select * from character where letter in ('A','B','C')。
=的作用就是一个值的比较。但是等号也可以实现in的效果,只是写起来比较麻烦。比如上面的例子,也可以这样写:
select * from character where letter='A' or letter='B' or letter='C'.
两个运算符都比较常用,根据具体的情况选择。
㈤ access数据库查询里in的用法和等号有什么区别
如果子查询只有1条记录,in和=是没有区别,如果子查询有多条记录,用=会出错的,所以in是无论只查询有多少条记录都可以使用,而=只有当子查询只有1条记录的时候才能使用
in和exists理解上其实是差不多,但对数据库而言,in的执行顺序是先执行只查询条件,然后把记录和外查询核对,找符合条件的,
而exists是先执行外查询,再执行子查询,找到外查询记录后和只查询对比符合条件的,
如果外查询和子查询的条目数差异很大,那么效率相差很明显的
㈥ 数据库 IN,OR,AND用法
我举例说明基本用法吧,lz如果已经有了基础而是要知道更多更深入的知识的话,不需要在知道提问,直接网络里搜索,资料大把大把的,而且不难懂。
表(stu)结构和数据如下:
id name age height
1 abby 14 134
2 amelia 13 128
3 ken 14 144
1、in
select t.* from stu t where age in (14, 15);
查询结果是1和3,没有age为15的。
2、or
select t.* from stu t where age = 13 or age = 14;
得到所有的3条,这是“或”,年龄为13岁或14岁
3、and
select t.* from stu t where age = 13 and name = 'ken';
没有结果,这是“与”的关系,检索年龄13岁,名字是ken的学生,没有符合条件的。
㈦ 数据库原理 in的用法
如有地区表t_zone有以下列(zone_id,zone_name ),想知道zone_id为217和218的zone_name。sql语句可以这么写:
select t.zone_name from t_zone t
where t.zone_id in(217,218)
也可以:
select t.zone_name from t_zone t
where t.zone_id = 217 or t.zone_id = 218
㈧ in在sql中是什么意思
select * from table where id in (1,3,5)
查询表里 id 是1 或者3 或者5 的记录
select * from table where name in ('小明','小红','小丽')
查询表里 name 等于 小明 或者小红 或者 小丽的记录
还有not in
㈨ 数据库中in、on、with的用法及示例。
in
select * from tab where field in ('A', 'B', 'C')
等价于select * from tab where field = 'A' or field = 'B' or field = 'C'
on永在表连接的时候
select * from a inner/left/right join b on a.xx = b.xx
with用法:
创建一个表:
create table regr (pid integer,id integer, name char(20))
alter table regr alter id set not null add primary key(id)
insert into regr values(-1,1,'library'),(1,2,'news'),(2,3,'world news'),(2,4,'politics'),(2,5,'bussiness')
(2,6,'science'),(2,7,'technology'),(1,8,'sports'),(8,9,'local'),(8,10,'collegiate'),(8,11,'professional')
(9,12,'soccer'),(10,13,'soccer'),(11,14,'soccer'),(9,15,'football'),(10,16,'football'),(11,17,'football'
使用with得到数据树
WITH RPL (PID, ID, name) AS
(SELECT ROOT.PID, ROOT.ID, ROOT.NameFROM regr ROOT
WHERE ROOT.PID = 8
UNION ALL
SELECT CHILD.PID, CHILD.ID, CHILD.Name
FROM RPL PARENT, regr CHILD
WHERE PARENT.ID = CHILD.PID)
SELECT DISTINCT PID, ID, Name
FROM RPL
ORDER BY PID, ID, Name
RPL 作为一个具有以下三列的虚拟表:PID、ID 和 name。
WITH 子句内的第一个 SELECT 语句是初始化表。它只执行一次。它的结果形成虚拟表的初始内容以作为递归的种子。在上面的示例中,种子是 PID 为 8 的一行或多行。
第二个 SELECT 语句执行多次。将种子作为输入(JOIN 中的辅助表)传递给第二个 SELECT 语句以产生下一个行集合。将 JOIN 的结果添加(UNION ALL)到虚拟表的当前内容中,并放回到其中以形成用于下一次传递的输入。只要有行产生,这个过程就会继续。
㈩ oracle in的用法
concat()是拼接函数,将两个字符串拼接在一起
select
concat(first_name,last_name)
from
employees
||
是字符串连接符,用与连接字符串
select
first_name||last_name
from
employees
两者很相似但也有不同的地方
||可以在字符串中间添加自定义的字符,而concat不行
如果你是要连接两个字段可以用concat()也可以用||
,用concat
可读性好
如果3个以上的连接字段就推荐||
可以根据你的需要来设置.