mysql 基础教程 很全

mysql 基础教程 很全一 数据库操作 1 创建数据库 createdataba 数据库名 createdataba 2 选择数据库 use 数据库名 userunoob 3 删除数据库 dropdatabase 数据库名 dropdatabase 二 数值类型 三 数据表 1 创建数据表 CREATETABL

(一)数据库操作

1、创建数据库

create database 数据库名; create database runoob; 

2、选择数据库

use 数据库名; use runoob; 

3、删除数据库

drop database 数据库名; drop database runoob; 

(三)数据表

1、创建数据表

CREATE TABLE 数据表名 (字段名 字段类型); CREATE TABLE `runoob_tbl`( `runoob_id` INT UNSIGNED AUTO_INCREMENT, `runoob_title` VARCHAR(100) NOT NULL, `runoob_author` VARCHAR(40) NOT NULL, `submission_date` DATE, PRIMARY KEY ( `runoob_id` ) )ENGINE=InnoDB DEFAULT CHARSET=utf8; 

2、删除数据表

DROP TABLE 数据表名 ; DROP TABLE runoob_tbl ; 

(四)数据操作

1、增

INSERT INTO table_name ( field1, field2,...fieldN ) VALUES ( value1, value2,...valueN ); INSERT INTO runoob_tbl (runoob_title, runoob_author, submission_date) VALUES ("学习 PHP", "菜鸟教程", NOW()); 

2、删

DELETE FROM table_name [WHERE Clause]; DELETE FROM runoob_tbl WHERE runoob_id=1; 

3、改

UPDATE table_name SET field1=new-value1, field2=new-value2 [WHERE Clause]; UPDATE runoob_tbl SET runoob_title='学习 C++' WHERE runoob_id=1; 

4、查

SELECT field1, field2,...fieldN FROM table_name1, table_name2... [WHERE condition1 [AND [OR]] condition2..... SELECT * from runoob_tbl WHERE runoob_author='菜鸟教程'; 

(五)查询

2、ORDER BY

SELECT field1, field2,...fieldN table_name1, table_name2... ORDER BY field1, [field2...] [ASC [DESC]]; SELECT * from runoob_tbl ORDER BY submission_date ASC; 

3、GROUP BY

GROUP BY 语句根据一个或多个列对结果集进行分组。

在分组的列上我们可以使用 COUNT, SUM, AVG,等函数。

SELECT column_name, function(column_name) FROM table_name WHERE column_name operator value GROUP BY column_name; SELECT name, COUNT(*) FROM employee_tbl GROUP BY name; 

4、JOIN

JOIN 按照功能大致分为如下三类:

SELECT a.runoob_id, a.runoob_author, b.runoob_count FROM runoob_tbl a INNER JOIN tcount_tbl b ON a.runoob_author = b.runoob_author 

(六)MySQL 事务

1、事务介绍

MySQL 事务主要用于处理操作量大,复杂度高的数据。比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务!

2、事务控制语句

BEGIN或START TRANSACTION;显式地开启一个事务;

COMMIT;也可以使用COMMIT WORK,不过二者是等价的。COMMIT会提交事务,并使已对数据库进行的所有修改成为永久性的;

ROLLBACK;有可以使用ROLLBACK WORK,不过二者是等价的。回滚会结束用户的事务,并撤销正在进行的所有未提交的修改;

(七)字段操作

1、增

ALTER TABLE 数据表名 ADD 新增字段 字段类型; ALTER TABLE runoob_tbl ADD status tinyint(1) NOT NULL DEFAULT '0' COMMENT '状态 0正常 1删除'; 

2、删

ALTER TABLE 数据表名 DROP 字段名; ALTER TABLE runoob_tbl DROP status; 

3、改

#例如,把字段 c 的类型从 CHAR(1) 改为 CHAR(10),可以执行以下命令: ALTER TABLE testalter_tbl MODIFY c CHAR(10); ALTER TABLE testalter_tbl CHANGE c c CHAR(10); #修改字段类型及名称 #在 CHANGE 关键字之后,紧跟着的是你要修改的字段名,然后指定新字段名及类型。尝试如下实例: #例如,把字段 c 改成 字段 j ,类型从 CHAR(1) 改为 CHAR(10),可以执行以下命令: ALTER TABLE testalter_tbl CHANGE c j CHAR(10); #ALTER TABLE 对 Null 值和默认值的影响 ALTER TABLE testalter_tbl MODIFY j BIGINT NOT NULL DEFAULT 100; #修改字段默认值 ALTER TABLE testalter_tbl ALTER i SET DEFAULT 1000; #修改表名 ALTER TABLE testalter_tbl RENAME TO alter_tbl; 

(八)索引

1、创建普通索引

#这是最基本的索引,它没有任何限制。它有以下几种创建方式: #(1)创建索引 CREATE INDEX indexName ON mytable(username(length)); #如果是CHAR,VARCHAR类型,length可以小于字段实际长度;如果是BLOB和TEXT类型,必须指定 length。 #(2)创建表的时候直接指定 CREATE TABLE mytable( ID INT NOT NULL, username VARCHAR(16) NOT NULL, INDEX [indexName] (username(length)) ); 

2、创建唯一索引

#它与前面的普通索引类似,不同的就是:索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一。它#有以下几种创建方式: #(1)创建索引 CREATE UNIQUE INDEX indexName ON mytable(username(length)) ; #(2)创建表的时候直接指定 CREATE TABLE mytable( ID INT NOT NULL, username VARCHAR(16) NOT NULL, UNIQUE [indexName] (username(length)) ); 

3、删除索引

DROP INDEX [indexName] ON mytable; 

4、使用ALTER 命令添加和删除索引

有四种方式来添加数据表的索引: #(1)该语句添加一个主键,这意味着索引值必须是唯一的,且不能为NULL。 ALTER TABLE tbl_name ADD PRIMARY KEY (column_list); #(2)这条语句创建索引的值必须是唯一的(除了NULL外,NULL可能会出现多次)。 ALTER TABLE tbl_name ADD UNIQUE index_name (column_list); #(3)添加普通索引,索引值可出现多次。 ALTER TABLE tbl_name ADD INDEX index_name (column_list); #(4)该语句指定了索引为 FULLTEXT ,用于全文索引。 ALTER TABLE tbl_name ADD FULLTEXT index_name (column_list); #添加索引实例 ALTER TABLE testalter_tbl ADD INDEX (c); #删除索引实例 ALTER TABLE testalter_tbl DROP INDEX c; 

项目版本升级常用SQL

#新建表 CREATE TABLE `ww_order` ( `id` int(10) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 'ID', `product_id` int(11) NULL DEFAULT NULL COMMENT '商品ID', `user_id` int(11) NULL DEFAULT NULL COMMENT '用户ID', `order_sn` varchar(50) NULL DEFAULT NULL COMMENT '订单号', `status` tinyint(1) NULL DEFAULT 1 COMMENT '状态:1=待完善信息,2=审核中,3=已通过,4=已驳回', `createtime` datetime(0) NULL DEFAULT NULL COMMENT '创建时间', `updatetime` datetime(0) NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间', `deletetime` int(11) NULL DEFAULT NULL COMMENT '删除时间', PRIMARY KEY (`id`) USING BTREE ) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '订单表' ROW_FORMAT = Dynamic; #在 ww_order 添加一个 phone 字段 ALTER TABLE `ww_order` add `phone` int(11) DEFAULT NULL COMMENT '联系方式'; #修改 ww_order 表 的phone 字段的数据类型 ALTER TABLE ww_order MODIFY column phone varchar (20) default NULL; #修改 ww_order 表 的 phone 字段默认值 ALTER TABLE ww_order ALTER `phone` SET DEFAULT 10086; # 删除 ww_order 表 的 phone 字段 ALTER TABLE ww_order DROP phone; #添加一个主键 这意味着索引值必须是唯一的且不能为NULL ALTER TABLE ww_order ADD PRIMARY KEY (id); #创建普通索引 注意 product_alias_name 为索引别名 删除索引时可以通过别名删除 可以不写别名 ALTER TABLE ww_order ADD INDEX product_alias_name (product_id); #不写索引别名时 默认索引名为 product_id ALTER TABLE ww_order ADD INDEX (product_id); #创建唯一索引 ALTER TABLE ww_order ADD UNIQUE order_sn_alias_name (order_sn); #不写索引别名时 默认索引名为 order_sn ALTER TABLE ww_order ADD UNIQUE (order_sn); #创建联合唯一索引 比如每人限购 user_id 联合 product_id 唯一 ALTER TABLE ww_order ADD UNIQUE user_product_id (user_id,product_id); #删除索引 product_id 通过索引别名删除索引 ALTER TABLE ww_order DROP INDEX `product_alias_name`; 

实战应用

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/202304.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月20日 上午7:26
下一篇 2026年3月20日 上午7:27


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号