mysql数据库笔记0

一次性添加多行数据

例如:

INSERT INTO students (class_id, name, gender, score) VALUES
(1, '大宝', 'M', 87),
(2, '二宝', 'M', 81); SELECT * FROM students;
注意分号,不是逗号。

更新语句

update <表名> set 字段1=值1,字段2=值2,。。。。where。。。

1. 并且更新语句支持表达式,比如以下sql
UPDATE students SET score=score+10 WHERE score<80;
给所有低于80分的学生加10分
2. 更新语句可以没有where子句,但是没有where子句的话,会对数据中的所有数据进行更新,如果涉及到大量的数据处理的时候小心点,
3. 更新语句如果没有响应的数据更新的时候,数据库不会产生更新的。只会显示影响0行

删除语句

DELETE FROM <表名> WHERE ...;
1. 最普通的删除语句
DELETE FROM students WHERE id=1;
-- 查询并观察结果:
SELECT * FROM students;
2. 根据where子句删除并且可以删除多个数据例如:
1. DELETE FROM students WHERE id>=5 AND id<=7;
-- 查询并观察结果:
SELECT * FROM students;
3. 如果where没有匹配到数据,delete语句也不会报错,也不会有任何数据被删除
4. 特别小心的是,和UPDATE类似,不带WHERE条件的DELETE语句会删除整个表的数据:

mysql的管理

1. 通过client登录系统指令:mysql -u root -p root
1. 如果连接成功的话,会出现mysql>光标在此
2. 注意,连接的时候,此时连接的是mysql服务器,在这可以是本地的服务器,也可以是远程的服务器,远程服务器在下介绍如何连接
3. 输入exit语句来断开与mysql server的连接并回到cmd模式
4. mysql client通过tcp协议与mysql server进行连接,并且可以通过sql语句进行操作数据库
5. 如果本地机装mysql数据库,服务器也在本地,那么tcp可连接地址:127.0.0.1:3306
6. 如果是远程的服务器,并且得知mysql server的服务器ip:10.1.1.1则输入一下语句进行连接数据库
* mysql -h 10.1.1.1 -u root -p
2. 进入到数据库后的指令:《cmd的模式下,有可能打不开,原因有可
能是你的环境没有配置,所以在cmd下,输入mysql -u等消息,系统没有路径,找不到你对应的程序,解决方法:可以添加path,可以在
mysql安装目录下的lib下cmd,也可以直接通过client启动,直接输入密码即可》

	1. show databases;列出所有的数据库
2. 创建一个新的数据库:create database test;
3. 删除一个数据库:drop database test;
4. 如果对一个数据库进行操作,需要user database名
5. 如果需要对数据库中的所有表展示,show tables;
6. 查看一个表的表结构,desc 表名
7. 查看创建数据库表的时候的创建语句
1. show create table students
2. drop table students:删除表
3. 修改表,新增一列:alter table students add column birth varchar(10) not null;
4. 修改birth列,把birth列改为birthday类型改为varchar(20)
alert table students change column birth birthday varchar(20) not null
5. 删除列
alert table students drop column birthday
8. 退出mysql:exit

实用性sql语句

  1. 插入或替换:使用场景:插入一条新纪录,但如果该记录存在,就先删除原记录,在插入新纪录,使用语句replace语句,这样就不比先查询,然后在决定是否先删除再插入:

     replace into students(id,class_id,name,gender,score) values(1,1,'小明',‘f’,99)
    作用,如果id=1的记录不存在,replace语句将插入新纪录,否则,当前id=1的记录被删除,然后在插入新的记录
  2. 插入或更新

    如果我们希望插入一条新纪录,但是记录存在,就更新该记录使用INSERT INTO ... ON DUPLICATE KEY UPDATE ...语句

     	INSERT INTO students (id, class_id, name, gender, score) VALUES (1, 1, '小明', 'F', 99) ON DUPLICATE KEY UPDATE name='小明', gender='F', score=99;
    若id=1的记录不存在,INSERT语句将插入新记录,否则,当前id=1的记录将被更新,更新的字段由UPDATE指定。
  3. 插入或忽略

    如果我们希望插入一条新记录(INSERT),但如果记录已经存在,就啥事也不干直接忽略,此时,可以使用INSERT IGNORE INTO ...语句:

     INSERT IGNORE INTO students (id, class_id, name, gender, score) VALUES (1, 1, '小明', 'F', 99);
    若id=1的记录不存在,INSERT语句将插入新记录,否则,不执行任何操作。
  4. 快照

    如果想要对一个表进行快照,即复制一份当前表的数据到一个新表,可以结合CREATE TABLE和SELECT:

     -- 对class_id=1的记录进行快照,并存储为新表students_of_class1:
    CREATE TABLE students_of_class1 SELECT * FROM students WHERE class_id=1;
    新创建的表结构和SELECT使用的表结构完全一致。
  5. 写入查询结果集

    如果查询结果集需要写入到表中,可以结合INSERT和SELECT,将SELECT语句的结果集直接插入到指定表中。

例如,创建一个统计成绩的表statistics,记录各班的平均成绩:

	CREATE TABLE statistics (
id BIGINT NOT NULL AUTO_INCREMENT,
class_id BIGINT NOT NULL,
average DOUBLE NOT NULL,
PRIMARY KEY (id)
);

然后,我们就可以用一条语句写入各班的平均成绩:

INSERT INTO statistics (class_id, average) SELECT class_id, AVG(score) FROM students GROUP BY class_id;

mysql数据库笔记0的更多相关文章

  1. java连接mysql数据库8.0以上版本过程中遇到的坑

    来自:https://blog.csdn.net/u013276277/article/details/80255468 首先,我居然不能用navicat客户端连接上mysql8.0数据库报1251错 ...

  2. Mysql数据库笔记

    出错记录: 1.mysql服务启动不了,进程意外终止 1067    错误显示:can not connect to mysql server on local hosts(1061)    解决方法 ...

  3. MySQL数据库笔记总结

    MySQL数据库总结 一.数据库简介 1. 数据 所谓数据(Data)是指对客观事物进行描述并可以鉴别的符号,这些符号是可识别的.抽象的.它不仅仅指狭义上的数字,而是有多种表现形式:字母.文字.文本. ...

  4. MySQL数据库笔记六:数据定义语言及数据库的备份和修复

    1. MySQL中的函数 <1>加密函数 password(str) 该函数可以对字符串str进行加密,一般情况下,此函数给用户密码加密. select PASSWORD('tlxy666 ...

  5. MySQL数据库笔记二:数据类型及数据库操作

    三.MySQL数据库数据类型 MySQL数据库中支持多种数据类型:数值型.字符型.日期型 常用的数据类型: 1.整型 int:整形,存储整数 int(M):M表示预期值.与存储大小和数值的范围无关. ...

  6. MySQL数据库笔记一:简介及简单操作

    一.初识MySQL数据库 1.数据库的概述 <1>数据库:Database 长期存储在计算机内的,有组织的,可共享的数据集合. 存储数据的仓库.(文件) <2>数据库管理系统: ...

  7. mysql数据库-8.0安装及环境搭建

           1.MySQL8.0 For Windows zip包下载地址 https://dev.mysql.com/downloads/file/?id=476233,进入页面后点击底部&quo ...

  8. MySQL数据库8.0.15 安装教程

    第一步:安装MySQL服务 这里下载完成的是一个压缩文件,直接将里面的‘mysql-8.0.15-winx64'文件夹解压到你想要安装的路径即可,我是直接安装在C盘的. 解压完后的文件路径如下图: 在 ...

  9. MySQL数据库笔记四:MySQL的约束

    <1>概念 是一种限制,它是对表的行和列的数据做出约束,确保表中的数据的完整性和唯一性. <2>使用场景 创建表的时候,添加约束 <3>分类 1. default: ...

随机推荐

  1. linux epoll 任务队列多线程模型

    /* * *EPOLL ET 触发必须使用非阻塞,LT触发可以阻塞/非阻塞. *read 函数 非阻塞读需 忙轮寻 soket关闭返回0,循环读完数据 *如果已经读完再读read返回 -1,errno ...

  2. 能够伪装为 win 10 的 kali 体验与中文设置

    前言 作为习惯性捣鼓各类操作系统,时长也会使用 Kali 系统,之前看到有新的版本发行 传闻这个版本和之前的版本在系统界面和壁纸上都做了更新,还能一键设置 win 10 的系统界面 对此决定下载体验一 ...

  3. (一)Thread的run() 和 start() 方法

    Java多线程在实际开发中会遇到很多问题,对于这种争抢CPU时间片段的选手,我们或许有很多困惑,捉摸不透.即便如此,它也是可以被我们控制的. 最近在看Java多线程的书籍,里面有好多我曾经不怎么注意的 ...

  4. js window.onload 加载多个函数和追加函数

    平时做项目 经常需要使用window.onload, 用法如下: function func(){alert("this is window onload event!");ret ...

  5. poj-3657 Haybale Guessing(二分答案+并查集)

    http://poj.org/problem?id=3657 下方有中文版,不想看英文的可直接点这里看中文版题目 Description The cows, who always have an in ...

  6. 八、linux-mysql的mysql主从复制原理和实战

    1.mysql主从复制介绍 mysql支持单向.双向.链式级联.实时.异步复制,在复制过程中,一台服务器充当主服务器(Master),而一个或多个其它服务器充当从服务器(Slave). 复制:单向同步 ...

  7. 吴裕雄--天生自然python学习笔记:python 用pygame模块游戏开发

    游戏开发在软件开发领域占据了非常重要的位直.游 戏开发需要用到的技术相当广泛,除了多媒体.图片.动 画的处理外,程序设计更是游戏开发的核心内容. Py game 是为了让 Python 能够进行游戏开 ...

  8. MySQL的详细操作

    MySQL的详细操作 存储引擎 不同的数据应该有不同的处理机制 mysql存储引擎 Innodb:默认的存储引擎 查询速度较myisam慢 但是更安全,支持事务,行锁,外键由于以上的支持,数据更安全, ...

  9. LeetCode No.76,77,78

    No.76 MinWindow 最小覆盖子串 题目 给你一个字符串 S.一个字符串 T,请在字符串 S 里面找出:包含 T 所有字母的最小子串. 示例 输入: S = "ADOBECODEB ...

  10. C++类和对象到底是什么意思?

    C++ 是一门面向对象的编程语言,理解 C++,首先要理解类(Class)和对象(Object)这两个概念. C++ 中的类(Class)可以看做C语言中结构体(Struct)的升级版.结构体是一种构 ...