一:在Mysql控制台创建数据表
create table student
(
stuid int primary key auto_increment,
stuName varchar(40) not null
);
这样就创建了一个studeng表,auto_increment是自增列的意思
插入数据
insert into student value(10,'wangwu');
insert into student(stuName) value('maliu');
也可以指定插入自增列的值,指定插入值之后,再自增插入,则继续自增。
添加删除字段
alter table student drop age;
添加删除唯一约束
alter table student drop index UN_Name;
二:修改、删除数据记录(DELETE\UPDATE)
除去某些记录或更改它们的内容。DELETE 和 UPDATE 语句令我们能做到这一点。
用update修改记录
UPDATE tbl_name SET 要更改的列
WHERE 要更新的记录
这里的 WHERE 子句是可选的,因此如果不指定的话,表中的每个记录都被更新。
例如,在pet表中,我们发现宠物Whistler的性别没有指定,因此我们可以这样修改这个记录:
mysql> update pet set sex=’f’ where name=” Whistler”;
用delete删除记录
DELETE 语句有如下格式:
DELETE FROM tbl_name WHERE 要删除的记录
WHERE 子句指定哪些记录应该删除。它是可选的,但是如果不选的话,将会删除所有的记录。这意味着最简单的 DELETE 语句也是最危险的。
这个查询将清除表中的所有内容。一定要当心!
为了删除特定的记录,可用 WHERE 子句来选择所要删除的记录。这类似于 SELECT 语句中的 WHERE 子句。
mysql> delete from pet where name=”Whistler”;
可以用下面的语句清空整个表:
mysql>delete from pet;
三:数据表插入行记录(INSERT)
使用INSERT语句插入新数据
语法:INSERT [INTO] tbl_name [(col_name,...)] VALUES (pression,...),…
INSERT [INTO] tbl_name SET col_name=expression, ...
让我们开始利用 INSERT 语句来增加记录,这是一个 SQL 语句,需要为它指定希望插入数据行的表或将值按行放入的表。INSERT 语句具有几种形式:
可指定所有列的值:
例如:
shell> mysql –u root –p mysql> use mytest; mysql> insert into worker values(“tom”,”tom@yahoo.com”); |
“INTO”一词自 MySQL 3.22.5 以来是可选的。(这一点对其他形式的 INSERT 语句也成立。)VALUES 表必须包含表中每列的值,并且按表中列的存放次序给出。(一般,这就是创建表时列的定义次序。如果不能肯定的话,可使用 DESCRIBE tbl_name 来查看这个次序。)
使用多个值表,可以一次提供多行数据。
Mysql>insert into worker values(‘tom’,’tom@yahoo.com’),(‘paul’,’paul@yahoo.com’);
有多个值表的INSERT ... VALUES的形式在MySQL 3.22.5或以后版本中支持。
可以给出要赋值的那个列,然后再列出值。这对于希望建立只有几个列需要初始设置的记录是很有用的。
例如:
mysql>insert into worker (name) values (‘tom’);
自 MySQL 3.22.5 以来,这种形式的 INSERT 也允许多个值表:
mysql>insert into worker (name) values (‘tom’), (‘paul’);
在列的列表中未给出名称的列都将赋予缺省值。
自 MySQL 3.22 .10 以来,可以 col_name = value 的形式给出列和值。
例如:
mysql>insert into worker set name=’tom’;
在 SET 子句中未命名的行都赋予一个缺省值。
使用这种形式的 INSERT 语句不能插入多行。
一个expression可以引用在一个值表先前设置的任何列。例如,你能这样:
mysql> INSERT INTO tbl_name (col1,col2) VALUES(15,col1*2);
但不能这样:
mysql> INSERT INTO tbl_name (col1,col2) VALUES(col2*2,