JAVA / MySql 编程—— 第三章 高级查询(一)
1、 修改表:
(1)修改表名语法: ALTER TABLE <旧表名> RENAME [ TO ] <新表名>; 注意:其中[TO]为可选参数,使用与否不影响结果,仅修改表名,表结构不变; |
(2)添加字段语法: ALTER TABLE 表名 ADD 字段名 数据类型 [属性]; |
(3)修改字段语法: ALTER TABLE 表名 CHANGE 原字段名 新字段名 数据类型 [属性]; 其中,”原字段名“指修改前的字段名,“ 新字段名”指修改后的字段名,“数据类型”指修改后的数据类型, 如果不需要修改数据类型,则和原数据类型保持一致,但“数据类型”不能为空。 注意:由于不同的类型的数据储存方式和长度不同,修改数据类型可能会影响数据表中已有的数据,因此,此种情况下不应轻易修改数据类型。 |
(4)删除字段语法: ALTER TABLE 表名 DROP字段名; |
Eg: DROP TABLE IF EXISTS `demo01`; #创建表 CREATE TABLE `demo01`( `id` INT(10) NOT NULL AUTO_INCREMENT PRIMARY KEY, `name` VARCHAR(8) NOT NULL ); #修改表名 ALTER TABLE `demo01` RENAME `demo02`; #添加字段 ALTER TABLE ` demo02 ` ADD `password` VARCHAR(32) NOT NULL; #修改字段 ALTERTABLE ` demo02 ` CHANGE `name` `username`CHAR(10) NOT NULL; #删除字段 ALTERTABLE ` demo02 ` DROP `password`; |
2、 添加主外键:
(1)添加主键约束语法: ALTER TABLE 表名 ADD CONSTRAINT 主键名 PRIMARY KEY 表名(主键字段); Eg:设置grade表中gradeId字段为主键 ALTER TABLE `grade` ADD CONSTRAINT `pk_grade` PRIMARY KEY `grade`(`gradeId`); |
(2)添加外键约束语法: ALTER TABLE 表名 ADD CONSTRAINT 外键名 FOREIGN KEY (外键字段) REFE RENCES 关联表名(关联字段); Eg:将student表的gradeId字段和grade表的gradeId字段建立外键关联: ALTER TABLE `student` ADD CONSTRAINT fk_student_grade FOREIGN KEY(`gradeId`) REFERENCES `grade` (`gradeId`); |
提示:在MySQL中,InnoDB储存类型的表支持外键, MyISAM储存类型的表不支持外键,因此对于MySISAM储存类型的表,也可以通过建立逻辑关联的方式保证数据的完整性和一致性, 这种关联实际上是依照设计之初就定义好的固有逻辑,按照这种固有逻辑存取数据即可,不需要在数据库层面进行“硬绑定”。 |
3、 DML(数据操作语言):
(1)插入数据记录: (A)插入单行数据记录语法: INSERT INTO 表名 [(字段名列表)] VALUES(值列表); Eg: INSERT INTO `student`(`loginPwd`,`studentName`,`gradeId`,`phone`,`bornDate`) VALUES('123','黄小平',1,'13956799999','1996-5-8'); 其中: 1.表的字段名是可选的,如果省略,则依次插入所有字段。 2.多个列表和多个值之间使用逗号分隔。 3.值列表必须和字段名列表数量相同,且数据类型相符。 4.如果插入的是表中部分数据,字段名列表必须填写。 (B)插入多行数据语法:在MySQL中INSERT语句支持一次插入多条记录,插入时可指定多个值列表,每个值列表之间逗号隔开。 INSERT INTO 新表(字段名列表)VALUES(值列表1),(值列表2),……(值列表n); 注意:插入数据时需要指定具体字段名。 Eg: INSERT INTO `subject`(`subjectNo`,`subjectName`,`classHour`,`gradeID`) VALUES(1,'Logic Java',220,1),(2,'HTML',160,1),(3,'Java OOP',230,2);
注意:为避免表结构发生变化引发的错误,建议插入数据时写明具体字段名! 插入时间类型也需要 ‘ ’ 。 |
(2)将查询结果插入到新表语法: CREATE TABLE 新表(SELECT 字段1,字段2,..........FROM 原表); 注意:新表无需事先创建,如新表已存在,将会报错! |
(3)更新数据记录语法: UPDATE 表名 SET 字段1=值,字段2=值,。。。。字段n=值[WHERE 条件]; |
(4)删除数据记录语法: DELETE FROM 表名 [WHERE 条件]; 除此之外,也可以使用TRUNCATE语句删除表中所有行。语法: TRUNCATE TABLE 表名; 注意:TRUNCATE 语句实现删除表中所有数据,删除后将重置自增列,表结构及其字段、约束、索引保持不变执行速度比DELETE语句快。 |
SQL Sever数据库与MySQL数据库把数据插入新表语法对比: |
4、数据查询:
●查询回顾:SQL Server中查询语句在MySQL中同样支持;
SQL Service中的数据查询语法: SELECT<字段名列表> FRMO<表名或视图> [WHERE <查询条件>] [GROUP BY<分组字段名>] [HAVING<条件>] [OGDER BY<排序的字段名>[ASC 或 DESC]] Eg: SELECT `studentNo`,`studentName`,`phone`,`address`,`bornDate` FROM `student` WHERE `gradeId` = 1 ORDER BY studentNo; |
|
其中: 1.字段名列表为要查询的字段名、各字段之间使用逗号分隔、若查询表中所有字段、则使用“* ”号表示。 2.FROM后的表名为要查询的数据的来源,可以单个可以多个。 3.WHERE子句为可选项,指定查询的条件。 4.GROUP BY子句表明查询出来的数据按指定字段进行分组。 5.HAVING子句用于筛选组。 6.OGDER BY子句指定按什么顺序显示查询出来的数据,什么字段的升序(ASC)或降序(DESC) |
●LIMIT子句:MySQL查询语句中使用LIMIT子句限制结果集;
SELECT <字段名列表> FROM <表名或视图> [WHERE <查询条件>] [GROUP BY <分组的字段名>] [ORDER BY <排序的列名> [ASC 或DESC]] [LIMIT [位置偏移量, ]行数]; 其中:
此参数可选,当省略是从第一条记录开始显示。 2.行数:指显示记录的条数。 |
5、常用函数:
聚合函数: AVG(); 作用:返回某字段的平均值。 COUNT(); 作用:返回某字段的行数。 MAX(); 作用:返回某字段的最大值。 MIN(); 作用:返回某字段的最小值。 SUM(); 作用:返回某字段的和。 |
数学函数: CEIL(x);作用:返回大于或等于数值 x 的最小整数。 举例:SELECT CEIL (2.3);返回:3 FLOOR(x);作用:返回小于或等于数值 x 的最大整数 举例:SELECT FLOOR(2.3);返回:2 RAND();作用:返回0~1的随机数。 举例:SELECT RAND();返回:0.59464161 |
- ●字符串函数:
CONCAT(str1,str2,...,strln);作用:链接字符串str1,str2.....strln为一个完整的字符串。 举例:SELECT CONCAT("My","S","QL"); 返回:MySQl INSERT(str,pos,len,newstr);作用:将字符串 str 从 pos 位置开始,len 个字符长的子串替换为字符串 newstr 举例:SELECT INSERT('这是SQL Server 数据库',3,10,'MySQL'); 返回:这是MySQl数据库 LOWER(str);作用:将字符串 str 中所有字符变为小写 举例:SELECT LOWER('MySQL'); 返回:mysql UPPER(str);作用:将字符串 str 中所有字符变为大写 举例:SELECT UPPER('MySQL'); 返回:MYSQL SUBSTRING(str,num,len);作用:返回字符串 str 的第num 个位置开始长度为len 的子字符串 举例:SELECT SUBSTRING('JavaMySQLOracle',5,5); 返回:MySQL |
- ●时间日期函数:
CURDATE();作用:获取当前日期 举例:SELECT CURDTE(); 返回:2016-08-08 CURTIME();作用:获取当前时间 举例:SELECT CURTIME(); 返回:19:19:26 NOW();作用:获取当前日期和时间 举例:SELECT NOW(); 返回:2016-08-08 19:19:26 WEEK(date);作用:返回日期date为一年中的第几周 举例:SELECT WEEK(NOW()); 返回:26 YEAR(date);作用:返回日期date的年份 举例:SELECT YEAR(NOW()); 返回:2016 |
HOUR(time);作用:返回时间按 time 的小时值 举例:SELECT HOUR(NOW());返回:9 MINUTE(time);作用:返回时间 time 的分钟值 举例:SELECT MINUTE(NOW()); 返回:43 DATEDIFF(date1,date2); 作用:返回日期参数 date1 和 date2 之间相隔的天数。 举例:SELECT DATEDIFF(NOW(),‘2018-8-8’);返回:2881 ADDDATE(date,n);作用:计算日期参数 date 加上 n 天后的日期。 举例:SELECT ADDDATE(NOW(),5); 返回:2016-09-02 09:37:07 |
6、子查询:以查询为查询条件的查询
Eg1:
eg: |
|
实现方法二:采用子查询实现: 1、 子查询是一个嵌套在 SELECT、INSERT、UPDATE 或 DELETE 语句或其他子查询中的查询 2、子查询在WHERE语句中的一般用法 子查询语法: SELECT .... FROM 表1 WHERE 字段1 比较运算符(子查询); 其中: 子查询语句必须放置在一对圆括号内。 比较运算符包括:>,=,<,>=,<=。 外面查询称为父查询,圆括号中嵌入的查询称为子查询。 执行时,先执行子查询,在执行父查询,返回返回值。 注意;将子查询和比较运算符联合使用,必须保证子查询返回的值不能多于一个 |
Eg2: 使用子查询替换表连接;
实现方法一:采用表连接 :内连接(等值连接) SELECT `studentName` FROM `student` stu INNER JOIN `result` r ON stu.studentNO = r.studentNo INNER JOIN `subject` sub ON r.subjectNo = sub.subjectNo WHERE `studentResult` = 60 AND `subjectName` = 'Logic Java'; |
|
实现方法二:采用子查询 SELECT `studentName` FROM `student` WHERE `studentNo` = ( SELECT `studentNo` FROM `result` INNER JOIN `Subject` ON result.subjectNo= subject.subjectNo WHERE `studentResult`=60 AND `subjectName`='Logic Java' ); 1、子查询比较灵活、方便,常作为增删改查的筛选条件,适合于操纵一个表的数据 2、表连接更适合于查看多表的数据 |
7、IN和NOT IN 子查询:
●IN子查询:使用=,>等比较运算符时,要求子查询只能返回,一条或空的记录,
在MySQL中,当子查询跟随在=、!=、<、>、>=和<=时,不允许子查询返回多条记录。
JAVA / MySql 编程—— 第三章 高级查询(一)的更多相关文章
- JAVA / MySql 编程—— 第四章 高级查询(二)
1. EXISTS和NOT EXISTS子查询:EXISTS关键字用来检测数数据库对象是否存在. ★EXISTS和NOT EXISTS的结果只取决于是否 ...
- JAVA / MySql 编程——第七章 JDBC
1.JDBC:JDBA是Java数据库连接(Java DataBase Connectivity)技术的简称,提供连接各种常用数据库的能力: ●Java是通过JDBC技术实现对各种数据 ...
- JAVA / MySql 编程——第五章 事务、视图、索引、备份和恢复
1.事务(Transaction): 事务是将一系列数据操作绑成一个整体进行统一管理. 如果一事务执行成功,则咋子该事务中进行的所有数据更改均会提交,称为数据库中的永久成部分. 如果事务执行是遇到错误 ...
- java面向对象编程—— 第三章 程序流程控制
3.1流程控制 三种基本技术可以改变程序的控制流程: ① 调用方法:调用方法将导致控制流程离开当前方法,转移到被调用的方法: ② 选择:java中有两种做出选择的机制:if/else语句和sw ...
- JAVA / MySql 编程——第六章 Mysql 创建账户的相关命令
1. 创建普通用户: 语法: CREATE USER `user`@`host` [IDENTIFIED 'password']; //user:用户名,host:主机名,passw ...
- 【MongoDB详细使用教程】三、高级查询
目录 1.使用比较运算符查询 2.使用关键字查询 2.1.in/not in 关键字 2.2.size 关键字 2.3.exists 关键字 2.4.or 关键字 3.模糊查询 4.查询结果排序 5. ...
- [Java并发编程(三)] Java volatile 关键字介绍
[Java并发编程(三)] Java volatile 关键字介绍 摘要 Java volatile 关键字是用来标记 Java 变量,并表示变量 "存储于主内存中" .更准确的说 ...
- [Beego模型] 三、高级查询
[Beego模型] 一.ORM 使用方法 [Beego模型] 二.CRUD 操作 [Beego模型] 三.高级查询 [Beego模型] 四.使用SQL语句进行查询 [Beego模型] 五.构造查询 [ ...
- 《Java程序设计》第三章-基础语法
20145221<Java程序设计>第三章-基础语法 总结 教材学习内容总结 类型.变量与运算符 类型 Java可区分为基本类型(Primitive Type)和类类型(Class Typ ...
随机推荐
- [转].Net Core上用于代替System.Drawing的类库
本文转自:http://www.tuicool.com/wx/iuaINjy 目前.Net Core上没有System.Drawing这个类库,想要在.Net Core上处理图片得另辟蹊径. 微软给出 ...
- Win7无线路由Win8/8.1开启网络承载DOS命令笔记本电脑当无线路由器
以下废话,先吐槽几句 这个功能其实在Win7+系统都内置了,不要再用什么某豹.某大师.某Soft之类的开启无线网络,这些软件都是骗你们安装一些垃圾软件的. 另外吐槽 某度wifi.某数字wifi都是垃 ...
- html table 的属性
表格table th,td 文字顶部对齐 <th valign="top"></th> <td valign="top">& ...
- position:fixed相对父级元素定位而不是浏览器
position:fixed默认是相对浏览器定位的 原理:fixed定位相对父级容器定位,不添加:top,bottom,left,right样式,通过margin定位 代码:http://jsbin. ...
- Android NDK 入门与实践
NDK 是什么 NDK 全称 Native Development Kit,可以让您在 Android 应用中调用 C 或 C++ 代码的工具. NDK 好处 1.NDK 可以生成 .so 文件, 方 ...
- python模块详解 hashlib
hashlib模块 用于加密相关的操作,在python3中替代了md5和sha模块,主要提供SHA和MD5算法. MD5 import hashlib m = hashlib.md5() #调用md5 ...
- Linux命令之文件重定向2
linux中重定向用符号“>”表示,语法一般是 源文件 > 目标文件 1)创出.txt文件touch 1.txt 注意:创建文件夹用mkdir 2)向.txt文件中写入内容 注意:①cat ...
- Docker build 安装报错, Could not open requirments file: [Errno 2] No such file or directory:'requirements.txt'
docker安装教程 https://docs.docker.com/get-started/part2/#build-the-app 相关帖子 https://stackoverflow.com/q ...
- 12/13 exercise
gcc -[cog] gcc pro1.o pro2.o //create a executable file x.out if unnamed
- 数据结构与算法分析java——线性表2(ArrarList )
ArrayList ArrayList 是一个数组队列,相当于 动态数组.与Java中的数组相比,它的容量能动态增长.它继承于AbstractList,实现了List, RandomAccess, C ...