MySQL纯天然新手小白笔记 【v1】

MySQL学习笔记 v1版 (以后再修改的更好看些)


数据库管理系统:DBMS,MySQL是一种DBMS。
缺点:并不总是支持其他DBMS提供的功能和特性。
能够适应不断增加的工作量而不失败,叫做可伸缩性。

tips

  1. 命令用\g或;结束,只按enter不执行命令。
  2. 必须先use数据库,才能读取其中数据。
  3. update/delete可同时更新/删除多表中的数据。
  4. LIMIT 5,5指示MySQL返回从行5开始的5行。
  5. IN(,)和OR功能一致。
  6. 头尾空格会干扰通配符匹配,可以在前面后面都加上%。更好的方式是使用函数去头尾空格。注意! LIKE ‘%jet%’中用的是单引号不是反引号。
  7. 通配符可以匹配任何东西除了NULL。
  8. LIKE 与 REGEXP,LIKE 匹配整个,若文本在列值中出现,LIKE将找不到;而REGEXP在列值内进行匹配,可以找到。
  9. .匹配任意字符,因此每行都会被检索出来,想要检索到特殊字符.的话,要使用REGEXP ‘\.’
  10. ?匹配它前面的任何字符的0次或1次,等同于{0,1}
  11. 多数DBMS使用+或| |来实现拼接,而MySQL需要使用Concat()函数来实现。转换时应注意。
  12. 如果确定使用函数,要保证做好代码注释。
  13. SUM()函数忽略列值为NULL的行。
  14. COUNR(DISTINCT)是不被允许的。
  15. GROUP BY子句必须出现在WHERE子句之后ORDER BY子句之前
  16. 大部分WHERE的功能HAVING都能实现,唯一的区别是:WHERE过滤行,HAVING过滤分组聚集值
  17. 应总是给出ORDER BY,这是保证数据正确排序的唯一方法。
  18. 应该保证所有联结都有WHERE子句。
  19. 创建表的时候就指定FULLTEXT等索引。导入的话,先导入所有数据,再修改表,再定义FULLTEXT等索引。
  20. 使用列的列表可使SQL代码继续有用,即使表结构发生了变化。
  21. 删除某个列的值,可以SET其为NULL。
  22. 在对UPDATE或DELETE使用WHERE前,应先使用SELECT进行测试,保证其过滤的是正确的记录。
  23. MYSQL无撤销按钮,所以一定要小心!
  24. 创建时若某一列必须要有值则指定NOT NULL。
  25. CREATE TABLE均以ENGINE=InnoDB语句结束。
  26. ALTER TABLE的一个常见用途是定义外键。
  27. 注释前面放置- -
  28. Error Code: 1046. No database selected Select the default DB to be used by double clicking出现该错误是因为没有选定数据库,先双击选中左侧数据库就ok了。

基本情况

名称描述
1、存储在表中的数据是一种类型的数据或一个清单比说说顾客的清单以及订单的清单。2、一个清单一个表。
模式关于数据库和表的布局及特性的信息。
1、一个列存储一条特定信息比如说顾客编号。2、每列都应有相应的可存储的数据类型比如说数值或字符
每行存储一个顾客的信息
主键1、一列(或一组列),该列的值可以唯一区分表中的每一行。2、可使用多个列作为主键。3、养成好习惯 主键不更新 不重用 不使用会更改的。
SQLdescription
DDL语句对数据库内部对象进行创建、删除、修改等操作。创建数据库create database dbname;删除数据库drop database dbname;创建表 create table tablename();删除表drop table tablename;修改表(几种类型以后再说)。。。
DML语句对数据库中表记录的操作,包括表记录插入、更新、删除、查询。插入记录 INSERT INTO tablename(field1,…,fieldn)VALUES(values1,…,valuesn);更新记录 UPDATE tablename SET field1=value1,…fieldn=valuen[WHERE CONDITION];删除记录 DELETE FROM tablename[WHERE CONDITION];查询记录 SELECT*FROM tablename[WHERE CONDITION]

导入SQL文件

  1. 打开workbench打开schema,起个名字。
  2. 在file文件下open script。

流程

  1. 启动服务: net start MySQL56(我的mysql名称)
  2. 找到bin位置:cd C:\。。。
  3. 请求输入密码:mysql -uroot -p(实际设置的用户名是Xuyx但是在这里还是要输入root)
  4. 输入密码:wy。。。
  5. 创建数据库:输入create database student(student为数据库名)
  6. 创建表:create table tablename(
    column_name column_type constrains,
    …,
    …)

这里写图片描述

这里写图片描述
注意!!!!!
MySQL引入反引号列名称使用的是反引号`
不然将会报错ERROR 1064 (42000)。

上图黄框中的简单的写法

create table tb_stu1(name varchar(30), sex varchar(2), birthday date)

注释

vendors表-供应商表
products表-产品表
customers表-顾客表
orders表-顾客订单
orderitems表-订单细节表
productnotes表-产品注释表

cust_id、vend_id、order_num是自动增量字段
vendors表中vend_id与products表中prod_id关联
customers表中cust_id与orders表中order_num关联
orderitems表中order_num与orders表中order_num关联
orderitems表中prod_id与products表中prod_id关联

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值