• MySQL的


    目录

    一,用户的管理

    二,建库

    三,建表

    四,四大引擎的作用及区别

    (1).InnoDB存储引擎(支持事务)

    (2)MyISAM存储引擎(不支持事务,效率会更快)

    (3)MEMORY存储引擎

    (4)Archive存储引擎

    五,案例演示


    前言:

    1.对于系统开发来讲,有三个环境

    (1)线网,生产环境:系统开发完毕,客户使用的环境

    (2)测试环境:公式内部模拟客户现场,搭建的环境

    (3)开发环境:本地电脑地址

    2.权限的划分一般针对的是生产环境

    一,用户的管理


    我们需要来看一下mysql默认数据库里面的四张表(user,db,tables_priv,columns_priv)

    (1)user表(用户层权限)

    注意事项:登陆的时候验证Host,User,Password(authentication_string)也就是ip,用户名,密码是否匹配,匹配登陆成功将会为登陆者分配权限。

    (2)db表(数据库层权限)

    注意事项:db表之后会匹配Host,User然后会根据Db字段对应的表进行权限分配(运用语句:Select,Insert,Update,Delete,Create,Drop---------分别代表着查询,增加,更新,删除,创建,销毁)

    (3)tables_priv表(表层权限)

    注意事项:同上分配权限,但是它只有Table_priv和Column_priv两个字段来记录权限。

    (4)columns_priv表(字段层权限)

    注意事项:通过Host,Db,User,Table,Column来进行定位到字段层的一个权限分配

    《演示图》

    提示:在MySQL里面的表很多,切记不能删掉,否则MySQL数据库用不成

    《代码演示》

    1. SELECT * FROM `user`
    2. 创建用户
    3. create user dxy;
    4. 设置密码
    5. ALTER USER 'dxy'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
    6. 设置客户的权限
    7. #语法:grant privileges on databasename.tablename to username@'host';
    8. 赋有所有权限
    9. grant all on db_dengxiyan.* to dxy@'%';
    10. 只有查询权限
    11. grant SELECT,DELETE db_xe.t_p1_user to xionger@'%';
    12. 查看所有权限
    13. show grants for 'dxy'@'%';
    14. 以下权限可以被收回的
    15. REVOKE DELETE on db_dengxiyan.* FROM dxy@'%';
    16. grant all on db_dengxiyan.* to dxy@'%';
    17. 当某个库里的某一张表里的某一权限不能收回,
    18. REVOKE UPDATE on db_dengxiyan.tb_book FROM dxy@'%';

     《效果图》

    当没有给权限时会默认与一个权限,当给用户添加了权限时,所有权限将一并查出 

    二,建库

    方式一:

    直接右键,新建数据库

    注:默认的数据库编码集:utf8(即UTF-8),collate表示排序规则为utf8_general_ci

    方式二:

    代码创建 

    1. 建库
    2. create database tb_dxy_0629;
    3. 查询版本(当版本的不同可能会产生乱码的现象)
    4. SELECT version();
    5. 查询数据库
    6. show databases;

    三,建表

    1.数据类型

    MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。
    1)字符类型:char varchar text blob
    2)数值类型:int bigint float decimal
    int -> int
    bigint -> long
    float -> 成绩
    decimal -> 货币类型(精度,小数)

    3)日期类型:date time datetime timestamp

    date -> yyyy:MM:dd HH:mm:ss
    time -> HH:mm:ss
    datetime -> yyyy:MM:dd
    timestamp(时间戳) -> 长整数

    《代码演示》

    1. CREATE TABLE user2(
    2. #主键
    3. id int PRIMARY key,
    4. #不为空
    5. name VARCHAR(15) not null,
    6. #唯一约束
    7. sex char DEFAULT '男',
    8. birthday datetime,
    9. code VARCHAR(18) UNIQUE
    10. )
    11. desc user2;
    12. 修改列名
    13. ALTER TABLE book CHANGE COLUMN publishdate pubDate DATETIME;
    14. 修改列的类型或约束
    15. ALTER TABLE book MODIFY COLUMN pubdate TIMESTAMP;
    16. 表的删除
    17. DROP TABLE IF EXISTS book_author;
    18. 添加新列
    19. ALTER TABLE author ADD COLUMN annual DOUBLE;
    20. 删除列
    21. ALTER TABLE book_author DROP COLUMN annual;
    22. 修改表名
    23. ALTER TABLE author RENAME TO book_author;

    四,四大引擎的作用及区别

    (1).InnoDB存储引擎(支持事务)

    InnoDB是事务型数据库的首选引擎,支持事务安全表(ACID),支持行锁定和外键,上图也看到了,InnoDB是默认的MySQL引擎。

    (2)MyISAM存储引擎(不支持事务,效率会更快)

    MyISAM基于ISAM存储引擎,并对其进行扩展。它是在Web、数据仓储和其他应用环境下最常使用的存储引擎之一。MyISAM拥有较高的插入、查询速度,但不支持事物。

    (3)MEMORY存储引擎

    MEMORY存储引擎将表中的数据存储到内存中,未查询和引用其他表数据提供快速访问。

    (4)Archive存储引擎

    如果只有INSERT和SELECT操作,可以选择Archive,Archive支持高并发的插入操作,但是本身不是事务安全的。Archive非常适合存储归档数据,如记录日志信息可以使用Archive

    不同的存储引擎都有各自的特点,以适应不同的需求,如下表所示:

    | **功 能**    | **MYISAM** | **Memory** | **InnoDB** | **Archive** |
    | 存储限制   | 256TB        | RAM            | 64TB          | None        |
    | 支持事物   | No              | No               | Yes             | No             |
    | 支持全文索引 | Yes        | No               | No              | No             |
    | 支持数索引   | Yes          | Yes             | Yes              | No            |
    | 支持哈希索引| No           | Yes             | No               | No            |
    | 支持数据缓存 | No          | N/A             | Yes              | No            |
    | 支持外键     | No             | No              | Yes               | No            |

    五,案例演示

    1. 案例演示
    2. 3.表的删除
    3. DROP TABLE IF EXISTS book_author;
    4. SHOW TABLES;
    5. 通用的写法:
    6. DROP DAT
    7. ABASE IF EXISTS
    8. CREATE DATABASE 新库名;
    9. DROP TABLE IF EXISTS user2;
    10. CREATE TABLE 表名();
    11. #4.表的复制
    12. INSERT INTO author VALUES
    13. (1,'村上春树','日本'),
    14. (2,'莫言','中国'),
    15. (3,'冯唐','中国'),
    16. (4,'金庸','中国');
    17. SELECT * FROM Author;
    18. SELECT * FROM copy2;
    19. 1.仅仅复制表的结构
    20. CREATE TABLE copy LIKE author;
    21. 2.复制表的结构+数据
    22. CREATE TABLE copy2
    23. SELECT * FROM author;
    24. 只复制部分数据
    25. CREATE TABLE copy3
    26. SELECT id,au_name
    27. FROM author
    28. WHERE nation='中国';
    29. 仅仅复制某些字段
    30. CREATE TABLE copy4
    31. SELECT id,au_name
    32. FROM author
    33. WHERE 0;
    34. 过滤查询案例
    35. select
    36. bname
    37. from
    38. tb_book
    39. where bname='朝花夕拾-01';
    40. 模糊查询
    41. 查询工资>12000的员工信息
    42. SELECT
    43. *
    44. FROM
    45. tb_book
    46. WHERE
    47. price>70;
    48. 案例2:查询部门编号不等于90号的员工名和部门编号
    49. SELECT
    50. bname,
    51. bid
    52. FROM
    53. tb_book
    54. WHERE
    55. bid<>12;
    56. 二、按逻辑表达式筛选
    57. 案例1:查询编号在110之间的书名、价格
    58. SELECT
    59. bname,
    60. price
    61. FROM
    62. tb_book
    63. WHERE
    64. bid>=1 AND bid<=10;
    65. 案例2:查询部门编不是在110之间,或者价格高于80的书籍信息
    66. SELECT
    67. *
    68. FROM
    69. tb_book
    70. WHERE
    71. NOT(bid>=1 AND bid<=10) OR price>90;
    72. 三、模糊查询
    73. 案例1:查询书籍名中包含字符花的书籍信息
    74. select
    75. *
    76. from
    77. tb_book
    78. where
    79. bname like '%花%';
    80. 案例2:查询书籍名称中第二个字符为哈,第四个字符为的书籍名称和价格
    81. select
    82. bname,
    83. price
    84. FROM
    85. tb_book
    86. WHERE
    87. bname LIKE '_哈_拾%';
    88. 案例3:查询书籍名中第二个字符为-的员工名
    89. SELECT
    90. bname
    91. FROM
    92. tb_book
    93. WHERE
    94. bname LIKE '_$花%' ESCAPE '$';
    95. 2.between and
    96. /*
    97. ①使用between and 可以提高语句的简洁度
    98. ②包含临界值
    99. ③两个临界值不要调换顺序
    100. */
    101. 案例1:查询价格在6070之间的书籍信息
    102. SELECT
    103. *
    104. FROM
    105. tb_book
    106. WHERE
    107. price BETWEEN 60 AND 70;
    108. 3.in
    109. /*
    110. 含义:判断某字段的值是否属于in列表中的某一项
    111. 特点:
    112. ①使用in提高语句简洁度
    113. ②in列表的值类型必须一致或兼容
    114. ③in列表中不支持通配符
    115. */
    116. 案例:查询书籍的编号是2,或3,或10中的一个书籍名和书籍编号
    117. select * from tb_book
    118. 方式一
    119. SELECT
    120. bname,
    121. bid
    122. FROM
    123. tb_book
    124. WHERE
    125. bid = '2' OR bid = '3' OR bid ='10';
    126. ​方式二
    127. SELECT
    128. bname,
    129. bid
    130. FROM
    131. tb_book
    132. WHERE
    133. bid IN( '2' ,'3','10');
    134. /*
    135. =或<>不能用于判断null值
    136. is null或is not null 可以判断null值
    137. ​*/
    138. 案例1:查询没有价格的书籍名称和编号
    139. SELECT
    140. bname,
    141. bid
    142. FROM
    143. tb_book
    144. WHERE
    145. price IS NULL;
    146. 1:查询有价格的书籍名和书籍编号
    147. SELECT
    148. bname,
    149. bid
    150. FROM
    151. tb_book
    152. WHERE
    153. price IS NOT NULL;
    154. #安全等于 <=>
    155. 案例1:查询没有价格的书籍名称和编号
    156. SELECT
    157. bname,
    158. price
    159. FROM
    160. tb_book
    161. WHERE
    162. price <=>NULL;
    163. 案例2:查询价格为66.99的员工信息
    164. SELECT
    165. bname,
    166. bid
    167. FROM
    168. tb_book
    169. WHERE
    170. price <=> 66.99;
    171. #is null pk <=>
    172. IS NULL:仅仅可以判断NULL值,可读性较高,建议使用
    173. <=> :既可以判断NULL值,又可以判断普通的数值,可读性较低
    174. ```
    175. ```
    176. 进阶3:排序查询
    177. /**
    178. 语法:
    179. select 查询列表
    180. from 表名
    181. 【where 筛选条件】
    182. order by 排序的字段或表达式;
    183. 特点:
    184. 1、asc代表的是升序,可以省略
    185. desc代表的是降序
    186. 2、order by子句可以支持 单个字段、别名、表达式、函数、多个字段
    187. 3、order by子句在查询语句的最后面,除了limit子句
    188. **/
    189. 1、按单个字段排序(降序)
    190. SELECT * FROM tb_book ORDER BY bid DESC;
    191. #2、添加筛选条件再排序
    192. 案例:查询书籍编号>=10的书籍信息,并按书籍价格降序
    193. SELECT *
    194. FROM tb_book
    195. WHERE bid>=10
    196. ORDER BY price DESC;
    197. #4、按别名排序
    198. 案例:查询员工信息 按年薪升序
    199. SELECT *,salary*12*(1+IFNULL(commission_pct,0)) price
    200. FROM tb_book
    201. ORDER BY 年薪 ASC;
    202. #5、按函数排序
    203. 案例:查询员工名,并且按名字的长度降序
    204. SELECT LENGTH(last_name),last_name
    205. FROM t_mysql_employees
    206. ORDER BY LENGTH(last_name) DESC;
    207. #6、按多个字段排序
    208. #案例:查询员工信息,要求先按工资降序,再按employee_id升序
    209. SELECT *
    210. FROM t_mysql_employees
    211. ORDER BY salary DESC,employee_id ASC;
    212. 排序练习
    213. #1.查询员工的姓名和部门号和年薪,按年薪降序 按姓名升序
    214. SELECT last_name,department_id,salary*12*(1+IFNULL(commission_pct,0)) 年薪
    215. FROM t_mysql_employees
    216. ORDER BY 年薪 DESC,last_name ASC;
    217. #2.选择工资不在800017000的员工的姓名和工资,按工资降序
    218. SELECT last_name,salary
    219. FROM t_mysql_employees
    220. WHERE salary NOT BETWEEN 8000 AND 17000
    221. ORDER BY salary DESC;
    222. #3.查询邮箱中包含e的员工信息,并先按邮箱的字节数降序,再按部门号升序
    223. SELECT *,LENGTH(email)
    224. FROM t_mysql_employees
    225. WHERE email LIKE '%e%'
    226. ORDER BY LENGTH(email) DESC,department_id ASC;
    227. ```
    228. 分组查询
    229. ```
    230. /*
    231. 功能:用作统计使用,又称为聚合函数或统计函数或组函数
    232. 分类:
    233. sum 求和、avg 平均值、max 最大值 、min 最小值 、count 计算个数
    234. 特点:
    235. 1、sum、avg一般用于处理数值型
    236. max、min、count可以处理任何类型
    237. 2、以上分组函数都忽略null值
    238. 3、可以和distinct搭配实现去重的运算
    239. 4、count函数的单独介绍
    240. 一般使用count(*)用作统计行数
    241. 5、和分组函数一同查询的字段要求是group by后的字段
    242. */
    243. #1、简单 的使用
    244. SELECT SUM(salary) FROM t_mysql_employees;
    245. SELECT AVG(salary) FROM t_mysql_employees;
    246. SELECT MIN(salary) FROM t_mysql_employees;
    247. SELECT MAX(salary) FROM t_mysql_employees;
    248. SELECT COUNT(salary) FROM t_mysql_employees;
    249. SELECT SUM(salary) 和,AVG(salary) 平均,MAX(salary) 最高,MIN(salary) 最低,COUNT(salary) 个数
    250. FROM t_mysql_employees;
    251. SELECT SUM(salary) 和,ROUND(AVG(salary),2) 平均,MAX(salary) 最高,MIN(salary) 最低,COUNT(salary) 个数
    252. FROM t_mysql_employees;
    253. #2、参数支持哪些类型
    254. SELECT SUM(last_name) ,AVG(last_name) FROM t_mysql_employees;
    255. SELECT SUM(hiredate) ,AVG(hiredate) FROM t_mysql_employees;
    256. SELECT MAX(last_name),MIN(last_name) FROM t_mysql_employees;
    257. SELECT MAX(hiredate),MIN(hiredate) FROM t_mysql_employees;
    258. SELECT COUNT(commission_pct) FROM t_mysql_employees;
    259. SELECT COUNT(last_name) FROM t_mysql_employees;
    260. #3、是否忽略null
    261. SELECT SUM(commission_pct) ,AVG(commission_pct),SUM(commission_pct)/35,SUM(commission_pct)/107 FROM t_mysql_employees;
    262. SELECT MAX(commission_pct) ,MIN(commission_pct) FROM t_mysql_employees;
    263. SELECT COUNT(commission_pct) FROM t_mysql_employees;
    264. SELECT commission_pct FROM t_mysql_employees;
    265. #4、和distinct搭配
    266. SELECT SUM(DISTINCT salary),SUM(salary) FROM t_mysql_employees;
    267. SELECT COUNT(DISTINCT salary),COUNT(salary) FROM t_mysql_employees;
    268. #5、count函数的详细介绍
    269. SELECT COUNT(salary) FROM t_mysql_employees;
    270. SELECT COUNT(*) FROM t_mysql_employees;
    271. SELECT COUNT(1) FROM t_mysql_employees;
    272. 效率:
    273. MYISAM存储引擎下 ,COUNT(*)的效率高
    274. INNODB存储引擎下,COUNT(*)和COUNT(1)的效率差不多,比COUNT(字段)要高一些
    275. #6、和分组函数一同查询的字段有限制,employee_id是最小的那个
    276. SELECT AVG(salary),employee_id FROM t_mysql_employees;

    效果图参考

     

  • 相关阅读:
    josef约瑟 闭锁继电器 LB-7DG 100V 50HZ 导轨安装
    TypeScript配置文件设置详解
    【数字图像处理】RGB 转灰度图
    2024年山东高企申报注意事项
    7月SCI/SSCI期刊变动,警惕这5本被剔除
    [Linux系统编程]_进程(二)
    PVE vi 编辑器方向键出现ABCD乱码
    数据库缓存策略
    香港服务器怎么解除被封ip?
    443-C++基础语法(121-130)
  • 原文地址:https://blog.csdn.net/weixin_66202611/article/details/125545734