【SQL】单个表的查询】的更多相关文章

SQL多表连接查询 本文主要列举两张和三张表来讲述多表连接查询. 新建两张表: 表1:student  截图如下: 表2:course  截图如下: (此时这样建表只是为了演示连接SQL语句,当然实际开发中不会这样建表,实际开发中这两个表会有自己不同的主键.) 一.外连接 外连接可分为:左连接.右连接.完全外连接. 1.左连接  left join 或 left outer join SQL语句:select * from student left join course on student.…
  图解SQL多表关联查询     网上看了篇文章关于多表连接的,感觉很好,记录下来,以便日后自己学习  内连接     左连接     右连接       全外连接   1. 查两表关联列相等的数据用内连接.2. Col_L是Col_R的子集时用右外连接.3. Col_R是Col_L的子集时用左外连接.4. Col_R和Col_L彼此有交集但彼此互不为子集时候用全外.5. 求差操作的时候用联合查询.   1.内连接(自然连接): 只有两个表相匹配的行才能在结果集中出现 2.外连接: 包括 (1…
避免SQL全表模糊查询查询   1.模糊查询效率很低: 原因:like本身效率就比较低,应该尽量避免查询条件使用like:对于like %...%(全模糊)这样的条件,是无法使用索引的,全表扫描自然效率很低:另外,由于匹配算法的关系,模糊查询的字段长度越大,模糊查询效率越低. 解决办法:首先       1.模糊查询效率很低: 原因:like本身效率就比较低,应该尽量避免查询条件使用like:对于like ‘%...%’(全模糊)这样的条件,是无法使用索引的,全表扫描自然效率很低:另外,由于匹配…
转载博客:joeleo博客(http://www.xker.com/page/e2012/0708/117368.html) 本文主要列举两张和三张表来讲述多表连接查询. 新建两张表: 表1:student  截图如下: 表2:course  截图如下: (此时这样建表只是为了演示连接SQL语句,当然实际开发中我们不会这样建表,实际开发中这两个表会有自己不同的主键.) 一.外连接 外连接可分为:左连接.右连接.完全外连接. 1.左连接  left join 或 left outer join S…
现有两表A(大).B(小)作关联查询,SQL语句如下: SQL1:select * from A,B where A.id = B.id SQL2:select * from A,B where B.id = A.id 在写SQL的时候可能这个顺序都是随便写的,当然SQL1和SQL2 执行的结果是完全相同的,那效率是否也一样呢,答案是否定的.SQL1 相当于将A表的id取出来,然后遍历B表进行查询,SQL2相当于将B表的id取出来,然后遍历A表进行查询.如果表A的记录条数为m,表B的记录条数为n…
有时候在sql遇到一次查询多张表的全部数据例如:创建一张虚拟表A ,表A中需要有表B和表C的全部数据(表B和表C并集,如图) 有两种方法一种是使用: 1):union,不过这种查询速度比较慢 /* B.C 公共部分 */ SELECT * FROM B JOIN C ON B.x = C.x UNION /*B独有部分*/ SELECT * FROM B WHERE B.x NOT IN (SELECT * FROM B JOIN C ON B.x = C.x) UNION /*C独有部分*/…
http://www.xker.com/page/e2012/0708/117368.html select * from student,course where student.ID=course.ID 其实是内连接. 本文主要列举两张和三张表来讲述多表连接查询. 新建两张表: 表1:student  截图如下: 表2:course  截图如下: (此时这样建表只是为了演示连接SQL语句,当然实际开发中我们不会这样建表,实际开发中这两个表会有自己不同的主键.) 一.外连接 外连接可分为:左连…
本文主要列举两张和三张表来讲述多表连接查询. 新建两张表: 表1:student  截图例如以下: 表2:course  截图例如以下: (此时这样建表仅仅是为了演示连接SQL语句.当然实际开发中我们不会这样建表,实际开发中这两个表会有自己不同的主键.) 一.外连接 外连接可分为:左连接.右连接.全然外连接. 1.左连接  left join 或 left outer join SQL语句:select * from student left join course on student.ID=…
两表合并查询,并同时展示及分页SELECT a.* FROM ( ( SELECT punycode, `domain`, 'Success' AS state, add_time, AS refund_status, icp, icp_state, AS order_id FROM exp_dnbiz_user_domains WHERE AND punycode = 'shang.com' ) UNION ALL ( SELECT punycode, `domain`, state, add…
一.查看所有表的行数select a.name as '表名',b.rows as '表数据行数'from sysobjects a inner join sysindexes bon a.id = b.idwhere a.type = 'u'and b.indid in (0,1)--and a.name not like 't%'order by b.rows desc 二.sql查看表名以及所占用空间信息if exists(select 1 from tempdb..sysobjects…
废话不说,直接建表 1.表Player USE T4st -- 设置当前数据库为T4st,以便访问sysobjects IF EXISTS(SELECT * FROM sysobjects WHERE name='Player') DROP TABLE Player CREATE TABLE Player ( Code ) PRIMARY KEY NOT NULL, Name ), ) ','赵甲'); ','钱乙'); ','孙丙'); ','李丁'); ','周戊'); ','吴已'); '…
看到一本好书:名字叫做<数据库系统基础教程> 第三版 岳丽华等译 讲得很清楚,也不啰嗦. 这里是书中第六章的部分笔记: 一.常见用法:  1. AS 定义别名 可省略 2. 可以用加减乘除等表达式 3. 可以用常量 例 ; SELECT year time FROM movies; 二. 模式匹配  LIKE %: 匹配任何长度的字符(包括0个) _ : 匹配任何1个字符 单引号:  ''   连写两个 转义字符:用 ESCAPE指定特定字符为转义字符  SQL中没有声明特别的转义字符,需要我…
sql 查询 distinc用法 distinct 和group by都需要排序,一样的结果集从执行计划的成本代价来看差距不大,但group by 还涉及到统计,所以应该需要准备工作.所以单纯从等价结果来说,选择distinct比较效率一些. 其实二者没有什么可比性,但是对于不包含聚集函数的GROUP BY操作来说,和DISTINCT操作是等价的.不过虽然二者的结果是一样的,但是二者的执行计划并不相同. 在Oracle9i中: SQL> SELECT * FROM V$VERSION; BANN…
1.平时分页查询都比较多针对一个表的数据 而这个分页查询是针对连表查询的 ,这也是我网上改版别人的sql语句 先在数据库新建一个存储过程 拷贝以下代码 CREATE PROCEDURE [dbo].[usp_PageLF] (@tblName varchar(255), -- 表名@tblName1 VARCHAR(255),--表名 连表字符串 @strGetFields varchar(1000) = '*', -- 需要返回的列@strGetFields1 varchar(1000) =…
sql 同时查询多个表 可以使用连表查询比如使用join sql 同时查询多个表 可以使用连表查询 比如 使用join select s1.*,s2.* from s1 left join s2 on s1.id = s2.id; 利用where and select s1.* ,s2.* from s1,s2 where s1.id = s2.id; 建议根据条件选择 第二条sql优于第一条 其次还可以 使用union select * from A union select * from B…
mysql数据库表及数据准备语句: USE test; DROP TABLE IF EXISTS `teacher_table`; DROP TABLE IF EXISTS `student_table`; CREATE TABLE `teacher_table` ( `id` ) NOT NULL AUTO_INCREMENT, `tName` ) NOT NULL DEFAULT '老师名字', PRIMARY KEY (`id`) ) ENGINE = INNODB DEFAULT CHA…
1.模糊查询效率很低: 原因:like本身效率就比较低,应该尽量避免查询条件使用like:对于like %...%(全模糊)这样的条件,是无法使用索引的,全表扫描自然效率很低:另外,由于匹配算法的关系,模糊查询的字段长度越大,模糊查询效率越低. 解决办法:首先       1.模糊查询效率很低: 原因:like本身效率就比较低,应该尽量避免查询条件使用like:对于like ‘%...%’(全模糊)这样的条件,是无法使用索引的,全表扫描自然效率很低:另外,由于匹配算法的关系,模糊查询的字段长度越…
通过连接运算符可以实现多个表查询.连接是关系数据库模型的主要特点,也是它区别于其它类型数据库管理系统的一个标志. 在关系数 据库管理系统中,表建立时各数据之间的关系不必确定,常把一个实体的所有信息存放在一个表中.当检索数据时,通过连接操作查询出存放在多个表中的不同实体 的信息.连接操作给用户带来很大的灵活性,他们可以在任何时候增加新的数据类型.为不同实体创建新的表,尔后通过连接进行查询. 连接可以在SELECT 语句的FROM子句或WHERE子句中建立,似是而非在FROM子句中指出连接时有助于将…
create database xue1 go --创建数据库 use xue1 go --引用数据库 create table xinxi ( code int, name ), xuehao ), brithday ), ) --创建信息表 ,,) ,,) ,,) ,,) ,,) ,,)--输入信息 --查询所有信息 select * from student --查询学号为6的人的所有信息 --查询学号为8的人的姓名 --查询所有人的姓名 select name from student…
SELECT表名=case when a.colorder=1 then d.name else '' end,--表说明=case when a.colorder=1 then isnull(f.value,'') else '' end,--字段序号=a.colorder,字段名=a.name,标识=case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then '√'else '' end,主键=case when exists(SEL…
    在创建关系型数据表时,根据数据库范式的要求,为了降低数据的冗余,提供数据维护的灵活性 将数据分成多个表进行存储,实际工作当中,需要多个表的信息,需要将多个表合并显示   --内连接 select e.empno as 员工编号, e.ename as 员工名称, d.dname as 部门 from emp e inner join dept d on e.deptno=d.deptno; --左外连接 ,'EAST','SALESMAN'); select e.empno,e.enam…
关键字:FULL JOIN 只要其中某个表存在匹配,FULL JOIN 关键字就会返回行. select a.createtime, ISNULL(lp, 0) lp , ISNULL(hp, 0) hp from ( select convert(nvarchar(10),cCreateTime,23) as createtime,count(iTotalAmount) as lp from vat_inv_standard where iCharacter = 0 and iStatus =…
连接查询:     交叉连接:   交叉连接返回的结果是被连接的两个表中所有数据行的笛卡尔积,也就是返回第一个表中符合查询条件的数据航数乘以第二个表中符合,查询条件的数据行数,例如department表中有4个部门,employee表中有4个员工,那么交叉连接的结果就有4 * 4 = 16条数据 SELECT * FROM 表1 CROSS JOIN 表2; SELECT * FROM 表1,表2; 从上述描述情况可以看出,交叉连接的结果就是两个表中所有数据的组合.需要注意的是,在实际开发中这种…
create database practiceSql; use practiceSql; -- create table student( `id` bigint not null auto_increment comment '主键id自增', `name` ) not null comment '学生名', `student_num` int not null comment '学号', `sex` ) not null comment '性别', `age` int not null c…
var pro = (from ps in db.ProductInfoes join pt in db.ProductTypees on ps.productType equals pt.pType orderby ps.inDate descending select new {ps.ID,ps.productName,ps.inDate,pt.typeName }).ToList(); 这句代码是指: 通过ProductInfoes.productType =productType .pT…
正式表:各字段内容获取 ) SET @tabname = 'ppeflow' SELECT @tabname AS '表名' ,(CASE ))+ ')' )) ) )) + ')' )) ) )) + ')' ELSE T.name END) AS '字段类型与容量' ,C.name as [字段名],T.name as [字段类型] ,convert(bit,C.IsNullable) as [可否为空] , FROM sysobjects where xtype='PK' and pare…
表结构: 需求 思路: 求出平均数 select avg(user_total) as avg from user_level 更新他的等级 update user_level set user_rank= xxx where user_total >= 平均数 when case 表达式: case when 表达式 then表达式 else 表达式 end select *, case user_total then '消费正好满100的用户' else '其他' end from user…
SELECT yt_fault_componentId FROM yt_fault_component a join yt_fault_assembly b on a.yt_fault_assembly=b.yt_fault_assemblyId where a.yt_code='' and b.yt_code=''…
sqlserver: update A a set a.i = b.k from B b where a.key = b.key oracle : update A a set a.i = (select b.k-b.unk from B b where a.key = b,key) where exists(select 1 from B b a.key = b.key)…
数据库中最最常用的语法----select.简单的select语法很直白: select column from table where expression: 从((from)存储数据的地方(table)按照(where)一定的条件(expression)查找(select)我要的数据(column); 但是在实际工作中用到的比较多的往往还是多联表查询,所以在这里记下自己学习多联表查询的心得. 首先聊一聊笛卡尔积,这是几乎所有数据库书籍在讲多联表查询时第一个要讲的东西,我等P民也只能是把笛卡尔…