关于《MySQL 必知必会》的学习5

来源:互联网 发布:sql创建表格语句 编辑:程序博客网 时间:2024/06/17 13:42

        前面的学习中,大部分的篇幅都是在学习SELECT语句(数据库最重要的也最常用的语句),而从今天开始的学习将是一些其它方面的东西,像数据的操作,表的操作这部分是相对比较容易的,但是后面的从22章视图的学习开始便让我感觉进入了另一个境界,本人天资不够啊,在解理上有一点吃力,而且有些地方感觉没有真正的弄懂。路漫漫其修远兮,吾将上下而求索。


第19章:数据插入

        数据的插入算是数据库常用的操作之一,之前几篇学习中,已经初步尝试了数据的插入操作,也即是 INSERT 语句。由于是比较熟悉的操作,所以下面只列出一些平常没有注意但是却该注意的地方 。

INSERT基本句型:

INSERT INTO test (user_id,user_name,user_add)VALUES(NULL,'LI Si','Shanghai');

1、INSERT操作必须提供的每个例一个值,如果没有提供列则必须给表中每个列一个值,一般不提倡不提供列的情况,因为这样你可以会漏了给某一个列一个值,或者是给值的顺序颠倒了这样都会产生错误,而且在以后的使用中,如果表的结构发生了变化,则你的插入语句就全部不能用了,得重写,所以INSERT语句一般都要提供列

2、由于INSERT语句是比较耗时的操作,尤其是需要更新索引时,所以在多用户同时对数据库发出请求的时候,如果同时有SELECT请求,而且SELECT比较重要,那就有必要降低一下INSERT语句的优先级,做法在INSERT INTO 之间添加关键字 LOW_PRIORITY,即如:INSERT  LOW_PRIORITY INTO

(这个方法适用于后面的更新和删除操作

3、INSERT 是插入一个行到一个表中,如果想插入多个行的话,如果重复的使用INSERT 语句那效率就会很低,这时我们可以使用之前我插入数据的句式

INSERT INTO test() VALUES(),(),();
多行数据用括号括起,然后不同行数据之间用逗号隔开,最后用分号结束。

4、INSERT 语句除了可以手动插入数据,还可以把SELECT查询语句得到的结果插入表中

INSERT INTO test(a,b,c)SELECT a,b,cFROM xxxx;
当然其列名可以不同,但是一定要一一对应,而且保证数据类型相同。


第20章:更新和删除数据

        更新操作(UPDATE)和删除操作(DELETE)也是比较容易掌握的操作,但是由于数据库是没有返回按钮的,改了就改了,删了就删了,没得回退,所以在使用之前一定要先想清楚语句的操作范围和准确性。

UPDATE 基本句型:

UPDATE testSET user_name='Wang Wu'WHERE user_name='Li SI';
Tips:在UPDATE中可以更新多个列的内容,只要在SET后面加上“列=值”的对应关系,多个更新之间用逗号隔开。有时多个更新之中如果有一个出错,那么MySQL会提示错误并语句中之前的更新还原,如果你不想它因为错误而停止执行和还原,那可以在UPDATE 之后加上关键字 IGNORE,这样也MySQL会忽略错误继续执行。

DELETE 基本句型:

DELETE FROM testWHERE user_name='Wang Wu';
Tips:DELETE用来删除行或者是表,在进行删除操作的时候一定要记得指定条件,否则删错很悲剧。而要清空表的话推荐使用TRUNCATE TABLE语句,因为TRUCATE TABLE是把整个表删除了之后重新创建,效率比用DELETE一条一条删除高得


第21章:创建和操纵表

        表的创建之前也陆陆续续的学习了一些,这一节中也是有几个点要注意。

建表基本语句:

CREATE TABLE example(id   int         NOT NULL AUTO_INCREMENT,name varchar(20) NOT NULL,age  int         NOT NULL DEFAULT 10,PRIMARY KEY (id))ENGINE=InnoDB;

上面的语句都比较熟悉了,其中的DEFAULT 10,是说如果在插入时没有提供值的话,那就默认为10。

更新表: ALTER TABLE 语句

一般来说表都是创建之初就计划好表的结构了,在之后是不应该被更新的,但有时确时的需要的话,那对于表的更新也要小心操作。

给表添加一个列

ALTER TABLE testADD age int;

删除表中的某列

ALTER TABLE testDROP COLUMN age;

删除表使用DROP TABLE子句:

DROP TABLE test;

重命名表使用RENAME TABLE子句:

RENAME TABLE test TO example;


原创粉丝点击