1、创建表格时添加: create table table1(id int auto_increment primary key,…)
成都创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站建设、网站建设、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的冀州网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!
2、创建表格后添加: alter table table1 add id int auto_increment primary key 自增字段,一定要设置为primary key.
附:mysql 中的alter table mysql alter table employee change depno depno int(5) not null;
加索引 mysql alter table 表名 add index 索引名 (字段名1[,字段名2 …]);
例子: mysql alter table employee add index emp_name (name);
加主关键字的索引 mysql alter table 表名 add primary key (字段名);
例子: mysql alter table employee add primary key(id);
加唯一限制条件的索引 mysql alter table 表名 add unique 索引名 (字段名);
例子: mysql alter table employee add unique emp_name2(cardnumber);
查看某个表的索引 mysql show index from 表名; 例子: mysql show index from employee;
删除某个索引 mysql alter table 表名 drop index 索引名; 例子: mysqlalter table employee drop index emp_name;
修改表:增加字段:mysql ALTER TABLE table_name ADD field_name field_type;
查看表:mysql SELECT * FROM table_name;
修改原字段名称及类型:mysql ALTER TABLE table_name CHANGE old_field_name new_field_name field_type;
删除字段:ALTER TABLE table_name DROP field_name;
前面介绍了如何对表数查询、更新、删除,本小节介绍如何在查询、更新、删除操作加上 WHERE 条件约束,使这些语句的操作更加准确,满足业务需求。WHERE 条件的操作符类型有如下:
以 teacher 表为例,查询年龄大于 18 的教师信息:
执行结果如下图:
再比如使用 LIKE 模糊查询身份证号以 020X 结尾的教师信息:
执行结果如下图:
[图片上传失败...(image-f53914-1648379120315)]
以 teacher 表为例,查询年龄大于 18 和 教师姓氏 王 的教师信息:
执行结果如下图:
[图片上传失败...(image-7dbeda-1648379120315)]
以 teacher 表为例,查询年龄大于 25 或 教师姓氏 王 的教师信息:
执行结果如下图:
以 teacher 表为例,将 age 在 20 和 30 之间的教师身份证设置为 无 :
为了演示方便,我们先给 teacher 表增加一个字段 email :
执行结果如下图:
清空表数据:
然后往 teacher 表插入几条测试数据:
然后查询 email 为 NULL 的教师信息结果集:
执行结果如下图:
本小节介绍了如果在查询、更新语句后面加上 WHERE 条件约束,需要注意的是当使用 、 、这样的操作符和空值比较的时候,NULL值与任何其它值的比较(即使是NULL)永远不会为 TRUE ,例如要查询 name 为 NULL 的结果集要写成 name IS NULL ,而不能使用 name=NULL 。
4.4.7添加约束
语句格式:ALTER TABLE 表名ADD CONSTRAINT 约束名 约束类型(字段名)
上面语句格式中,“表名”指定要添加约束的是哪个表,“ADD CONSTRAINT”表示要在表中增加约束,其后的“约束名”是拟增加约束的名字,“约束类型”是拟增加约束的类型,其后括号里的“字段名”是指约束是在哪一个字段上建立起来的。
下面截图中的“ALTER TABLE”语句在t_dept表中新增加了一个约束名为unidept的约束,它是在对字段deptno进行的唯一性约束。
试试
CREATE TABLE user
(
id INT not null AUTO_INCREMENT,
name varchar(100) not null,
password varchar(100) not null,
PRIMARY KEY (id),
UNIQUE KEY (name)
);
其实这个和你的mysql版本也有关系,语法会不一样
你可以下载个图形化界面mysqlbrowser,然后通过图形化方式生成语句就知道了
选中你要改的表---打开后选中你要添加约束的列--右键--选增加约束---写[1,0]就好了
个人觉得EMS的SQL MANAGER FOR MYSQL更好用些
这是一项新功能,用于指定在插入或更新到一行之前检查值的条件。如果表的任何行的搜索条件的结果为 FALSE,则约束可能返回错误(但如果结果为 UNKNOWN 或 TRUE,则约束不会返回错误)。此功能开始在 MySQL 8.0.16 上运行,在以前的版本中,我们可以创建它,但它不起作用,这意味着支持语法,但不起作用。要牢记的使用规则:
AUTO_INCREMENT 自增列不允许使用
引用另一个表中的另一列不允许使用
存储的函数和用户定义的函数不允许使用
存储过程和函数参数不允许使用
子查询不允许使用
在外键中用于后续操作(ON UPDATE,ON DELETE)的列不允许使用
为下一条语句 INSERT,UPDATE,REPLACE,LOAD DATA 和 LOAD XML 评估此次监测。此外,还会为 INSERT IGNORE,UPDATE IGNORE,LOAD DATA…IGNORE 和 LOAD XML…IGNORE 评估此监测约束。对于这些语句,如果约束的评估结果为 FALSE,则会发生警告。插入或更新被跳过。
我们可以使用此功能在表中添加更多的逻辑,但是根据我以前作为程序员的经验,我不建议在表中添加逻辑,因为除非您无法访问应用程序代码,否则很难找到或调试错误。