当前位置: 首页 > news >正文

MySQL学习(DDL,DML,DQL)基本语法总结

DDL

  • 使用某个数据库
use world;
  • 展示表
show tables;
  • 创建表
 create table student(id int,name varchar(10),age int,gender varchar(10));
  • 删除表
drop table student; 
  • 修改表结构
  1. 查看表结构
  desc student;
  1. 添加列
  alter table student add dept varchar(10);
  1. 修改列名和类型
  alter table student change name st_name varchar(10);
  1. 删除列
  alter table student drop dept;
  1. 修改表名
  rename table student to st;

DML

  • 数据操作
  1. 插入数据
insert into student values(1, '鲁思豪', 21, '男'), (2, '撒刀锋战士', 18, '男'), (3, '发送端', 17, '女'), (4, '问啊发大水', 38, '男'), (5, '雨课堂', 27, '女'), (6, '当然土豪', 5, '女'), (7, '首都儿', 25, '女'), (8, '饿死认同感', 24, '男'), (9, '散热通过', 31, '女'), (10, '色让他', 22, '男'); 
  1. 删除数据(id小于4的数据)
  delete from student where id < 4;
  1. 更新数据
  update student set name = '谢谢小星星' where id = 4;
  • 约束
  1. 主键约束(primary key) PK: 唯一加非空
    创建时加上:[constraint pk1] primary key(字段1,字段2)
    创建好后,使用
ALTER TABLE student ADD PRIMARY KEY (id);

删除主键约束:

ALTER TABLE student DROP PRIMARY KEY;
  1. 自增长约束(auto_increment): 实现主键的自增长
    在创建表时在primary key后加auto_increment
    设置开始值:在create的括号后加auto_increment = min, 或在创建表结束后使用ALTER TABLE student auto_increment = min
    delete删除数据后,自增长从最后一个值基础上增长,turncate删除数据后,自增长从默认开始值增长
  2. 非空约束(not null)
    – 创建表时加not null,或
 ALTER TABLE student MODIFY name VARCHAR(10) NOT NULL;

删除约束

ALTER TABLE student MODIFY name VARCHAR(10);
  1. 唯一性约束(unique)
    创建表时加unique, 或
ALTER TABLE student ADD CONSTRAINT unique_pn unique(id); 

删除唯一约束

ALTER TABLE student DROP INDEX unique_pn;
  1. 默认约束(default)
    创建表时加default ‘默认值’,或
ALTER TABLE student MODIFY dept VARCHAR(10) DEFAULT 'sdas';

删除默认约束

 ALTER TABLE student MODIFY dept VARCHAR(10) DEFAULT NULL;
  1. 零填充约束(zerofill): 插入数据是,当该字段的长度小于定义长度时,会在该值前面补0,zerofill默认为int(10)
    创建表时加zerofill
    删除零填充约束:ALTER TABLE student MODIFY ‘字段’

DQL

  • 查询数据
select id, name from student;
  • 别名
	-- 表别名SELECT * FROM student AS p;-- 列别名SELECT id AS '编号', name AS '名字' FROM student;
  • 去掉重复值
    SELECT DISTINCT age FROM student;SELECT DISTINCT * FROM student;
  • 运算查询
    SELECT name, age +10 FROM student;
  • 过滤
    select * from student where age > 20;
  • 模糊匹配
    SELECT * FROM student where name LIKE '%发%'; -- %匹配任意字符SELECT * FROM student where name LIKE '_思%'; -- _匹配任意字符
  • least和greatest
    SELECT LEAST(10, 5, 20) AS min_number;  -- 最小值SELECT GREATEST(10,20,30) AS max_number;  -- 最大值
  • 分组聚合
select gender, avg(age), sum(age), max(age), min(age), count(*) from student group by gender; -- 分组后的结果筛选  havingSELECT gender, avg(age), sum(age), max(age), min(age), count(*) FROM student GROUP BY gender HAVING AVG(age) > 22;
  • 排序
    select * from student where age > 20 order by age asc;select * from student where age > 20 order by age desc;
  • 分页
    select * from student limit 5; # 限制取5条数据select * from student limit 9, 5; # 跳过10条取5条数据
  • INSERT INTO SELECT语句
    INSERT INTO student SELECT * FROM stu;INSERT INTO student(id, name, age) SELECT id, name, age FROM stu;
  • 正则表达式
    -- ^ 在开头进行匹配SELECT 'abcdefg' REGEXP '^a'; -- 1-- $ 在结尾匹配SELECT 'grfdgsrte' REGEXP 'e$'; -- 1-- . 匹配任意单个字符(除了换行符)SELECT 'asdasf' REGEXP '.s';  -- 1SELECT 'asdasf' REGEXP 'a.';  -- 1SELECT 'asdasf' REGEXP '.f';  -- 1-- [...] 匹配括号内任意单个字符SELECT 'zsfrsdfr' REGEXP '[abc]'; -- 0SELECT 'faredfarews' REGEXP '[ared]'; -- 1-- [^...] 匹配括号内任意字符之外的字符SELECT 'a' REGEXP '[^abc]'; -- 0SELECT 'x' REGEXP '[^abc]'; -- 1SELECT 'abc' REGEXP '[^a]'; -- 1-- a* 匹配0个或多个a,包括空字符串,可以作为占位符用,有没有指定字符都可以匹配到数据SELECT 'stab' REGEXP '.ta*b'; -- 1SELECT 'stb' REGEXP '.ta*b';  -- 1SELECT '' REGEXP 'a*'; -- 1-- a+ 匹配1个或多个a,不包括空字符串SELECT 'stab' REGEXP '.ta+b'; -- 1SELECT 'stb' REGEXP '.ta+b';  -- 0SELECT '' REGEXP 'a+'; -- 0-- a? 匹配0个或1个aSELECT 'stab' REGEXP '.ta?b'; -- 1SELECT 'stb' REGEXP '.ta?b';  -- 1SELECT 'staab' REGEXP '.ta?b'; -- 0-- a1|a2 匹配a1或a2SELECT 'a' REGEXP 'a|b';  -- 1SELECT 'bc' REGEXP 'a|b';  -- 1SELECT 'c' REGEXP 'a|b';  -- 0-- a{m} 匹配m个aSELECT 'abbba' REGEXP 'ab{3}a'; -- 1SELECT 'abbba' REGEXP 'ab{4}a'; -- 0-- a{m,} 匹配m个或更多aSELECT 'abbbbbbba' REGEXP 'ab{2,}a'; -- 1-- a{m, n} 匹配m到n个aSELECT 'abbbbba' REGEXP 'ab{2,7}a'; -- 1SELECT 'aba' REGEXP 'ab{2,7}a';  -- 0 
http://www.lryc.cn/news/431363.html

相关文章:

  • JAVA学习-练习试用Java实现“单词反转”
  • 【MySQL】深圳大学数据库实验一
  • 接口测试 —— 如何设计高效的测试用例!
  • linux top命令介绍以及使用
  • 必备资源!精选大模型领域100篇必读论文,赶紧加入收藏夹!
  • 基于STM32设计的防盗书包(华为云IOT)(216)
  • 2024高教社杯全国大学生数学建模竞赛C题原创python代码
  • Java基础 - 14 - Java高级技术
  • glsl着色器学习(六)
  • 毒枸杞事件启示录:EasyCVR视频AI智能监管方案如何重塑食品卫生安全防线
  • git进阶·团队开发的时候为何要创建临时分支来修复bug
  • Unity 性能优化工具收集
  • linux下的Socket网络编程教程
  • 华为人工智能重要服务总结
  • 涉嫌欺诈者利用机器人通过播放AI创作的音乐赚取1000万美元版税
  • k8s helm
  • KMP 详解
  • go语言并发编程-超详细mutex解析
  • VirtualBox Debian 自动安装脚本
  • 最好的开放式耳机?五款红榜开放式耳机推荐!
  • 线性代数之线性方程组
  • 速盾:怎么查看是否使用cdn服务?
  • 828华为云征文|采用Flexus云服务器X实例部署RTSP直播服务器
  • Spring Cloud Gateway(二)
  • docker 简易入门
  • 【看雪-注册安全分析报告】
  • 记录一个前端学习小组的收集的模版
  • Rk3588 Android12 AIDL 开发
  • 两个长整数字符串求和(不允许使用ES6+)
  • 11 Java 方法引用、异常处理、Java接口之函数式编程(接口知识补充Function<T,R>、BiFunction<T, U, R>和自定义泛型接口)