Mysql

Mysql是最流行的关系型数据库管理系统,在WEB应用方面MySQL是最好的RDBMS

主键:主键是唯一的。一个数据表中只能包含一个主键。你可以使用主键来查询数据。
外键:外键用于关联两个表.。

1.数据以表格的形式出现
2.每行为各种记录名称
3.每列为记录名称所对应的数据域
4.许多的行和列组成一张表单
5.若干的表单组成database

具体连接参照node连接数据库笔记,使用navicat。

这里主要记录需要重点掌握的:

数值类型;INTEGER DECIMAL(M,D) NUMERIC FLOAT DOUBLE
日期和时间类型:DATETIME(YYYY-MM-DD HH:MM:SS混合)、DATE(YYYY-MM-DD)、
TIMESTAMP、TIME(HH:MM:SS)和YEAR(YYYY)
字符串类型:CHAR(定长)、VARCHAR(变长)、TEXT(长文本数据)

  • 如果你不想字段为 NULL 可以设置字段的属性为 NOT NULL
  • AUTO_INCREMENT定义列为自增的属性,一般用于主键,数值会自动加1。
  • PRIMARY KEY关键字用于定义列为主键。 您可以使用多列来定义主键,列间以逗号分隔。

show databases 显示数据库 use 某个库 show tables 显示有什么表
CREATE TABLE table_name;
DROP TABLE table_name ;
修改:修改数据表使用 RENAME 子句来实现。
ALTER TABLE testalter_tbl RENAME TO alter_tbl;
修改字段的默认值:
ALTER TABLE testalter_tbl ALTER i SET DEFAULT 1000;
修改字段类型及名称:把字段 c 的类型从 CHAR(1) 改为 CHAR(10)
ALTER TABLE testalter_tbl MODIFY c CHAR(10);
使用 ADD 子句来向数据表中添加列
ALTER TABLE testalter_tbl ADD i INT;
使用了 ALTER 命令及 DROP 子句来删除以上创建表的 i 字段:
ALTER TABLE testalter_tbl DROP i;

查询
SELECT column_name,column_name FROM table_name [WHERE Clause] [OFFSET M ][LIMIT N]

插入
INSERT INTO table_name ( field1, field2,...fieldN ) VALUES ( value1, value2,...valueN );
INSERT INTO table_name (field1, field2,...fieldN) VALUES (valueA1,valueA2,...valueAN),(valueB1,valueB2,...valueBN),(valueC1,valueC2,...valueCN)......;

Where子句:
你可以在 WHERE 子句中指定任何条件。
你可以使用 AND 或者 OR 指定一个或多个条件。
WHERE 子句也可以运用于 SQL 的 DELETE 或者 UPDATE 命令。

更新
UPDATE table_name SET field1=new-value1, field2=new-value2 可以同时更新一个或多个字段。
[WHERE Clause] 可以在 WHERE 子句中指定任何条件。

删除
DELETE FROM table_name [WHERE Clause]

  • 没有指定 WHERE 子句,MySQL 表中的所有记录将被删除。

Like子句及通配符:
SELECT field1, field2,...fieldN FROM table_name WHERE field1 LIKE condition1 [AND [OR]] filed2 = 'somevalue'

  • %表示任何字符出现任意次数
  • _表示匹配单个字符
  • [ ] 用来指定一个字符集
  • Mysql拼接字符串使用 ‘ ’ 单引号括起来

UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中。多个 SELECT 语句会删除重复的数据。
select ... UNION [ALL | DISTINCT] select ...

排序:
SELECT field1, field2,...fieldN table_name1, table_name2... ORDER BY field1, [field2...] [ASC [DESC]]

  • 可以使用任何字段来作为排序的条件,从而返回排序后的查询结果。
  • 可以设定多个字段来排序。顺序从左到右
  • 使用 ASC 或 DESC 关键字来设置查询结果是按升序或降序排列

分组:
GROUP BY 语句根据一个或多个列对结果集进行分组。
在分组的列上我们可以使用 COUNT, SUM, AVG,等函数,所以一般有聚集函数都有分组
SELECT column_name, function(column_name) FROM table_name WHERE column_name operator value GROUP BY column_name;

过滤分组:所有类型的where子句都可以用having代替,区别在于where过滤行,having过滤分组。
一般使用group by子句时,应该也给出order by子句。

联结:
简单联结:通过where子句将两个表中相同属性列关联起来
如:where Vendors.vend_id = Products.vend_id 多个表则用and拼在一起

高级联结:
自联结:select c1.cust_name, c1.cust_contact from Customers as c1 , Customers as c2 where c1.cust_name = c2.cust_name and c2.cust_contact = 'Jim'

  • INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录。
  • LEFT JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录。
  • RIGHT JOIN(右连接):用于获取右表所有记录,即使左表没有对应匹配的记录。
Select Customers.cust_id,Orders.order_num
From Customers inner join Orders
On Customers.cust_id = Orders.cust_id;

Select Customers.cust_id,Orders.order_num
From Customers left join Orders
On Customers.cust_id = Orders.cust_id;

Select Customers.cust_id,Orders.order_num
From Customers right join Orders
On Customers.cust_id = Orders.cust_id;

NULL值:

  • IS NULL: 当列的值是 NULL,此运算符返回 true。
  • IS NOT NULL: 当列的值不为 NULL, 运算符返回 true。
  • NULL 值与任何其它值的比较(即使是 NULL)永远返回 false,即 NULL = NULL 返回false
  • <=>: 比较操作符(不同于=运算符),当比较的的两个值为 NULL 时返回 true

补充正则:
[...] 字符集合。匹配所包含的任意一个字符
[^...] 负值字符集合。匹配未包含的任意字符
. 匹配除 "\n" 之外的任何单个字符
*匹配前面的子表达式零次或多次
^ 匹配输入字符串的开始位置
$ 匹配输入字符串的结束位置
+匹配前面的子表达式一次或多次
{n,m} m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次。

查找name字段中以'st'为开头的所有数据:
SELECT name FROM person_tbl WHERE name REGEXP '^st';
查找name字段中以'ok'为结尾的所有数据:
SELECT name FROM person_tbl WHERE name REGEXP 'ok$';

Mysql事务处理

1、事务的原子性:一组事务,要么成功;要么撤回。
2、稳定性 :有非法数据(外键约束之类),事务撤回。
3、隔离性:事务独立运行。一个事务处理后的结果,影响了其他事务,那么其他事务会撤回。事务的100%隔离,需要牺牲速度。
4、可靠性:软、硬件崩溃后,InnoDB数据表驱动会利用日志文件重构修改。可靠性和高速度不可兼得, innodb_flush_log_at_trx_commit 选项 决定什么时候吧事务保存到日志里。

事务控制语句:
BEGIN或START TRANSACTION;显式地开启一个事务;
COMMIT;也可以使用COMMIT WORK,不过二者是等价的。COMMIT会提交事务,并使已对数据库进行的所有修改称为永久性的;
ROLLBACK;有可以使用ROLLBACK WORK,不过二者是等价的。回滚会结束用户的事务,并撤销正在进行的所有未提交的修改;
SAVEPOINT identifier;SAVEPOINT允许在事务中创建一个保存点,一个事务中可以有多个SAVEPOINT;
RELEASE SAVEPOINT identifier;删除一个事务的保存点,当没有指定的保存点时,执行该语句会抛出一个异常;
ROLLBACK TO identifier;把事务回滚到标记点;
实例:

mysql> begin;  # 开始事务
Query OK, 0 rows affected (0.00 sec)
mysql> insert into runoob_transaction_test value(5);
Query OK, 1 rows affected (0.01 sec)
mysql> insert into runoob_transaction_test value(6);
Query OK, 1 rows affected (0.00 sec)
mysql> commit; # 提交事务
Query OK, 0 rows affected (0.01 sec)

mysql> begin;    # 开始事务
Query OK, 0 rows affected (0.00 sec)
mysql>  insert into runoob_transaction_test values(7);
Query OK, 1 rows affected (0.00 sec)
mysql> rollback;   # 回滚
Query OK, 0 rows affected (0.00 sec)

补充: INSERT IGNORE INTO与INSERT INTO的区别就是INSERT IGNORE会忽略数据库中已经存在的数据,如果数据库没有数据,就插入新的数据,如果有数据的话就跳过这条数据。

所谓SQL注入,就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令。
我们永远不要信任用户的输入,我们必须认定用户输入的数据都是不安全的,我们都需要对用户输入的数据进行过滤处理。
可以通过正则表达式,或限制长度;对单引号和 双"-"进行转换等。
永远不要使用管理员权限的数据库连接,为每个应用使用单独的权限有限的数据库连接。

导出数据:可以使用SELECT...INTO OUTFILE语句来简单的导出数据到文本文件上。
SELECT * FROM runoob_tbl INTO OUTFILE '/tmp/tutorials.txt';

导入数据:LOAD DATA INFILE语句来插入数据。 以下实例中将从当前目录中读取文件 dump.txt ,将该文件中的数据插入到当前数据库的 mytbl 表中。
LOAD DATA LOCAL INFILE 'dump.txt' INTO TABLE mytbl;

文本处理函数:LENGTH() LOWER() UPPER()
聚集函数:AVG() COUNT() MAX() MIN() SUM()

视图是虚拟的表:只包含使用时动态检索数据的查询。
主要作用是保护基础数据,简化数据处理。
create view pc as select........

完全限定列名即表示字段前面要指明表名,这样不容易混淆,可读性好。

补充子查询:从内向外处理,但是性能低。
select id from orders where or_num in (select or_num from orderitems where prod_id = 'R01')

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,186评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,858评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,620评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,888评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,009评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,149评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,204评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,956评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,385评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,698评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,863评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,544评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,185评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,899评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,141评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,684评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,750评论 2 351

推荐阅读更多精彩内容

  • 什么是数据库? 数据库是存储数据的集合的单独的应用程序。每个数据库具有一个或多个不同的API,用于创建,访问,管理...
    chen_000阅读 4,033评论 0 19
  • 这一篇最主要是记录下命令,方便以后查找 使用Mysql 创建数据库 create database mysql_t...
    Treehl阅读 576评论 0 0
  • 1.表中的任何列都可以作为主键, 只要它满足以下条件:任意两行都不具有相同的主键值;每一行都必须具有一个主键值( ...
    Cherryjs阅读 650评论 0 0
  • 1.简介 mysql是一个快速的、多线程的、多用户的、支持健壮SQL的数据库管理系统(DBMS)。mysql可以应...
    at小宇阅读 912评论 0 2
  • Canvas 是HTML5的核心技术技术所在,用于在网页上进行绘制图形,自身并不具备绘制功能,canvas须依靠j...
    王_建峰阅读 811评论 1 2