一.数据类型

常用的数据类型如下:

  • 整数:int,bit
  • 小数:decimal
  • 字符串:varchar,char
  • 日期时间: date, time, datetime
  • 枚举类型(enum)

特别说明的类型如下:

  • decimal表示浮点数,如 decimal(5, 2) 表示共存5位数,小数占 2 位.
  • char表示固定长度的字符串,如char(3),如果填充'ab'时会补一个空格为'ab '.
  • varchar表示可变长度的字符串,如varchar(3),填充'ab'时就会存储'ab'
  • 对于图片、音频、视频等文件,不存储在数据库中,而是上传到某个服务器上,然后在表中存储这个文件的保存路径
  • 字符串 text 表示存储大文本,当字符大于 4000 时推荐使用, 比如博客

二、数据约束

约束本质上是对数据在数据类型限定的基础上添加的额外的要求.

常见的约束如下:

  • 主键 primary key: 用于唯一标识一条记录. MySQL 建议所有表的主键字段都叫 id, 类型为 int unsigned.
  • 非空 not null: 此字段不允许填写空值.
  • 惟一 unique: 此字段的值不允许重复.
  • 默认 default: 当不填写字段对应的值会使用默认值,如果填写时以填写为准.
  • 外键 foreign key: 对关系字段进行约束, 当为关系字段填写值时, 会到关联的表中查询此值是否存在, 如果存在则填写成功, 如果不存在则填写失败并抛出异常.

说明:虽然外键约束可以保证数据的有效性, 在进行数据的 crud(增删改查), 会降低数据库的性能, 此种情况下不推荐使用

最后附上常见的数据类型表

1. 整数类型
类型 字节大小 有符号范围(Signed) 无符号范围(Unsigned)
TINYINT 1 -128 ~ 127 0 ~ 255
SMALLINT 2 -32768 ~ 32767 0 ~ 65535
MEDIUMINT 3 -8388608 ~ 8388607 0 ~ 16777215
INT/INTEGER 4 -2147483648 ~2147483647 0 ~ 4294967295
BIGINT 8 -9223372036854775808 ~ 9223372036854775807 0 ~ 18446744073709551615
2. 字符串
类型 字节大小 示例
CHAR 0-255 类型:char(3) 输入 'ab', 实际存储为'ab ', 输入'abcd' 实际存储为 'abc'
VARCHAR 0-255 类型:varchar(3) 输 'ab',实际存储为'ab', 输入'abcd',实际存储为'abc'
TEXT 0-65535 大文本
3. 日期时间类型
类型 字节大小 示例
DATE 4 '2020-01-01'
TIME 3 '12:29:59'
DATETIME 8 '2020-01-01 12:29:59'
YEAR 1 '2017'
TIMESTAMP 4 '1970-01-01 00:00:01' UTC ~ '2038-01-01 00:00:01' UTC

二.基本操作

1、登录以及退出MYSQL

  • 登录:mysql -uroot -p
  • 退出:exit 或者 quit
  • 查看数据库版本:select version();
  • 显示当前的日期时间:select now();
  • 显示当前的年份 select year(now());
  • 显示当前的时间 select time(now());
  • 查看环境变量 show variables;
  • 查看状态 show status;
  • 查看用户登录信息 执行语句 show processlist;
  • 查看上次报警信息 show warnings;
  • 开启查看时间监控 set profiling=1 select语句 show profiles;

2、数据库操作

  • 查看当前在哪个数据库:select database();
  • 查看所有数据库:show databases;
  • 使用数据库:use 数据库名;
  • 创建数据库:  create database [if not exists] 数据库名;推荐这种方法
  • 创建数据库:create database 数据库名 charset=utf8;    (charset=utf8一定要加,不然表里用到中文可能会乱码,后续更改很麻烦)
  • 删除数据库: drop database 数据库名;
  • 删除数据库:drop database [if exists] 数据库名; 推荐这种方法

3、数据表结构的操作

  • 查看当前数据库的所有表:show tables;
  • 删除表:drop table 表名;
  • 查看表结构:desc 表名;
  • 创建表结构:create table 表名(字段名称  数据类型 约束条件,*其他的格式和前面的一样)

注意:主键说明可以放在字段中单独说明 也可以放在最后统一说明PRIMARY KEY(字段名称)

表基础操作

  1. -- 1.创建表(类似于一个excel表)
  2.  
  3. create table tab_name(
  4. field1 type[完整性约束条件],
  5. field2 type,
  6. ...
  7. fieldn type
  8. )[character set xxx];
  9.  
  10. -- 创建一个员工表employee
  11.  
  12. create table employee(
  13. id int primary key auto_increment ,
  14. name varchar(20),
  15. gender bit default 1, -- gender char(1) default 1 ----- 或者 TINYINT(1)
  16. birthday date,
  17. entry_date date,
  18. job varchar(20),
  19. salary double(4,2) unsigned,
  20. resume text -- 注意,这里作为最后一个字段不加逗号
  21. );
  22.  
  23. /* 约束:
  24. primary key (非空且唯一) :能够唯一区分出当前记录的字段称为主键!
  25. unique
  26. not null
  27. auto_increment 主键字段必须是数字类型。
  28. 外键约束 foreign key */
  29.  
  30. -- 2.查看表信息
  31. desc tab_name 查看表结构
  32. show columns from tab_name 查看表结构
  33. show tables 查看当前数据库中的所有的表
  34. show create table tab_name 查看当前数据库表建表语句
  35.  
  36. -- 3.修改表结构
  37. -- (1)增加列(字段)
  38. alter table tab_name add [column] 列名 类型[完整性约束条件][firstafter 字段名];
  39. alter table user add addr varchar(20) not null unique first/after username;
  40. #添加多个字段
  41. alter table users2
  42. add addr varchar(20),
  43. add age int first,
  44. add birth varchar(20) after name;
  45.  
  46. -- (2)修改一列类型
  47. alter table tab_name modify 列名 类型 [完整性约束条件][firstafter 字段名];
  48. alter table users2 modify age tinyint default 20;
  49. alter table users2 modify age int after id;
  50.  
  51. -- (3)修改列名
  52. alter table tab_name change [column] 列名 新列名 类型 [完整性约束条件][firstafter 字段名];
  53. alter table users2 change age Age int default 28 first;
  54.  
  55. -- (4)删除一列
  56. alter table tab_name drop [column] 列名;
  57. -- 思考:删除多列呢?删一个填一个呢?
  58. alter table users2
  59. add salary float(6,2) unsigned not null after name,
  60. drop addr;
  61.  
  62. -- (5)修改表名
  63. rename table 表名 to 新表名;
  64. -- (6)修该表所用的字符集
  65. alter table student character set utf8;
  66.  
  67. -- 4.删除表
  68. drop table tab_name;
  69.  
  70. ---5 添加主键,删除主键
  71. alter table tab_name add primary key(字段名称,...)
  72. alter table users drop primary key;
  73.  
  74. eg:
  75. mysql> create table test5(num int auto_increment);
  76. ERROR 1075 (42000): Incorrect table definition; there can be only one auto column and it must be defined as a key
  77. create table test(num int primary key auto_increment);
  78. -- 思考,如何删除主键?
  79. alter table test modify id int; -- auto_increment没了,但这样写主键依然存在,所以还要加上下面这句
  80. alter table test drop primary key;-- 仅仅用这句也无法直接删除主键
  81.  
  82. -- 唯一索引
  83. alter table tab_name add unique [index|key] [索引名称](字段名称,...)
  84.  
  85. alter table users add unique(name)-- 索引值默认为字段名show create table users;
  86. alter table users add unique key user_name(name);-- 索引值为user_name
  87.  
  88. -- 添加联合索引
  89. alter table users add unique index name_age(name,age);#show create table users;
  90.  
  91. -- 删除唯一索引
  92. alter table tab_name drop {index|key} index_name

三.表记录增删改

  1. -- 1.增加一条记录insert
  2.  
  3. /*insert [into] tab_name (field1,filed2,.......) values (value1,value2,.......);*/
  4.  
  5. create table employee_new(
  6. id int primary key auto_increment,
  7. name varchar(20) not null unique,
  8. birthday varchar(20),
  9. salary float(7,2)
  10. );
  11.  
  12. insert into employee_new (id,name,birthday,salary) values
  13. (1,'yuan','1990-09-09',9000);
  14.  
  15. insert into employee_new values
  16. (2,'alex','1989-08-08',3000);
  17.  
  18. insert into employee_new (name,salary) values
  19. ('xialv',1000);
  20.  
  21. -- 插入多条数据
  22. insert into employee_new values
  23. (4,'alvin1','1993-04-20',3000),
  24. (5,'alvin2','1995-05-12',5000);
  25.  
  26. -- set插入: insert into tab_name set 字段名=值 通过键值对插入数据
  27.  
  28. insert into employee_new set id=12,name="alvin3";
  29.  
  30. -- 2.修改表记录 update tab_name set field1=value1,field2=value2,......[where 语句]
  31.  
  32. /* UPDATE语法可以用新值更新原有表行中的各列。
  33. SET子句指示要修改哪些列和要给予哪些值。
  34. WHERE子句指定应更新哪些行。如没有WHERE子句,则更新所有的行。*/
  35.  
  36. update employee_new set birthday="1989-10-24" WHERE id=1;
  37.  
  38. --- yuan的薪水在原有基础上增加1000元。
  39. update employee_new set salary=salary+4000 where name='yuan';
  40.  
  41. -- 3.删除表纪录 注意:一定要带where条件 不带是删表
  42.  
  43. delete from tab_name [where ....]
  44.  
  45. /* 如果不跟where语句则删除整张表中的数据
  46. delete只能用来删除一行记录
  47. delete语句只能删除表中的内容,不能删除表本身,想要删除表,用drop
  48. TRUNCATE TABLE也可以删除表中的所有数据,词语句首先摧毁表,再新建表。此种方式删除的数据不能在
  49. 事务中恢复。*/
  50.  
  51. -- 删除表中名称为’alex’的记录。
  52. delete from employee_new where name='alex';
  53. -- 删除表中所有记录。
  54. delete from employee_new;-- 注意auto_increment没有被重置:alter table employee auto_increment=1;
  55. -- 使用truncate删除表中记录。
  56. truncate table emp_new;

四.单表查询

  1. -- 1.增加一条记录insert
  2.  
  3. /*insert [into] tab_name (field1,filed2,.......) values (value1,value2,.......);*/
  4.  
  5. create table employee_new(
  6. id int primary key auto_increment,
  7. name varchar(20) not null unique,
  8. birthday varchar(20),
  9. salary float(7,2)
  10. );
  11.  
  12. insert into employee_new (id,name,birthday,salary) values
  13. (1,'yuan','1990-09-09',9000);
  14.  
  15. insert into employee_new values
  16. (2,'alex','1989-08-08',3000);
  17.  
  18. insert into employee_new (name,salary) values
  19. ('xialv',1000);
  20.  
  21. -- 插入多条数据
  22. insert into employee_new values
  23. (4,'alvin1','1993-04-20',3000),
  24. (5,'alvin2','1995-05-12',5000);
  25.  
  26. -- set插入: insert into tab_name set 字段名=值 通过键值对插入数据
  27.  
  28. insert into employee_new set id=12,name="alvin3";
  29.  
  30. -- 2.修改表记录 update tab_name set field1=value1,field2=value2,......[where 语句]
  31.  
  32. /* UPDATE语法可以用新值更新原有表行中的各列。
  33. SET子句指示要修改哪些列和要给予哪些值。
  34. WHERE子句指定应更新哪些行。如没有WHERE子句,则更新所有的行。*/
  35.  
  36. update employee_new set birthday="1989-10-24" WHERE id=1;
  37.  
  38. --- yuan的薪水在原有基础上增加1000元。
  39. update employee_new set salary=salary+4000 where name='yuan';
  40.  
  41. -- 3.删除表纪录 注意:一定要带where条件 不带是删表
  42.  
  43. delete from tab_name [where ....]
  44.  
  45. /* 如果不跟where语句则删除整张表中的数据
  46. delete只能用来删除一行记录
  47. delete语句只能删除表中的内容,不能删除表本身,想要删除表,用drop
  48. TRUNCATE TABLE也可以删除表中的所有数据,词语句首先摧毁表,再新建表。此种方式删除的数据不能在
  49. 事务中恢复。*/
  50.  
  51. -- 删除表中名称为’alex’的记录。
  52. delete from employee_new where name='alex';
  53. -- 删除表中所有记录。
  54. delete from employee_new;-- 注意auto_increment没有被重置:alter table employee auto_increment=1;
  55. -- 使用truncate删除表中记录。
  56. truncate table emp_new;
  57.  
  58. -- 查询表达式
  59.  
  60. SELECT select_expr [,select_expr,...] [
  61. FROM tb_name
  62. [JOIN 表名]
  63. [ON 连接条件]
  64. [WHERE 条件判断]
  65. [GROUP BY {col_name | postion} [ASC | DESC], ...]
  66. [HAVING WHERE 条件判断]
  67. [ORDER BY {col_name|expr|postion} [ASC | DESC], ...]
  68. [ LIMIT {[offset,]rowcount | row_count OFFSET offset}]
  69. ]
  70.  
  71. # 精简版
  72. select distinct *
  73. from 表名
  74. where ....
  75. group by ... having ...
  76. order by ...
  77. limit start,count
  78.  
  79. #执行顺序
  80. from 表名
  81. where ....
  82. group by ...
  83. select distinct *
  84. having ...
  85. order by ...
  86. limit start,count
  87.  
  88. ---准备表
  89.  
  90. CREATE TABLE ExamResult(
  91.  
  92. id INT PRIMARY KEY auto_increment,
  93. name VARCHAR (20),
  94. JS DOUBLE ,
  95. Django DOUBLE ,
  96. OpenStack DOUBLE
  97. );
  98.  
  99. INSERT INTO ExamResult(name,JS,Django,OpenStack) VALUES ("yuan",98,98,98),
  100. ("xialv",35,98,67),
  101. ("alex",59,59,62),
  102. ("wusir",88,89,82),
  103. ("alvin",88,98,67),
  104. ("yuan",86,100,55);
  105.  
  106. -- 1select [distinct] *|field1field2,...... from tab_name
  107. -- 其中from指定从哪张表筛选,*表示查找所有列,也可以指定一个列
  108. -- 表明确指定要查找的列,distinct用来剔除重复行。
  109.  
  110. -- 查询表中所有学生的信息。
  111. select * from ExamResult;
  112. -- 查询表中所有学生的姓名和对应的英语成绩。
  113. select name,JS from ExamResult;
  114. -- 过滤表中重复数据。
  115. select distinct JS ,name from ExamResult;
  116. +------+-------+
  117. | JS | name |
  118. +------+-------+
  119. | 98 | yuan |
  120. | 35 | xialv |
  121. | 59 | alex |
  122. | 88 | wusir |
  123. | 88 | alvin |
  124. | 86 | yuan |
  125. +------+-------+
  126.  
  127. -- 2select 也可以使用表达式,并且可以使用: 字段 as 别名或者:字段 别名
  128.  
  129. -- 在所有学生分数上加10分特长分显示。
  130.  
  131. select name,(JS+10)as JS成绩,(Django+10)Django成绩,(OpenStack+10)OpenStack成绩 from ExamResult;
  132. +-------+----------+--------------+-----------------+
  133. | name | JS成绩 | Django成绩 | OpenStack成绩 |
  134. +-------+----------+--------------+-----------------+
  135. | yuan | 108 | 108 | 108 |
  136. | xialv | 45 | 108 | 77 |
  137. | alex | 69 | 69 | 72 |
  138. | wusir | 98 | 99 | 92 |
  139. | alvin | 98 | 108 | 77 |
  140. | yuan | 96 | 110 | 65 |
  141.  
  142. -- 统计每个学生的总分。
  143. select name,JS+Django+OpenStack from ExamResult;
  144.  
  145. -- 使用别名表示学生总分。
  146. select name as 姓名,JS+Django+OpenStack as 总成绩 from ExamResult;
  147.  
  148. select name,JS+Django+OpenStack 总成绩 from ExamResult;
  149. +-------+-----------+
  150. | name | 总成绩 |
  151. +-------+-----------+
  152. | yuan | 294 |
  153. | xialv | 200 |
  154. | alex | 180 |
  155. | wusir | 259 |
  156. | alvin | 253 |
  157. | yuan | 241 |
  158. +-------+-----------+
  159.  
  160. select name JS from ExamResult; -- what will happen?---->记得加逗号
  161.  
  162. -- 3)使用where子句,进行过滤查询。
  163.  
  164. -- 查询姓名为XXX的学生成绩
  165. select * from ExamResult where name='yuan';
  166.  
  167. -- 查询英语成绩大于90分的同学
  168. select id,name,JS from ExamResult where JS>90;
  169.  
  170. -- 查询总分大于200分的所有同学
  171. select name,JS+Django+OpenStack as 总成绩 from
  172. ExamResult where JS+Django+OpenStack>200 ;
  173.  
  174. -- where字句中可以使用:
  175. -- 比较运算符:
  176. > < >= <= <> !=
  177. between 80 and 100 值在80100之间
  178. in(80,90,100) 值是8090100
  179. like 'yuan%'
  180. /*
  181. pattern可以是%或者_,
  182. 如果是%则表示任意多字符,此例如唐僧,唐国强
  183. 如果是_则表示一个字符唐_,只有唐僧符合。两个_则表示两个字符:__
  184. */
  185.  
  186. -- 逻辑运算符
  187. 在多个条件直接可以使用逻辑运算符 and or not
  188. -- 练习
  189. -- 查询JS分数在 70100之间的同学。
  190. select name ,JS from ExamResult where JS between 70 and 100;
  191.  
  192. -- 查询Django分数为75,76,77的同学。
  193. select name ,Django from ExamResult where Django in (75,76,77);
  194.  
  195. -- 查询所有姓王的学生成绩。
  196. select * from ExamResult where name like '王%';
  197.  
  198. -- 查询JS分>90Django分>90的同学。
  199. select id,name from ExamResult where JS>90 and Django >90;
  200.  
  201. -- 查找缺考数学的学生的姓名
  202. select name from ExamResult where Database is null;
  203.  
  204. -- 4Order by 指定排序的列,排序的列即可是表中的列名,也可以是select 语句后指定的别名。
  205.  
  206. -- select *|field1,field2... from tab_name order by field [Asc|Desc]
  207.  
  208. -- Asc 升序、Desc 降序,其中asc为默认值 ORDER BY 子句应位于SELECT语句的结尾。
  209. -- 练习:
  210. -- JS成绩排序后输出。
  211. select * from ExamResult order by JS;
  212.  
  213. -- 对总分排序按从高到低的顺序输出
  214. select name ,(ifnull(JS,0)+ifnull(Django,0)+ifnull(Database,0))
  215. 总成绩 from ExamResult order by 总成绩 desc;
  216.  
  217. -- 对姓李的学生成绩排序输出
  218. select name ,(ifnull(JS,0)+ifnull(Django,0)+ifnull(OpenStack,0)) as
  219. 总成绩 from ExamResult where name like 'a%'
  220. order by 总成绩 desc;
  221.  
  222. -- 5group by 分组查询:
  223. CREATE TABLE order_menu(
  224. id INT PRIMARY KEY auto_increment,
  225. product_name VARCHAR (20),
  226. price FLOAT(6,2),
  227. born_date DATE,
  228. class VARCHAR (20)
  229. );
  230.  
  231. INSERT INTO order_menu (product_name,price,born_date,class) VALUES
  232. ("苹果",20,20170612,"水果"),
  233. ("香蕉",80,20170602,"水果"),
  234. ("水壶",120,20170612,"电器"),
  235. ("被罩",70,20170612,"床上用品"),
  236. ("音响",420,20170612,"电器"),
  237. ("床单",55,20170612,"床上用品"),
  238. ("草莓",34,20170612,"水果");
  239.  
  240. select * from order_menu;
  241. +----+--------------+--------+------------+--------------+
  242. | id | product_name | price | born_date | class |
  243. +----+--------------+--------+------------+--------------+
  244. | 1 | 苹果 | 20.00 | 2017-06-12 | 水果 |
  245. | 2 | 香蕉 | 80.00 | 2017-06-02 | 水果 |
  246. | 3 | 水壶 | 120.00 | 2017-06-12 | 电器 |
  247. | 4 | 被罩 | 70.00 | 2017-06-12 | 床上用品 |
  248. | 5 | 音响 | 420.00 | 2017-06-12 | 电器 |
  249. | 6 | 床单 | 55.00 | 2017-06-12 | 床上用品 |
  250. | 7 | 草莓 | 34.00 | 2017-06-12 | 水果 |
  251. +----+--------------+--------+------------+--------------+
  252.  
  253. -- 注意,按分组条件分组后每一组只会显示第一条记录
  254.  
  255. -- group by字句,其后可以接多个列名,也可以跟having子句,对group by 的结果进行筛选。
  256.  
  257. -- 按位置字段筛选
  258. select * from order_menu group by 5;
  259. +----+--------------+--------+------------+--------------+
  260. | id | product_name | price | born_date | class |
  261. +----+--------------+--------+------------+--------------+
  262. | 4 | 被罩 | 70.00 | 2017-06-12 | 床上用品 |
  263. | 1 | 苹果 | 20.00 | 2017-06-12 | 水果 |
  264. | 3 | 水壶 | 120.00 | 2017-06-12 | 电器 |
  265. +----+--------------+--------+------------+--------------+
  266.  
  267. -- 练习:对购物表按类名分组后显示每一组商品的价格总和
  268. select class as 商品,SUM(price) as 总价 from order_menu group by class;
  269. +--------------+--------+
  270. | 商品 | 总价 |
  271. +--------------+--------+
  272. | 床上用品 | 125.00 |
  273. | 水果 | 134.00 |
  274. | 电器 | 540.00 |
  275. +--------------+--------+
  276.  
  277. -- 练习:对购物表按类名分组后显示每一组商品价格总和超过150的商品
  278. select class,SUM(price)from order_menu group by class
  279. HAVING SUM(price)>150;
  280. +--------+------------+
  281. | class | SUM(price) |
  282. +--------+------------+
  283. | 电器 | 540.00 |
  284. +--------+------------+
  285.  
  286. /*
  287. having 和 where两者都可以对查询结果进行进一步的过滤,差别有:
  288. <1>where语句只能用在分组之前的筛选,having可以用在分组之后的筛选;
  289. <2>使用where语句的地方都可以用having进行替换
  290. <3>having中可以用聚合函数,where中就不行。
  291. */
  292.  
  293. -- GROUP_CONCAT() 函数
  294. SELECT id,GROUP_CONCAT(name),GROUP_CONCAT(JS) from ExamResult GROUP BY id;
  295.  
  296. -- 6)聚合函数: 先不要管聚合函数要干嘛,先把要求的内容查出来再包上聚合函数即可。
  297. -- (一般和分组查询配合使用)
  298.  
  299. --<1> 统计表中所有记录
  300.  
  301. -- COUNT(列名):统计行的个数
  302. -- 统计一个班级共有多少学生?先查出所有的学生,再用count包上
  303. select count(*) from ExamResult;
  304.  
  305. -- 统计JS成绩大于70的学生有多少个?
  306. select count(JS) from ExamResult where JS>70;
  307.  
  308. -- 统计总分大于280的人数有多少?
  309. select count(name) from ExamResult
  310. where (ifnull(JS,0)+ifnull(Django,0)+ifnull(OpenStack,0))>280;
  311. -- 注意:count(*)统计所有行; count(字段)不统计null值.
  312.  
  313. -- SUM(列名):统计满足条件的行的内容和
  314. -- 统计一个班级JS总成绩?先查出所有的JS成绩,再用sum包上
  315. select JS as JS总成绩 from ExamResult;
  316. select sum(JS) as JS总成绩 from ExamResult;
  317. -- 统计一个班级各科分别的总成绩
  318. select sum(JS) as JS总成绩,
  319. sum(Django) as Django总成绩,
  320. sum(OpenStack) as OpenStack from ExamResult;
  321.  
  322. -- 统计一个班级各科的成绩总和
  323. select sum(ifnull(JS,0)+ifnull(Django,0)+ifnull(Database,0))
  324. as 总成绩 from ExamResult;
  325. -- 统计一个班级JS成绩平均分
  326. select sum(JS)/count(*) from ExamResult ;
  327. -- 注意:sum仅对数值起作用,否则会报错。
  328.  
  329. -- AVG(列名):
  330. -- 求一个班级JS平均分?先查出所有的JS分,然后用avg包上。
  331. select avg(ifnull(JS,0)) from ExamResult;
  332. -- 求一个班级总分平均分
  333. select avg((ifnull(JS,0)+ifnull(Django,0)+ifnull(Database,0)))
  334. from ExamResult ;
  335. -- MaxMin
  336. -- 求班级最高分和最低分(数值范围在统计中特别有用)
  337. select Max((ifnull(JS,0)+ifnull(Django,0)+ifnull(OpenStack,0)))
  338. 最高分 from ExamResult;
  339.  
  340. select Min((ifnull(JS,0)+ifnull(Django,0)+ifnull(OpenStack,0)))
  341. 最低分 from ExamResult;
  342. -- 求购物表中单价最高的商品名称及价格
  343. ---SELECT id, MAX(price) FROM order_menu;--id和最高价商品是一个商品吗?
  344.  
  345. SELECT MAX(price) FROM order_menu;
  346.  
  347. -- 注意:null 和所有的数计算都是null,所以需要用ifnullnull转换为0
  348. -- -----ifnull(JS,0)
  349.  
  350. -- with rollup的使用
  351.  
  352. --<2> 统计分组后的组记录
  353.  
  354. -- 7 重点:Select from where group by having order by
  355. -- Mysql在执行sql语句时的执行顺序:
  356. -- from where select group by having order by
  357. -- 分析:
  358. select JS as JS成绩 from ExamResult where JS成绩 >70; ---- 不成功
  359. select JS as JS成绩 from ExamResult having JS成绩 >90; --- 成功
  360.  
  361. -- (8) limit
  362. SELECT * from ExamResult limit 1;
  363. SELECT * from ExamResult limit 2,5;--跳过前两条显示接下来的五条纪录
  364. SELECT * from ExamResult limit 2,2;
  365.  
  366. --- (9) 使用正则表达式查询
  367. SELECT * FROM employee WHERE emp_name REGEXP '^yu';
  368.  
  369. SELECT * FROM employee WHERE emp_name REGEXP 'yun$';
  370.  
  371. SELECT * FROM employee WHERE emp_name REGEXP 'm{2}';

参考:https://www.cnblogs.com/yuanchenqi/articles/6357507.html

https://www.cnblogs.com/chichung/p/9571004.html

https://www.cnblogs.com/chichung/p/9585127.html

MYSQL数据类型 表基本操作 表记录增删改 单表查询的更多相关文章

  1. python 全栈开发,Day62(外键的变种(三种关系),数据的增删改,单表查询,多表查询)

    一.外键的变种(三种关系) 本节重点: 如何找出两张表之间的关系 表的三种关系 一.介绍 因为有foreign key的约束,使得两张表形成了三种了关系: 多对一 多对多 一对一 二.重点理解如果找出 ...

  2. MySQL 初识别语句,数据库、表、行的增删改查

    一.MySQL 开场语句 1.登陆 mysql -u root -p ; #回车然后输入密码 2.退出 eixt | quit #二者选其一 3.查看数据文件路径(配置文件中学习的) show glo ...

  3. mysql之字段的修改,添加、删除,多表关系(外键),单表详细操作(增删改)

    字段的修改.添加和删除 create table tf1( id int primary key auto_increment, x int, y int ); #修改 alter table tf1 ...

  4. Django框架之第二篇--app注册、静态文件配置、form表单提交、pycharm连接数据库、django使用mysql数据库、表字段的增删改查、表数据的增删改查

    本节知识点大致为:静态文件配置.form表单提交数据后端如何获取.request方法.pycharm连接数据库,django使用mysql数据库.表字段的增删改查.表数据的增删改查 一.创建app,创 ...

  5. 一、数据库表中字段的增删改查,二、路由基础.三、有名无名分组.四、多app共存的路由分配.五、多app共存时模板冲突问题.六、创建app流程.七、路由分发.八、路由别名,九、名称空间.十、反向解析.十一、2.x新特性.十二、自定义转换器

    一.数据库表中字段的增删改查 ''' 直接在modules中对字段进行增删改查 然后在tools下点击Run manage.py Task执行makemigrations和migrate 注意在执行字 ...

  6. Microsoft Dynamics CRM 增删改子表汇总子表的某个字段到主表的某个字段(通用插件)

    背景 经常有某个汇总子表的数量到主表的总数量,或者汇总子表的总价到主表的总价这种需求. 传统的做法: 1.就是为每个子表实体单独写成一个插件,但是这样不好复用. 2.主表的汇总字段是汇总货币类型,但是 ...

  7. MySQL查询数据表中数据记录(包括多表查询)

    MySQL查询数据表中数据记录(包括多表查询) 在MySQL中创建数据库的目的是为了使用其中的数据. 使用select查询语句可以从数据库中把数据查询出来. select语句的语法格式如下: sele ...

  8. 第三百零七节,Django框架,models.py模块,数据库操作——表类容的增删改查

    Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...

  9. mysql--对行(表中数据)的增删改查

    一.插入数据(增加)insert 1.插入数据(顺序插入) 语法一: INSERT INTO 表名(字段1,字段2,字段3…字段n) VALUES(值1,值2,值3…值n); #指定字段来插入数据,插 ...

随机推荐

  1. Eclipse-离线安装Memory Anlysis Tool

    Eclipse版本:Version: Mars.2 Release (4.5.2) 1.从官网下载MAT Memory Anlysis Tool http://www.eclipse.org/mat/ ...

  2. gcc 编译问题

    一般情况一句话即可: gcc -o fuck fuck.c ./fuck 直接运行了 问题 1. 报错 ld 未找到 此时,gcc编译得分布来,并且指定特定的ld gcc -c  1.c //会在目录 ...

  3. C/C++ -- Gui编程 -- Qt库的使用 -- 信号与槽的关联

    Qt信号与槽的三种关联方法:1.设计界面关联,编辑信号/槽,自动关联 2.手动关联(1).头文件中定义槽 -----mywidget.h----- #ifndef MYWIDGET_H #define ...

  4. mongodb-手写mongoclient加入到springmvc中

    由于一个项目使用的是springmvc3.x版本, mongodb使用的为3.x版本, 所以springmvc继承的mongodb-data并不可用, 只能自己手写一个mongoclient并加入到s ...

  5. mysql创建用户,并指定用户的权限(grant命令)

    参考链接http://blog.csdn.net/leili0806/article/details/8573636,谢谢这位仁兄 1.创建新用户的SQL语句: CREATE USER 'pig'@' ...

  6. LVS负载均衡DR模式部署

    目录: 1. 拓扑图 2. 搭建环境 3. LVS服务器部署 4. 测试 1. 拓扑图     LVS-DR模式采的IP地址全部为外网IP.    本例中IP的设置全部采用临时设置IP的方式,重启后会 ...

  7. DOM-添加元素、节点

    createElement()方法能够根据参数指定的标签名称创建一个新元素,并返回新建元素的引用,用法如下 var element=document.createElement("tagNa ...

  8. ASP.NET MVC 学习笔记-3.面向对象设计原则

    在设计程序.系统框架或者类时,最主要考虑的事情就是代码的可扩展性,而不是完成功能即可.因此,提倡使用面向对象设计的最佳实践和基本原则. 1.       单一职责原则(SRP:The Single R ...

  9. 7行代码看EntityFramework是如何运行

    这段时间在项目中运用Entity Framework作为底层数据交互框架.一个字,爽.不仅提高了开发效率,省了很多代码,而且数据库也规范了很多.按照网上的一些教程初步学习,然后实际运用了,再结合MVC ...

  10. 使用tcmalloc替换系统的malloc

    https://blog.csdn.net/educast/article/details/79166553?utm_source=blogxgwz0 今天对服务器进行压测,模拟的请求量到4万次/分的 ...