1、创建测试表,
create table test_cols(id varchar2(20),remark varchar2(20),ex_filed1 varchar2(20),ex_filed2 varchar2(20))
2、编写sql,查看系统视图,可以看到该用户下所有表的字段信息,select * from user_tab_cols;
3、编写sql,查询刚创建的表,字段信息,select * from user_tab_cols t where table_name = 'TEST_COLS'
4、编写sql,查询该表的字段数,这样对于字段较多的表,结果更明显
select count(distinct column_name) from user_tab_cols t where table_name = 'TEST_COLS'
注意点
select 指定表.字段 from 表1,表2
四则运算包括加减乘除
select 字段1 四则运行符号 字段2 from 表名称
语法:select 函数(字段1) from 表名称
统计函数
binary
区分大小写
语法:select 段落 from 表明 where binary 字段....................................
分组
语法
select....from 表名
where .......
group by 字段名称 #如果这里有多个字段,A,B,用,连接表示具有相同字段A以及相同字段B进行分组
having 判断内容
注意 :
排序
语法:默认为升序
ord by 字段名称
固定升序或者降序
多个条件排序主次关系
ord by 主字段,次字段
限制显示记录
对于单页表 *** 作
limit start count
对于多页 *** 作
分页原理:先查询总数据条数 设为a
确定每页数量b
总页数为c = a / b 如果除不尽则需要加1 例如 10 / 3 正确页数为4
查询语句的起始位置为s = 当前页数d 减去1 乘以每页数量
即 s = (d - 1) * b
limit s b
语法 :where 字段名称 regexp '正则表达式'
注意:正则表达式不包括特殊字符如\w
语法:select *from 表1,表2
他会把多个表每行与另外个表统统匹配上,其中会有一些脏数据,我们可以用里面值的关系进行连接
其本质就是笛卡尔积查询
区别是把,变成 join
且不能用where,要先用on根据里面值的关系拼接好了再用 where
左表中记录的无论是否有匹配关系都全部显示,右表中仅显示匹配成功的记录
语法:select *from 表1 left join,表2
右表中记录的无论是否有匹配关系都全部显示,左表中仅显示匹配成功的记录
语法:select *from 表1 right join 表2
无论是否匹配成功,两边表中的记录都要全部显示
select *from 表1 full join 表2
注意:mysql 不支持
我们要引入union
union 只能用于字段数量相同的两个表 会自动去除重复的记录
union all 则保留所有记录
select from dept left join emp on dept.id=emp.dept_id
union
select from dept right join emp on dept.id=emp.dept_id
可以完成全外连接
在三表以及三表以上查询的时候,表1 join 表2 join 表三,其意思是表1与表2连接后的表再与表3进行连接
如果三表连接时候没有用join而是用 , 进行连接表示同时查询3个表
将查找后的内容作为查找的值或者查找的对象,
如果要作为一个表当作查找对象,要对于查找后的表进行重命名语法如下
select .... from (select ....from .......) as 新名字
xists 后跟子查询 子查询有结果是为True 没有结果时为False
为true时外层执行 为false外层不执行
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)