sql查询语句?

作者&投稿:爱新觉罗胀 (若有异议请与网页底部的电邮联系)
怎么用sql语句查询?~

一、用连接查询:SELECT * FROM Student INNER JOIN ScoreON Cno=2 AND Grade>=90 二、用子查询:SELECT * FROM Student WHERE Sno IN(SELECT Sno FROM Score WHERE Cno=2 AND Grade>90)
sql语句:
结构化查询语言(Structured Query Language)简称SQL,结构化查询语言是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;
sql 语句就是对数据库进行操作的一种语言。

/*SQL是3个表的查询,会给出表以及3个表之间的约束关系Student 表 No编号 Name 姓名 Birthday 生日 bj 班级 jg 籍贯 adds地址 number电话Course 表 Kcbh课程编号 kcmc课程名称Source 表 Cjguid (主键) No 编号 kcbh 课程编号 cj成绩*/-- (1)查询学生籍贯为‘湖北’生日为1995-10-3的所有信息select *from Studentwhere 1=1and jg = '湖北' -- 籍贯为‘湖北’and Birthday = '1995-10-3' -- 生日为1995-10-3-- (2)查询学生姓名为‘王华’的各课程的平均分,最高分,最低分,总分。select avg(kcbh) as 平均分, max(kcbh) as 最高分, min(kcbh) as 最低分, sum(kcbh) as 总分from Sourcewhere 1=1and exists (select 1 from Student. where 1=1 and Student.No = Source.No Name = '王华' -- 姓名为‘王华’ )-- (3)没有太看题,大致是要求查询4,5列以上的信息,其中3个表各包含一些信息select Student.Name as 学生, Course.kcmc as 课程, Source.cj as 成绩from Student, Course, Source,where 1=1and Student.No = Source.Noand Course.Kcbh = Source.kcbh

SQL查询就是用的select相关的语句,根据不用的需求,设置关键属性值和查询区间即可完成一条查询语句



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/


sql数据库查询语句例子
各位同学们好,我们今天继续来说,sql数据库。我们今天的文档中主要介绍了SQL查询语句、查询语句示例等。这里我给大家做了一个总结,有需要的同学可以参考一下。首先,我们来了解一下SQL数据库组成基本:查找Movies表里的Title字段:查找ID小于5的电影的Title和Director的以下这些:查看电影的总条数 以下...

SQL问题:编写查询语句
) >= 2);注: 如果数据库是 SQL Server, 那么用 LEN 替换掉上面的 LENGTH 为数据表tbl_student的stuBirthday字段添加检查约束,约束名为CK_Birthday,要求该字段>=`1990-1-1`。ALTER TABLE tbl_student ADD CONSTRAINT CK_Birthday CHECK ( stuBirthday >= '1990-1-1' );

怎样从简单数据库用sql语句查询数据
查询是SQL语言的核心,SQL语言只提供唯一一个用于数据库查询的语句,即SELECT语句。用于表达SQL查询的SELECT语句是功能最强也是最复杂的SQL语句,它提供了很多选项和使用方法。SELECT语句的命令格式如下:SELECT查询语句是由七个子句构成,其中SELECT和FROM子句是一个完整SELECT查询语句必须要有的,其它的子句...

SQL语句where多条件查询怎么写?
工具\/材料:以Management Studio为例。1、首先在桌面上,点击“Management Studio”图标。2、然后在该界面中,点击右上角“新建查询”选项。3、之后在该界面中,输入where多条件查询的SQL语句“selec t * from rss where grade >90 and No=20”。4、接着在该界面中,点击“执行”按钮。5、最后在该...

sql查询 更新语句怎么写
1、首先需要打开sql server 数据库。2、点击新建查询按钮,进入sql 执行界面。3、编写sql 更新语句,update tablename set name='更新' ,点击执行按钮。4、使用查询语句,检查是否更新成功,select * from tablename。5、上面的语句是对数据库进行批量更新,如果更新指定的信息可以在update 语句后面加...

mysql多表查询sql语句怎么写?
在使用UNION或ALL关键字将多个表合并输出时,查询结果必须具有相同的结构并且数据类型必须兼容,另外使用UNION时两张表的字段数量也必须相同,否则会提示SQL语句有错误。e.x:SELECT id,name,pwd FROM tb_demo067 UNION SELECT uid,price,date FROM tb_demo067_tel四简单嵌套查询子查询:子查询是一个SELECT查询,返回...

SQL有哪些语句
结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作。它不要求用户指定对数据的存放方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统, 可以使用相同的结构化查询语言作为数据输入与管理的接口。结构化查询语言语句可以嵌套,这使它具有极大的灵活性和...

SQL的一些查询语句
--1、列出订单明细表中订单ID列表,要求去掉所有重复值。SELECT DISTINCT 订单ID FROM 订单明细 --2、列出产品的最高库存量、最低库存量和平均库存量 SELECT MAX(库存量) 最高库存量,MIN(库存量) 最低库存量,AVG(库存量) 平均库存量 FROM 产品 --3、统计订单数量。SELECT COUNT(*) 订单数量 ...

标准SQL嵌套查询语句
1、简单子查询 select name,age from person where age > (select age from person where name = '百度')2、in嵌套查询 select name from person where countryid in (select countryid from country where countryname = '百度')

sql语句的增删改查
下面教大家sql增删改查语句怎么写,操作方法如下。1、首先在电脑中打开navicat,点击新建查询。2、然后在打开的软件中,写出insert语句增加数据。3、接着用delete语句删除数据。4、最后写出update语句对数据进行修改,用select语句对数据进行查询,这样就完成了。

确山县19290554046: sql查询语句大全 -
镇录盐酸: 一、基础1、说明:创建数据库 Create DATABASE database-name 2、说明:删除数据库 drop database dbname 3、说明:备份sql server --- 创建 备份数据的 device USE master EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7...

确山县19290554046: SQL查询语句有哪些? -
镇录盐酸: 查询语句只有一种SELECT ... FROM WHERE ... (GROUP BY ... ORDER BY ...) 只是根据想要的结果不一样,而查询的内容会稍有修改. 比如FROM的表名,可以不是一张表,而是一个SELECT查询的结果作为一张表. 同样,查询统计分组汇总...

确山县19290554046: sql简单查询语句 -
镇录盐酸: ......为点分真不容易 1 select * from StuInfo 2 select 考号,姓名,语文,数学,英语 from StuMarks 3 select s1.考号,s1.姓名,s1.性别,s2.计算机基础,s2.SQL数据库from StuInfo s1left join StuMarks s2 on s1.学号=s2.学号where 专业名!='...

确山县19290554046: SQL的查询语句是什么? -
镇录盐酸: 这要运用SQL的联结查询,使用select 字段名 from 表名 where 条件 (select 字段名(注意:此字段要和前面的字段一样)from 表名(另一个表)where 条件)

确山县19290554046: sql所有查询的语句 -
镇录盐酸: 下面内容供你参考 1.查看所有用户: select * from dba_users; select * from all_users; select * from user_users;2.查看用户或角色系统权限(直接赋值给用户或角色的系统权限): select * from dba_sys_privs; select * from user_sys_privs; 3.查看角...

确山县19290554046: sql查询语句如何写 -
镇录盐酸: 我的写法是oracle的,如果是其他数据库,自己调整(比如mysql的必须有别名等等) 两个办法 (1)编号和还款日期合并求最大值,然后再查询一次. select * from table where 编号||还款记录 in (select 编号||max(还款记录) 合并记录 from table group by 编号) (2)开窗函数,按照还款日期排序,然后求最大的那个. select 编号,还款日期,金额 from (select rank()over(group by 编号 order by 还款日期 desc) 倒序,编号,还款记录,金额 from table) where 倒序=1

确山县19290554046: sql查询语句 -
镇录盐酸: SELECTteacherId AS [教师编号],class AS [课程],SUM(1) AS [数量],CONVERT(NUMERIC(18,4),SUM(CASE WHEN score>=60 THEN 1 ELSE 0 END)/CAST(SUM(1) AS FLOAT)*100) AS [及格率] FROM @tb GROUP BY teacherId,class --执...

确山县19290554046: SQL数据库查询语句
镇录盐酸: 一、 简单查询 简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句.它们分别说明所查询列、查询的表或视图、以及搜索条件等. 例如,下面的语句查询testtable表中姓名为“张三”的nickname字段和email字段. SELECT ...

确山县19290554046: SQL 查询语句
镇录盐酸: select * from table

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网