关于《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;
- 关于《MySQL 必知必会》的学习5
- 关于《MySQL 必知必会》的学习1
- 关于《MySQL 必知必会》的学习2
- 关于《MySQL 必知必会》的学习3
- 关于《MySQL 必知必会》的学习4
- 关于《MySQL 必知必会》的学习6
- 关于MYSQL的Replication的初步学习
- 关于MYSQL的Replication的初步学习
- 关于MySQL的一点学习纪录
- 关于mysql存储过程的学习
- 关于MavenSpark framework和MYsql的学习
- 关于mysql的视图部分的学习与总结
- 关于mysql的存储过程的学习与总结
- 关于Linux下的mysql安装及配置学习笔记
- 关于MySQL Command Line Client的一些专有指令学习
- MySQL学习笔记(五):关于max_allowed_packet错误的问题
- MySQL学习之——关于or的索引问题
- 关于MySQL应该学习的6件事
- Linux安装Oracle 10g
- Windows 7和Vista的休眠功能启用和禁止休眠
- Android真机调试环境搭建(网口)
- Silverlight实战示例1(兼集合属性的妙用)--整体架构
- 疯狂的Web应用开源项目
- 关于《MySQL 必知必会》的学习5
- django使用token认证authenticate
- void fun() const{}; const void fun(){}; 和void const fun(){}; 的区别?
- JBPM流程部署之部署数据表分析
- ubuntu10.10优化设置和技巧
- [观点]重构代码的7个阶段
- MySQL集群配置
- [评论]为什么谷歌要执行严格的代码编写规范
- 非常难察觉的声明引用指向错误