码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 学习MySQL的第二天:SQL(基础篇)


    目录

     一,SQL通用语法

    二,SQL分类

     三,DDL(数据定义语言)

    1,数据库操作:

     2,表操作:

    3,表操作-数据类型:

    1)数据类型:​编辑

    2)字符串类型:

    3)日期类型:

     4)案例:

     4,表操作-修改:

    1)增加字段: 

    2)修改:

     3)删除字段:

     4)修改表名:

     5,表操作-删除

    6,总结:

    1)数据库操作:

    2)表操作:

    四, 图形化界面工具DataGrip

    五,DML(数据操作语言)--Data Manipulation Language

     1,增加数据:

    1)给指定字段添加数据:

     2)给所有字段添加数据:

     3)批量添加数据:

     2,修改数据:

    3,删除数据:

    六,DQL (数据查询语言)--Data Query Language

     1,基本查询:

    1)查询多个字段:

    2)设置别名: ​编辑

     3)去除重复记录:(返回去重操作后的数据)

    2,条件查询:

     3,聚合函数:

     4,分组查询:

     5,排序查询:

     6,分页查询:

    习题:

    答案:

    7,执行顺序:

    七,DCL(数据控制语言)--Data Control Language

    1,用户管理:

     2,权限控制:

    学习大纲:

     一,SQL通用语法

    1. SQL语句可以单行或多行书写,以分号结尾。

    2.SQL语句可以使用空格/缩进来增强语句的可读性。

    3. MySQL数据库的SQL语句不区分大小写, 关键字建议使用大写。(统一规范)

    4.注释:

    ●单行注释: -- 注释内容或 # 注释内容(MySQL特有)
    ●多行注释: /* 注释内容*/
     

    二,SQL分类

     三,DDL(数据定义语言)

    1,数据库操作:

      

     2,表操作:

     查询所有的表之前,前提是要先进入这个数据库中。(use 数据库名)

     注意: [..]为可选参数,最后一个字段后面没有逗号

    尝试用上面的伪代码讲下面的表结构创建出来。

     注:不要随意在系统库里面进行操作。

    3,表操作-数据类型:


    MySQL中的数据类型有很多,主要分为三类:数值类型、字符串类型、日期时间类型。

    1)数据类型:

     精度:所有位数

    标度:小数位数

    2)字符串类型:

     char的性能较好,(varchar)。有一个计算的过程。(计算字符串的长度)

    3)日期类型:

     4)案例:

    根据需求创建表(设计合理的数据类型、长度)

    设计一张员工信息表,要求如下:
    1.编号(纯数字)
    2.员工工号 (字符串类型,长度不超过10位)
    3. 员工姓名(字符串类型,长度不超过10位)
    4.性别(男/女,存储一一个汉字)
    5.年龄(正常人年龄,不可能存储负数)
    6. 身份证号(二代身份证号均为18位,身份证中有X这样的字符)
    7.入职时间 (取值年月日即可)

     4,表操作-修改:

    1)增加字段: 

    为emp表增加一个新的字段”昵称"为nickname,类型为varchar(20)

    2)修改:

     将emp表的nickname字段修改为username,类型为varchar(30)

     3)删除字段:

     将emp表的字段username删除

     4)修改表名:

     将emp表的表名修改为employee

     5,表操作-删除

     

     

     将原有的数据全部删除,重新创建一张新表,表中无任何数据。

    6,总结:

    1)数据库操作:

    2)表操作:

    四, 图形化界面工具DataGrip

     日常开发效率低,使用不直观。

    五,DML(数据操作语言)--Data Manipulation Language

    用于对数据库中表的数据记录进行增删改操作

     1,增加数据:

    1)给指定字段添加数据:

     2)给所有字段添加数据:

     3)批量添加数据:

     注意:
    ●插入数据时,指定的字段顺序需要与值的顺序是一一对应的。.
    ●字符串和日期型数据应该包含在引号中。
    ●插入的数据大小,应该在字段的规定范围内。

     

     2,修改数据:

     注意:修改语句的条件可以有,也可以没有,如果没有条件,则会修改整张表的所有数据。

     

     

     

     如果不带where条件,代表修改整张表。 

    Laravel基础篇学习笔记(二)SQL文件
    sql 0星 超过10%的资源 1KB
    下载

    3,删除数据:

     

     注意:
    DELETE语句的条件可以有,也可以没有,如果没有条件,则会删除整张表的所有数据。
    DELETE语句不能删除某一个字段的值(可以使 用UPDATE)。

    六,DQL (数据查询语言)--Data Query Language

    用来查询数据库中表的记录。

     1,基本查询:

    1)查询多个字段:

    2)设置别名: 

     3)去除重复记录:(返回去重操作后的数据)

    1. create table emp(
    2. id int comment '编号',
    3. workno varchar(10) comment '工号',
    4. name varchar(10) comment '姓名',
    5. gender char(1) comment '性别',
    6. age tinyint unsigned comment '年龄',
    7. idcard char(10) comment '身份证号',
    8. workaddress varchar(50) comment '工作地址',
    9. entrydata date comment '入职时间'
    10. ) comment '员工表';
    11. insert into emp(id, workno, name, gender, age, idcard, workaddress, entrydata)
    12. values (1,'1','y11','m',29,'1234','北京','2008-01-01'),
    13. (2,'2','y12','m',30,'2234','北京','2008-03-01'),
    14. (3,'3','y13','w',19,'3234','北京','2008-05-01'),
    15. (4,'4','y14','m',56,'4234','北京','2008-07-01'),
    16. (5,'5','y15','w',25,'5234','北京','2008-08-01'),
    17. (6,'6','y16','m',35,'6234','北京','2009-01-01'),
    18. (7,'7','y17','w',38,'7234','北京','2002-01-01'),
    19. (8,'8','y18','m',45,'8234','北京','2005-06-01'),
    20. (9,'9','y19','w',29,'9234','北京','2008-01-01'),
    21. (10,'10','y10','m',21,'0234','北京','2007-03-01');

    案例:

     

     1,

     

     2,

     尽量不写*,不直观,会影响效率。

     3,

    as可写可不写。 

    4,

     

     不能用别名去查重。

    2,条件查询:

     

     

    案例:

    1, 

     2,

     4,

     

     不能混合使用关键字。

    6,

     7,

     

     

     between后面接最小值,and后面接最大值。

     9,

     10,

     11,查询身份证号第一位是9的员工信息

     

     3,聚合函数:

    1)将一列数据作为一个整体,进行纵向计算。

    2)常见聚合函数:

    3)语法:

     

     案例:

     注意: null值不参与所有聚合函数运算。

    mysql技术文档 1.基础篇
    pdf 0星 超过10%的资源 717KB
    下载

    1,

    2,自动保留四位小数 3,

     5,

     4,分组查询:

     where与having区别
    执行时机不同: where是分组之前进行过滤,不满足where条件,不参与分组;而having是分组之后对结果进行过滤。

    判断条件不同: where不能对聚合函数进行判断,而having可以。

     案例:

    1, 

    3, 

     注意
    ●执行顺序: where >聚合函数> having。
    ●分组之后,查询的字段一般为聚合函数和分组字段,查询其他字段无任何意义。

     5,排序查询:

     排序方式
    ASC:升序(默认值)
    DESC:降序

    注意:如果是多字段排序,当第一个字段值相同时,才会根据第二个字段进行排序。

    案例:

    1, 3,

     6,分页查询:

     注意
    ●起始索引从0开始,起始索引= (查询页码-1) *每页显示记录数。
    ●分页查询是数据库的方言,不同的数据库有不同的实现,MySQL中是LIMIT。
    ●如果查询的是第一页数据,起始索引可以省略,直接简写为limit 10。

     案例:

    1, 

    2, 

    习题:

    答案:

    7,执行顺序:

     验证!!!!

    七,DCL(数据控制语言)--Data Control Language

    用来管理数据库用户,控制数据库访问权限。

     主要是管理两个方面。

    1,哪些用户可以访问该数据库服务器。(用户管理)

    2,该用户可以访问哪些数据库。(权限控制)

    1,用户管理:

     案例:

     注意:
    ●主机名可以使用%通配。
    ●这类SQL语句开发人员操作的比较少,主要是DBA ( Database Administrator 数据库管理员)使用。

     

     2,权限控制:

     还想知道更多,就去查官方文件。

     

    无任何权限,仅仅是能登录数据库,连接数据库而已。

     

     

     用命令行查看时,要先退出,再进去查看。不然的话,权限仍然未变。

     注意:
    ●多个权限之间,使用逗号分隔
    ●授权时,数据库名和表名可以使用*进行通配,代表所有。

  • 相关阅读:
    LeetCode50天刷题计划第二季(Day 31 — 两数之和 II - 输入有序数组(11.10-11.20)分数到小数(11.30-12.30)
    [《命如草贱》偶感小记]2013-2-17
    loT行业生死竞速:Aqara绿米得用户得天下
    Java 基于Graphics2D 实现海报(支持自定义颜色,背景,logo,贴图)
    pip安装sentence transformer失败原因解析
    Serverless Devs 进入 CNCF 沙箱,成首个入选的 Serverless 工具项目
    【计网】物理层
    字节跳动Java实习面试题目大全
    C++之二叉搜索树详解
    读书笔记之C Primer Plus 4
  • 原文地址:https://blog.csdn.net/m0_63309778/article/details/125823723
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号