数据库一些常用的SQL语句
1.多表连接查询:
假设现在有三个表,One,Two,Three;
One表字段:Code(主键),Name
Two表字段:Birthday,T_code(One表Code的外键)
Three表字段:Sex,Age,Th_bir(Two表Birthday外键)
(1)查询Code,Name,Birthday,Sex,Age:
select One.Code,Name,Two.Birthday,Three.Sex,Age from Two join One on One.Code=Two.T_code
join Three on Two.Birthday=Three.Th_bir
多表连接查询时将与所有表有主外键关系的表当做查找的表,join关联的表,on 关联的字段,如上面的例子,如果以Two表数据为主,过滤其他表中多余的数据,
可以用Left join ,以左边主要查询的表为主,如果要以后面的表的数据为主,可以用right join
(2)过滤掉重复的条件distinct:
distinct:可以自动过滤到多余的条件,此方法仅用于去重复,可以用作单独条件查询,普通全表查询慎用,他会将表中所有有重复的数据过滤掉,以免造成查询数据不完整
用法:select distinct 查询的字段 from 表格
(3)数据转换,如果Three表中Sex字段存的是0和1,现在查询这个表,将0显示男,1显示女,case when then end查询方式
用法1:select Age,case Sex when 0 then '男' when 1 then '女' end as Sex from Three
用法2:select Age,case when Sex=0 then '男' when Sex=1 then '女' end as Sex from Three
case 后面是要转换的字段,when后面是这个字段在数据库所存的信息,满足when的条件就执行then,将要改为的数据放在then后面,多条件最后条件也可以用else,
最后end结束,as是转换这个字段查询出来的显示,也就是用这个方法查完数据Sex列名将显示一长串字符,as可以转换为自己定义的,一般还是转换为原字段名称,以免在
开发程序操作数据库时出错
2.截取字符串
如果在开发中遇到需要操作一个字段,只需要这个字段数据的一部分,而不是全部,可以用字符串截取方式(substr(字段名,从哪一位截取,到哪一位))
例:现在有一个人员信息表(Information),其中一列(birth)存的是出生年月xxxx-xx-xx的形式,现在要查找出生年份是1993年的所有用户信息
select substr(birth,0,4) from Information,这是将所有的信息年份截取出来,显示出生年月这一列的所有年份
select * from Information where substr(birth,0,4) ='1993' 这是查询年份为1993的所有人员信息
同理,修改也可以用这个作条件,将所有5月份生日的人的性别(sex)改为先生:
Update Information set sex='先生' where substr(birth,6,7)='05'
删除也可以,将所有1992年6月份生日的人删除:delete from Information where substr(birth,0,7)='1992-06'
数据库一些常用的SQL语句的更多相关文章
- 面试、笔试中常用的SQL语句(数据库知识必杀)一共50个!!!
Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cname,T#) 课程表 SC(S#,C#,score) 成绩表 Teacher(T#,Tname) 教师表 ...
- Oracle数据库常用的Sql语句整理
Oracle数据库常用的Sql语句整理 查看当前用户的缺省表空间 : select username,default_tablespace from user_users; 2.查看用户下所有的表 : ...
- MySQL 常用的sql语句小结(待续)
mysql 常用的sql语句 1.查看数据库各个表中的记录数 USE information_schema; SELECT table_name,table_rows FROM tables WHER ...
- 经典SQL语句大全以及50个常用的sql语句
经典SQL语句大全 一.基础 1.说明:创建数据库CREATE DATABASE database-name 2.说明:删除数据库drop database dbname3.说明:备份sql serv ...
- SQL之50个常用的SQL语句
50个常用的sql语句 Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cname,T#) 课程表 SC(S#,C#,score) 成绩表 Teacher(T#,T ...
- 第五篇、常用的SQL语句和函数介绍
简介: 在使用到sqlite3的时候,常常需要写一些SQL语句,现将常用到的部分语句稍微总结以下,由于个人习惯,关键字用大写. 附: /*简单约束*/ CREATE TABLE IF NOT EXIS ...
- MySQL的一些常用的SQL语句整理
安装MySQL有两种的方式,一种是解压版本,但是需要配置环境变量,相对而言比较麻烦.所以我们一般采取第二种方式,那就是到MySQL的官网上下载安装版.这样就会省去很多麻烦,在这里我就不再详细的介绍具体 ...
- 50个常用的sql语句
50个常用的sql语句 Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cname,T#) 课程表 SC(S#,C#,score) 成绩表 Teacher(T#,T ...
- 常用经典SQL语句大全完整版--详解+实例 (存)
常用经典SQL语句大全完整版--详解+实例 转 傻豆儿的博客 http://blog.sina.com.cn/shadou2012 http://blog.sina.com.cn/s/blog_84 ...
随机推荐
- innodb的锁
观察innodb的锁时间,需要关注: mysqladmin extended-status -r -i 1 -uroot | grep "Innodb_row_lock_time" ...
- selenium + phantomjs 爬取落网音乐
题记: 作为一个业余程序猿,最大的爱好就是电影和音乐了,听音乐当然要来点有档次的.落网的音乐的逼格有点高,一听听了10年.学习python一久了,于是想用python技术把落网的音乐爬下来随便听. 目 ...
- JavaScript的学习5
一.DOM对象 1.DOM对象:Document Object Model 文档对象模型,主要是用来提供了操作HTML文档的属性与方法 2.DOM的分类: a.核心DOM:为操作XML和HTML ...
- Linux下搭建SVN服务器及自动更新项目文件到web目录(www)的方法
首先搭建SVN服务器 1,安装SVN服务端 直接用apt-get或yum安装subversion即可(当然也可以自己去官方下载安装) sudo apt-get install subversion ...
- [REP]AWS Regions and Availability Zones: the simplest explanation you will ever find around
When it comes to Amazon Web Services, there are two concepts that are extremely important and spanni ...
- windows 服务
一.创建一个Windows Service1)创建Windows Service项目 2)对Service重命名将Service1重命名为你服务名称,这里我们命名为ServiceTest. 二.创建服 ...
- xfce4 启用回收站
Userspace virtual filesystem implemented as a pluggable module for gio # pacman -S gvfs
- C++与零值比较
1.布尔值与零值的比较 if(flag)//if为真 if(!flag)//if为假 其它都为不良风格: if (flag == TRUE) ) if (flag == FALSE) ) 2.整形值与 ...
- extentreports报告插件之extentX之服务搭建(三)
之前两个章节已经写完再extentreports报告插件与testng 的集成,但是发现 每次测试完后,生成的报告都要在单独发送,每个项目都有一份报告,如果项目多的话,管理起来就会很冗余. 这个给大家 ...
- 在Mac上配置adb命令
在Mac上配置adb命令 在Mac OS中使用adb命令时,应进行变量配置,步骤如下: 一.终端中输入 cd ~ 二.输入touch .bash_profile 回车 touch:如果没有,则创建文件 ...