常用MySQL语句大全分析
- 格式:doc
- 大小:26.50 KB
- 文档页数:10
mysql数据库常用语句SQL分类:DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE)DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT)DCL—数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK)首先,简要介绍基础语句:1、说明:创建数据库CREATE DATABASE database-name2、说明:删除数据库drop database dbname3、说明:备份sql server--- 创建备份数据的deviceUSE masterEXEC sp_addumpdevice ’disk’, ’testBack’, ’c:mssql7backupMyNwind_1.dat’--- 开始备份BACKUP DATABASE pubs TO testBack4、说明:创建新表create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)根据已有的表创建新表:A:create table tab_new like tab_old (使用旧表创建新表)B:create table tab_new as select col1,col2… from tab_old definition only5、说明:删除新表:drop table tabname6、说明:增加一个列:Alter table tabname add column col type注:列增加后将不能删除。
DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar 类型的长度。
7、说明:添加主键:Alter table tabname add primary key(col)说明:删除主键:Alter table tabname drop primary key(col)8、说明:创建索引:create [unique] index idxname on tabname(col….)删除索引:drop index idxname注:索引是不可更改的,想更改必须删除重新建。
常用的mysql语句一、创建表的语句1. 创建一个名为student的表,包含id、name、age三个字段,其中id为主键,自增长:CREATE TABLE student(id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(20),age INT);2. 创建一个名为teacher的表,包含id、name、salary三个字段,其中id为主键,自增长:CREATE TABLE teacher(id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(20),salary INT);3. 创建一个名为course的表,包含id、name、teacher_id三个字段,其中id为主键,自增长,teacher_id为外键,参考teacher 表的id字段:CREATE TABLE course(id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(20),teacher_id INT,FOREIGN KEY (teacher_id) REFERENCES teacher(id));二、插入数据的语句1. 向student表中插入一条数据,id为1,name为Tom,age为18:INSERT INTO student (id, name, age) VALUES (1, 'Tom', 18);2. 向teacher表中插入一条数据,id为1,name为John,salary 为5000:INSERT INTO teacher (id, name, salary) VALUES (1, 'John', 5000);3. 向course表中插入一条数据,id为1,name为Math,teacher_id为1:INSERT INTO course (id, name, teacher_id) VALUES (1, 'Math', 1);三、查询数据的语句1. 查询student表中所有的数据:SELECT * FROM student;2. 查询teacher表中所有salary大于4000的数据:SELECT * FROM teacher WHERE salary > 4000;3. 查询course表中所有的数据,同时查询出对应的教师姓名:SELECT course.id, , FROM course INNER JOIN teacher ON course.teacher_id = teacher.id;四、更新数据的语句1. 将student表中id为1的记录的age更新为20:UPDATE student SET age = 20 WHERE id = 1;2. 将teacher表中salary大于4000的记录的salary都增加500:UPDATE teacher SET salary = salary + 500 WHERE salary > 4000;3. 将course表中name为Math的记录的teacher_id改为2:UPDATE course SET teacher_id = 2 WHERE name = 'Math';五、删除数据的语句1. 删除student表中id为1的记录:DELETE FROM student WHERE id = 1;2. 删除teacher表中salary小于4000的记录:DELETE FROM teacher WHERE salary < 4000;3. 删除course表中name为English的记录:DELETE FROM course WHERE name = 'English';六、聚合函数的语句1. 计算student表中age的平均值:SELECT AVG(age) FROM student;2. 计算teacher表中salary的最大值:SELECT MAX(salary) FROM teacher;3. 统计course表中每个教师的课程数量:SELECT , COUNT(*) FROM course INNER JOINteacher ON course.teacher_id = teacher.id GROUP BY ;七、事务处理的语句1. 开启一个事务:START TRANSACTION;2. 执行一系列修改操作:UPDATE student SET age = age + 1 WHERE id = 1;UPDATE teacher SET salary = salary - 1000 WHERE id = 1;3. 提交事务:COMMIT;4. 回滚事务:ROLLBACK;以上就是常用的mysql语句,涵盖了创建表、插入数据、查询数据、更新数据、删除数据、聚合函数和事务处理等方面的操作,可以满足日常开发中的需求。
mysql 参数化语句MySQL是一种常用的关系型数据库管理系统,它支持使用参数化语句进行数据库操作。
参数化语句可以提高数据库的性能和安全性,同时也可以防止SQL注入攻击。
在本文中,我将列举出10个常用的MySQL参数化语句,并对其进行详细解释。
1. 插入数据:使用参数化语句插入数据可以防止SQL注入攻击,同时也可以提高性能。
下面是一个插入数据的示例:```sqlINSERT INTO table_name (column1, column2, column3) VALUES (?, ?, ?);```2. 更新数据:参数化语句也可以用于更新数据操作。
下面是一个更新数据的示例:```sqlUPDATE table_name SET column1 = ? WHERE column2 = ?; ```3. 删除数据:参数化语句可以用于删除数据操作。
下面是一个删除数据的示例:```sqlDELETE FROM table_name WHERE column = ?;```4. 查询数据:参数化语句可以用于查询数据操作。
下面是一个查询数据的示例: ```sqlSELECT * FROM table_name WHERE column = ?;```5. 使用LIKE语句模糊查询:参数化语句也可以用于模糊查询操作。
下面是一个使用LIKE语句的模糊查询示例:```sqlSELECT * FROM table_name WHERE column LIKE ?;```6. 使用IN语句查询多个值:参数化语句可以用于查询多个值的情况。
下面是一个使用IN语句查询多个值的示例:```sqlSELECT * FROM table_name WHERE column IN (?, ?, ?);```7. 使用BETWEEN语句查询范围:参数化语句可以用于查询指定范围的数据。
下面是一个使用BETWEEN语句查询范围的示例:```sqlSELECT * FROM table_name WHERE column BETWEEN ? AND ?;```8. 使用ORDER BY语句排序查询结果:参数化语句可以用于排序查询结果。
mysql数据库查询语句大全MySQL是一个功能强大的关系型数据库管理系统,支持多种查询语句,涵盖了数据检索、更新、删除等操作。
下面是一些常见的MySQL查询语句:数据查询:1.SELECT:从数据库中检索数据。
SELECT column1,column2 FROM table_name WHERE condition;2.DISTINCT:返回唯一不同的值。
SELECT DISTINCT column FROM table_name;3.WHERE:添加筛选条件。
SELECT*FROM table_name WHERE column=value;4.ORDER BY:按特定列排序检索结果。
SELECT*FROM table_name ORDER BY column ASC/DESC;5.LIMIT:限制返回的记录数。
SELECT*FROM table_name LIMIT 10;数据更新和删除:1.UPDATE:更新表中的数据。
UPDATE table_name SET column=value WHERE condition;2.DELETE:从表中删除行。
DELETE FROM table_name WHERE condition;表操作:1.CREATE TABLE:创建表格。
CREATE TABLE table_name(column1 datatype,column2 datatype,...);2.ALTER TABLE:修改表格。
ALTER TABLE table_name ADD column datatype;3.DROP TABLE:删除表格。
DROP TABLE table_name;4.TRUNCATE TABLE:清空表格数据。
TRUNCATE TABLE table_name;聚合函数:1.SUM:返回特定列的总和。
SELECT SUM(column)FROM table_name;2.COUNT:返回行数。
mysql 分支语句MySQL是一种常用的关系型数据库管理系统,它支持分支语句,用于根据不同的条件执行不同的代码块。
下面列举了十个使用MySQL 分支语句的示例:1. IF语句:IF语句是MySQL中最基本的分支语句,用于根据条件执行不同的代码块。
语法如下:```IF condition THENstatement1;ELSEstatement2;END IF;```其中,condition是一个返回布尔值的表达式。
2. CASE语句:CASE语句用于根据不同的条件执行不同的代码块。
它有两种形式:简单CASE和搜索CASE。
简单CASE语法如下:```CASE expressionWHEN value1 THEN statement1;WHEN value2 THEN statement2;...ELSE statementN;END CASE;```搜索CASE语法如下:```CASEWHEN condition1 THEN statement1;WHEN condition2 THEN statement2;...ELSE statementN;END CASE;```其中,expression是一个表达式,value1、value2等是常量,condition1、condition2等是布尔表达式。
3. IFNULL函数:IFNULL函数用于判断一个表达式是否为NULL,如果是NULL则返回指定的值,否则返回表达式的值。
语法如下:```IFNULL(expression, value);```其中,expression是一个表达式,value是一个常量。
4. NULLIF函数:NULLIF函数用于比较两个表达式的值,如果相等则返回NULL,否则返回第一个表达式的值。
语法如下:```NULLIF(expression1, expression2);```其中,expression1和expression2是两个表达式。
mysql统计查询语句MySQL是一种常用的关系型数据库管理系统,可以用于存储和处理大量数据。
为了有效地管理和分析数据,需要使用统计查询语句。
本文将介绍一些常用的MySQL统计查询语句,包括聚合函数、分组语句、筛选条件等。
一、聚合函数聚合函数能够通过对数据进行计算、统计等操作,返回单一值作为结果。
MySQL支持多种聚合函数,包括以下几种:1. COUNT函数:用于返回某一列的行数。
语法:SELECT COUNT(column_name) FROM table_name;2. SUM函数:用于返回某一列的总和。
语法:SELECT SUM(column_name) FROM table_name;3. AVG函数:用于返回某一列的平均值。
语法:SELECT AVG(column_name) FROM table_name;4. MAX函数:用于返回某一列的最大值。
语法:SELECT MAX(column_name) FROM table_name;5. MIN函数:用于返回某一列的最小值。
语法:SELECT MIN(column_name) FROM table_name;二、分组查询分组查询是一种将数据集合按照特定的列进行分组的方式。
在MySQL中,可以使用GROUP BY语句实现分组查询。
一般情况下,分组查询需要和聚合函数一起使用,以实现更加精细的数据分析。
语法:SELECT column_name, COUNT(*) FROM table_name GROUP BY column_name;三、筛选条件在进行统计查询时,往往需要按照特定的条件对数据进行筛选。
MySQL中可以使用WHERE语句实现条件筛选。
语法:SELECT column_name FROM table_name WHERE condition;常用的条件运算符包括:1. 等于(=)2. 不等于(<>或!=)3. 大于(>)4. 小于(<)5. 大于等于(>=)6. 小于等于(<=)四、查询结果排序有时候需要按照某一列的值对查询结果进行排序,可以使用ORDER BY语句实现。
mysql数据库常用语句大全1.连接数据库:连接本地数据库:mysql -u root -p连接远程数据库:mysql -h 192.169.22.199 -u root -p退出数据库:exit2.创建数据库:create database payment;使用 mysqladmin 创建数据库mysqladmin -u root -p create abc_db; 3.显示所有数据库:show databases;4.删除数据库:drop database payment;使用 mysqladmin 删除数据库mysqladmin -u root -p drop abc_db5.选择数据库:use home_db;6.数据类型:数值类型:TINYINT:SMALLINT:MEDIUMINT:INT(INTEGER):BIGINT:FLOAT:DOUBLE:DECIMAL:日期和时间类型:DATE:TIEM:DATETIME:YEAR:TIMESTAMP:字符串类型:CHAR:VARCHAR:TINYBLOB:TINYTEXT:BLOB:TEXT:MEDIUMBLOB:MEDIUMTEXT:LONGBLOB:LONGTEXT:7.创建数据表:CREATE TABLE IF NOT EXISTS `t_order`( `id` INT(10) UNSIGNED AUTO_INCREMENT,`title` VARCHAR(100) NOT NULL,PRIMARY KEY(`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;8.删除数据表:DROP TABLE t_order;9.insert 插入:插入一条数据:INSERT INTO t_order(title)VALUES('手机');INSERT 插入多条数据:INSERT INTO t_order(title)VALUES('笔记本'),('平板电脑');10.select 查询:所有字段查询:SELECT * FROM t_order;某些字段查询:SELECT t_order.id, t_order.title FROM t_order;分页查询:SELECT t_order.title FROM t_order WHERE id LIMIT 1,10 11.where 条件:OR,AND的应用:SELECT * FROM t_order WHERE title ='手机' OR title='笔记本';SELECT * FROM t_order WHERE title ='手机' AND id=2;12.update 更新:UPDATE t_order SET title='苹果手机' WHERE id =2;13.delete 删除:DELETE FROM t_order WHERE id=2;14.like 查询SELECT * FROM t_order WHERE title LIKE '%手机%';SELECT * FROM t_order WHERE title LIKE '_机';14.union 联合查询:连接两个以上的 SELECT 语句合并成一个结果集合SELECT * FROM t_order UNION SELECT * FROM t_user; SELECT * FROM t_order UNION ALL SELECT * FROM t_user;15.order by 排序:升序排序:SELECT * FROM t_order ORDER BY id ASC;降序排序:SELECT * FROM t_order ORDER BY id DESC;16.group by 分组:SELECT title, count(*) as total FROM t_order GROUP BY title;17.join 连接:inner join(内连接) on:获取两个表中字段匹配关系的记录SELECT * FROM t_order o INNER JOIN t_user u ON o.id =u.id;left join(左连接)on:获取左表所有记录,即使右表没有对应匹配的记录SELECT * FROM t_order o LEFT JOIN t_user u ON o.id =u.id;right join(右连接)on:获取右表所有记录,即使左表没有对应匹配的记录SELECT * FROM t_order o RIGHT JOIN t_user u ON o.id =u.id;18.null的处理:null值的判断:SELECT * FROM t_user WHERE name IS NULL;非null值的判断:SELECT * FROM t_user WHERE name IS NOT NULL;19.REGEXP 正则表达式:SELECT * FROM t_order WHERE title REGEXP('手机$'); SELECT * FROM t_order WHERE title REGEXP('^笔');。
mysql查询语句大全及用法MySQL是一种常用的关系型数据库管理系统,提供了强大的查询语言(SQL)来操作和管理数据库。
下面是一些常见的MySQL查询语句及其用法:1. SELECT语句:-用法:用于从数据库中检索数据。
-示例:SELECT * FROM 表名;(检索表中的所有数据)SELECT 列1, 列2 FROM 表名WHERE 条件;(根据条件检索指定列的数据)2. INSERT语句:-用法:用于向数据库中插入新的数据。
-示例:INSERT INTO 表名(列1, 列2) VALUES (值1, 值2);(向表中插入指定列的数据)3. UPDATE语句:-用法:用于更新数据库中的数据。
-示例:UPDATE 表名SET 列1 = 值1, 列2 = 值2 WHERE 条件;(根据条件更新指定列的数据)4. DELETE语句:-用法:用于从数据库中删除数据。
-示例:DELETE FROM 表名WHERE 条件;(根据条件删除数据)5. WHERE子句:-用法:用于在SELECT、UPDATE和DELETE语句中指定条件。
-示例:SELECT * FROM 表名WHERE 列= 值;(根据条件检索数据)6. ORDER BY子句:-用法:用于对结果进行排序。
-示例:SELECT * FROM 表名ORDER BY 列ASC/DESC;(根据指定列的升序或降序排序数据)7. GROUP BY子句:-用法:用于将结果分组。
-示例:SELECT 列, COUNT(*) FROM 表名GROUP BY 列;(根据指定列对数据进行分组并计数)8. JOIN语句:-用法:用于在多个表之间建立连接。
-示例:SELECT * FROM 表1 JOIN 表2 ON 表1.列= 表2.列;(根据指定列在两个表之间建立连接)9. DISTINCT关键字:-用法:用于返回唯一的结果。
-示例:SELECT DISTINCT 列FROM 表名;(返回指定列的唯一结果)10. LIMIT关键字:-用法:用于限制结果集的行数。
mysql必背50条语句1. 创建数据库:```sqlCREATE DATABASE dbname;```2. 删除数据库:```sqlDROP DATABASE dbname;```3. 选择数据库:```sqlUSE dbname;```4. 显示所有数据库:```sqlSHOW DATABASES;```5. 创建表:```sqlCREATE TABLE tablename (column1 datatype,column2 datatype,...);```6. 查看表结构:```sqlDESC tablename;```7. 删除表:```sqlDROP TABLE tablename;```8. 插入数据:```sqlINSERT INTO tablename (column1, column2, ...) VALUES (value1, value2, ...);```9. 查询数据:```sqlSELECT * FROM tablename;```10. 条件查询:```sqlSELECT * FROM tablename WHERE condition;```11. 更新数据:```sqlUPDATE tablename SET column1 = value1, column2 = value2 WHERE condition;```12. 删除数据:```sqlDELETE FROM tablename WHERE condition;```13. 查找唯一值:```sqlSELECT DISTINCT column FROM tablename;```14. 排序数据:```sqlSELECT * FROM tablename ORDER BY column ASC/DESC;```15. 限制结果集:```sqlSELECT * FROM tablename LIMIT 10;```16. 分页查询:```sqlSELECT * FROM tablename LIMIT 10 OFFSET 20;```17. 计算行数:```sqlSELECT COUNT(*) FROM tablename;```18. 聚合函数:```sqlSELECT AVG(column), SUM(column), MIN(column), MAX(column) FROM tablename;```19. 连接表:```sqlSELECT * FROM table1 INNER JOIN table2 ON table1.column = table2.column;```20. 创建索引:```sqlCREATE INDEX indexname ON tablename (column);```21. 查看索引:```sqlSHOW INDEX FROM tablename;```22. 删除索引:```sqlDROP INDEX indexname ON tablename;```23. 备份整个数据库:```sqlmysqldump -u username -p dbname > backup.sql;```24. 恢复数据库:```sqlmysql -u username -p dbname < backup.sql;```25. 修改表结构:```sqlALTER TABLE tablename ADD COLUMN newcolumn datatype;```26. 重命名表:```sqlRENAME TABLE oldname TO newname;```27. 增加主键:```sqlALTER TABLE tablename ADD PRIMARY KEY (column);```28. 删除主键:```sqlALTER TABLE tablename DROP PRIMARY KEY;```29. 增加外键:```sqlALTER TABLE tablename ADD CONSTRAINT fk_name FOREIGN KEY (column) REFERENCES othertable(column);```30. 删除外键:```sqlALTER TABLE tablename DROP FOREIGN KEY fk_name;```31. 查看活动进程:```sqlSHOW PROCESSLIST;```32. 杀死进程:```sqlKILL process_id;```33. 给用户授权:```sqlGRANT permission ON dbname.tablename TO 'username'@'host';```34. 撤销用户权限:```sqlREVOKE permission ON dbname.tablename FROM 'username'@'host';```35. 创建用户:```sqlCREATE USER 'username'@'host' IDENTIFIED BY 'password';```36. 删除用户:```sqlDROP USER 'username'@'host';```37. 修改用户密码:```sqlSET PASSWORD FOR 'username'@'host' = PASSWORD('newpassword');```38. 查看用户权限:```sqlSHOW GRANTS FOR 'username'@'host';```39. 启用外键约束:```sqlSET foreign_key_checks = 1;```40. 禁用外键约束:```sqlSET foreign_key_checks = 0;```41. 启用查询缓存:```sqlSET query_cache_type = 1;```42. 禁用查询缓存:```sqlSET query_cache_type = 0;```43. 查看服务器版本:```sqlSELECT VERSION();```44. 查看当前日期和时间:```sqlSELECT NOW();```45. 查找匹配模式:```sqlSELECT * FROM tablename WHERE column LIKE 'pattern';```46. 计算平均值:```sqlSELECT AVG(column) FROM tablename;```47. 查找空值:```sqlSELECT * FROM tablename WHERE column IS NULL;```48. 日期比较:```sqlSELECT * FROM tablename WHERE date_column > '2022-01-01';```49. 将结果导出为CSV 文件:```sqlSELECT * INTO OUTFILE 'output.csv' FIELDS TERMINATED BY ',' FROM tablename;```50. 将结果导入其他表:```sqlLOAD DATA INFILE 'input.csv' INTO TABLE tablename FIELDS TERMINATED BY ',';。
mysql 查询语法一、概述MySQL是一个开源的关系型数据库管理系统,广泛应用于Web应用程序的开发中。
在MySQL中,查询语句是最常用的操作之一,本文将对MySQL查询语法进行详细介绍。
二、基本语法MySQL查询语句通常由SELECT、FROM、WHERE、GROUP BY、HAVING和ORDER BY等关键字组成。
其中,SELECT和FROM是必须的关键字,其他关键字可以根据需要选择使用。
1. SELECTSELECT关键字用于指定要查询哪些列。
可以使用*来表示所有列,也可以指定具体的列名。
2. FROMFROM关键字用于指定要从哪个表中查询数据。
3. WHEREWHERE关键字用于指定查询条件。
可以使用比较运算符(如=、>、<等)和逻辑运算符(如AND、OR等)来组合多个条件。
4. GROUP BYGROUP BY关键字用于将结果按照某些列进行分组,并对每个分组计算聚合函数(如SUM、AVG等)。
5. HAVINGHAVING关键字与GROUP BY一起使用,用于筛选聚合函数计算结果满足某些条件的分组。
6. ORDER BYORDER BY关键字用于将结果按照某些列进行排序。
默认情况下按照升序排序,可以使用DESC关键字来改变排序方向。
三、示例1. 查询所有列SELECT * FROM table_name;2. 查询指定列SELECT column1, column2 FROM table_name;3. 查询符合条件的数据SELECT * FROM table_name WHERE column1 > 10 ANDcolumn2 = 'abc';4. 分组计算聚合函数SELECT column1, SUM(column2) FROM table_name GROUP BY column1;5. 筛选分组结果SELECT column1, SUM(column2) FROM table_name GROUP BY column1 HAVING SUM(column2) > 100;6. 按照某些列排序SELECT * FROM table_name ORDER BY column1 DESC, column2 ASC;四、高级语法1. JOINJOIN关键字用于将两个或多个表中的数据进行关联查询。
mysql查询判断语句在MySQL中,查询判断语句是一个非常重要的功能,它可以根据特定的条件从数据库中获取符合要求的数据。
下面,我将详细介绍一些常见的MySQL查询判断语句,以帮助大家更好地查询数据库。
1. SELECT语句SELECT语句是MySQL中最基本的查询语句,它可以从一个或多个表中选择指定的列,并根据一定的条件来筛选数据。
例如,我们要从表中选择学生姓名、学号和班级信息,可以使用以下SELECT语句:SELECT name, number, class FROM student;其中,name、number和class是我们要选择的列名,student是我们要查询的表名称。
2. WHERE语句WHERE语句是MySQL中最常用的筛选语句,它可以从表中选择符合特定条件的数据。
例如,我们要从表中选择姓名为张三的学生信息,可以使用以下WHERE 语句:SELECT name, number, class FROM student WHERE name = '张三';其中,name、number和class是我们要选择的列名,student是我们要查询的表名称,而姓名为“张三”的条件则通过WHERE子句来筛选出符合要求的数据。
3. LIKE语句LIKE语句是MySQL中用于模糊匹配的语句,它可以在表中查找包含特定字符或字符串的数据。
例如,我们要从表中选择姓名包含“张”的学生信息,可以使用以下LIKE语句:SELECT name, number, class FROM student WHERE name LIKE '%张%';其中,name、number和class是我们要选择的列名,student是我们要查询的表名称,“%张%”则表示对于所有含有“张”的字符串都筛选出来。
%代表0个、1个或多个任意字符,所以WHERE子句这里可以使用%来进行模糊匹配。
4. IN语句IN语句是MySQL用于筛选特定集合的语句,它可以从表中选择符合特定条件的数据。
mysql常⽤语句⼤全最常⽤的显⽰命令:1、显⽰数据库列表。
show databases;2、显⽰库中的数据表:use mysql;show tables;3、显⽰数据表的结构:describe 表名;4、建库:create database 库名;5、建表:use 库名;create table 表名 (字段设定列表);6、删库和删表:drop database 库名;drop table 表名;7、将表中记录清空:delete from 表名;(这个清空表只是把数据表内容数据清掉,⾃增id不会被清掉,⾃增id会保留)truncate table 表名;(成功返回0)(⾃增id也⼀同会被清掉)truncate与delete的区别:a.事务:truncate是不可以rollback的,但是delete是可以rollback的;原因:truncate删除整表数据(ddl语句,隐式提交),delete是⼀⾏⼀⾏的删除,可以rollbackb.效果:truncate删除后将重新⽔平线和索引(id从零开始) ,delete不会删除索引c.truncate 不能触发任何Delete触发器。
d.delete 删除可以返回⾏数8、显⽰表中的记录:select * from 表名连接MySQL格式: mysql -h 主机地址 -u⽤户名 -p⽤户密码例 1:连接到本机上的 MySQL。
mysql -uroot -pmysql;连接到远程主机上的 MYSQL。
mysql -h 127.0.0.1 -uroot -pmysql;2、连接到远程主机上的MYSQL。
假设远程主机的IP为:110.110.110.110,⽤户名为root,密码为abcd123。
则键⼊以下命令:mysql -h110.110.110.110 -u root -p 123;(注:u与root之间可以不⽤加空格,其它也⼀样)3、退出MYSQL命令: exit (回车)修改新密码在终端输⼊:mysql -u⽤户名 -p密码,回车进⼊Mysql。
以下是一些 MySQL 数据库中常用的 SQL 语句,包括创建、查询、更新和删除等操作。
请注意,这只是一个概览,实际使用中可能需要根据具体情况进行调整。
创建数据库和表
1.创建数据库:
2.使用数据库:
3.创建表:
插入数据
1.插入单行数据:
2.插入多行数据:
查询数据
1.查询所有数据:
2.条件查询:
3.排序查询:
4.分组统计:
5.连接查询:
更新和删除数据1.更新数据:
2.删除数据:
数据库维护
1.备份数据库:
2.还原数据库:
3.删除表:
4.删除数据库:
这只是 MySQL 中常见的一些 SQL 语句,具体的使用还需要根据实际情况进行调整。
注意在执行删除和更新语句时要格外小心,确保条件和目标是正确的,以免误删或误改数据。
一.衔接MySQL格局: mysql -h主机地址-u用户名-p用户暗码1.例1:衔接到本机上的MYSQL.起首在打开DOS窗口,然落后入目次mysqlbin,再键入敕令mysql -uroot -p,回车后提示你输暗码,假如刚装配好MYSQL,超等用户root是没有暗码的,故直接回车即可进入到MYSQL中了,MYSQL 的提示符是: mysql>.2.例2:衔接到长途主机上的MYSQL.假设长途主机的IP为:110.110.110.110,用户名为root,暗码为abcd123.则键入以下敕令:mysql -h110.110.110.110 -uroot -pabcd123(注:u与root可以不必加空格,其它也一样)3.退出MYSQL敕令: exit (回车).二.修正暗码格局:mysqladmin -u用户名 -p旧暗码 password 新暗码1.例1:给root加个暗码ab12.起首在DOS下进入目次mysqlbin,然后键入以下敕令:mysqladmin -uroot -password ab12注:因为开端时root没有暗码,所以-p旧暗码一项就可以省略了.2.例2:再将root的暗码改为djg345.mysqladmin -uroot -pab12 password djg345三.增长新用户.(留意:和上面不合,下面的因为是MySQL情形中的敕令,所今后面都带一个分号作为敕令停止符)格局:grant select on 数据库.* to 用户名@登录主机 identified by \"暗码\"例1.增长一个用户test1暗码为abc,让他可以在任何主机上登录,并对所稀有据库有查询.拔出.修正.删除的权限.起首用以root用户连入MySQL,然后键入以下敕令:grant select,insert,update,delete on *.* to test2@localhost identified by \"abc\";假如你不想test2有暗码,可以再打一个敕令将暗码消失落.grant select,insert,update,delete on mydb.* to test2@localhost identified by \"\";在上面讲了登录.增长用户.暗码更改等问题.下面我们来看看MySQL中有关数据库方面的操纵.留意:你必须起首登录到MySQL中,以下操纵都是在MySQL的提示符下进行的,并且每个敕令以分号停止.1.MySQL 经常应用敕令create database name; 创建数据库use databasename; 选择数据库drop database name 直接删除数据库,不提示show tables; 显示表describe tablename; 表的具体描写select 中加上distinct去除反复字段mysqladmin drop database name 删除数据库前,有提示.显示当前mysql版本和当前日期select version(),current_date;2.修正mysql中root 的暗码:shell>mysql -u root -pmysql> update user set password=password(”xueok654123″) where user=’root’;mysql> flush privileges //刷新数据库mysql>use dbname; 打开数据库:mysql>show databases; 显示所稀有据库mysql>show tables; 显示数据库mysql中所有的表:先use mysql;然后mysql>describe user; 显示表mysql数据库中user表的列信息);3.grant创建一个可以从任何地方衔接办事器的一个完全的超等用户,但是必须应用一个口令something做这个mysql> grant all privileges on *.* to user@localhost identified by ’something’ with增长新用户格局:grant select on 数据库.* to 用户名@登录主机identified by “暗码”GRANT ALL PRI VILEGES ON *.* TO monty@localhost IDENTIFIED BY ’something’ WITH GRANT OPTION;GRANT ALL PRIVILEGES ON *.* TO monty@”%” IDENTIFIED BY ’something’ WITH GRANT OPTION;删除授权:mysql> revoke all privileges on *.* from root@”%”;mysql> delete from user where user=”root” and host=”%”;mysql> flush privileges;创建一个用户custom在特定客户端登录,可拜访特定命据库fangchandbmysql >grant select, insert, update, delete, create,drop on fangchandb.* to custom@ identified by ‘ passwd’重定名表:mysql > alter table t1 rename t2;4.mysqldump10.操纵数据#拔出表departmentinsert into department(name,description) values('体系部','体系部');insert into department(name,description) values('公关部','公关部');insert into department(name,description) values('客服部','客服部');insert into department(name,description) values('财务部','财务部');insert into department(name,description) values('测试部','测试部');#拔出表s_positioninsert into s_position(name,description) values('总监','总监');insert into s_position(name,description) values('司理','司理');insert into s_position(name,description) values('通俗员工','通俗员工');#拔出表depart_posinsert into depart_pos(department_id,position_id)select a.id department_id,b.id postion_idfrom department a,s_position b;#拔出表stafferinsert into staffer(name,department_id,position_id) values('陈达治',1,1);insert into staffer(name,department_id,position_id) values('李文宾',1,2);insert into staffer(name,department_id,position_id) values('马佳',1,3);insert into staffer(name,department_id,position_id) values('亢志强',5,1);insert into staffer(name,department_id,position_id) values('杨玉茹',4,1);11.查询及删除操纵#显示体系部的人员和职位select , department_name, position_namefrom staffer a,department b,s_position cwherea.department_id=b.id and a.position_id=c.id and ='体系部';#显示体系部的人数select count(*) from staffer a,department bwhere a.department_id=b.id and ='体系部'#显示各部分的人数select count(*) cou,from staffer a,department bwhere a.department_id=b.idgroup by ;#删除客服部delete from department where name='客服部';#将财务部修正为财务一部update department set name='财务一部' where name='财务部';12.备份和恢复备份数据库stafferc:\mysql\bin\mysqldump -uroot -proot staffer>e:\staffer.sql得到的staffer.sql是一个sql剧本,不包含建库的语句,所以你须要手工创建数据库才可以导入恢复数据库staffer,须要创建一个空库stafferc:\mysql\bin\mysql -uroot -proot staffer<staffer.sql假如不愿望后来手工创建staffer,可以c:\mysql\bin\mysqldump -uroot -proot --databases staffer>e:\staffer.sqlmysql -uroot -proot >e:\staffer.sql但如许的话体系种就不克不及消失staffer库,且无法导入其他名字的数据库,当然你可以手工修正staffer.sql文件13.从文本向数据库导入数据1)应用对象c:\mysql\bin\mysqlimport这个对象的感化是将文件导入到和去失落文件扩大名名字雷同的表里,如staffer.txt,staffer都是导入到staffer表中经常应用选项及功效如下-d or --delete 新数据导入数据表中之前删除数据数据表中的所有信息-f or --force不管是否碰到错误,mysqlimport将强迫持续拔出数据-i or --ignore mysqlimport跳过或者疏忽那些有雷同独一症结字的行, 导入文件中的数据将被疏忽.-l or -lock-tables 数据被拔出之前锁住表,如许就防止了,你在更新数据库时,用户的查询和更新受到影响.-r or -WordStr 这个选项与-i选项的感化相反;此选项将替代表中有雷同独一症结字的记载.--fields-enclosed- by= char指定文本文件中数据的记载时以什么括起的, 许多情形下数据以双引号括起. 默认的情形下数据是没有被字符括起的.--fields-terminated- by=char指定各个数据的值之间的分隔符,在句号分隔的文件中,分隔符是句号.您可以用此选项指定命据之间的分隔符.默认的分隔符是跳格符(Tab)--lines-terminated- by=str此选项指定文本文件中行与行之间数据的分隔字符串或者字符. 默认的情形下mysqlimport以newline为行分隔符.您可以选择用一个字符串来替代一个单个的字符:一个新行或者一个回车.mysqlimport敕令经常应用的选项还有-v 显示版本(version),-p 提示输入暗码(password)等.这个对象有个问题,无法疏忽某些列,如许对我们的数据导入有很大的麻烦,固然可以手工设置这个字段,但会消失莫名其妙的成果,我们做一个简略的示例我们界说如下的depart_no.txt,保管在e盘,距离为制表符\t10 1011 1112 24履行如下敕令c:\mysql\bin\mysqlimport -uroot -proot staffer e:\depart_pos.txt在这里没有应用列的包抄符号,朋分采取默认的\t,因为采取此外符号会有问题,不知道是不是windows的原因2)Load Data INFILE file_name into table_name(column1_name,column2_name)这个敕令在mysql>提示符下应用,长处是可以指定列导入,示例如下c:\mysql\bin\mysql -uroot -proot staffermysql>load data infile "e:/depart_no.txt" into depart_no(department_id,position_id);这两个对象在Windows 下应用都有问题,不知道是Windows的原因照样中文的问题,并且不指定的列它产生了空值,这显然不是我们想要的,所以谨严应用这些对象进入MySQL:mysql -uuser -ppassword --port=33071:应用SHOW语句找出在办事器受骗前消失什么数据库:mysql> SHOW DATABASES;2:2.创建一个数据库MYSQLDATAmysql> Create DATABASE MYSQLDATA;3:选择你所创建的数据库mysql> USE MYSQLDATA; (按回车键消失Database changed 时解释操纵成功!)4:检讨如今的数据库中消失什么表mysql> SHOW TABLES;5:创建一个数据库表mysql> Create TABLE MYTABLE (name VARCHAR(20), sex CHAR(1));6:显示表的构造:mysql> DESCRIBE MYTABLE;7:往表中参加记载mysql> insert into MYTABLE values ("hyq","M");8:用文本方法将数据装入数据库表中(例如D:/mysql.txt)mysql> LOAD DATA LOCAL INFILE "D:/mysql.txt" INTO TABLE MYTABLE;9:导入.sql文件敕令(例如D:/mysql.sql)mysql>use database;mysql>source d:/mysql.sql;10:删除表mysql>drop TABLE MYTABLE;11:清空表mysql>delete from MYTABLE;12:更新表中数据mysql>update MYTABLE set sex="f" where name='hyq';UPDATE [LOW_PRIORITY] [IGNORE] tbl_nameSET col_name1=expr1 [, col_name2=expr2 ...][WHERE where_definition][ORDER BY ...][LIMIT rows]orUPDATE [LOW_PRIORITY] [IGNORE] tbl_name [, tbl_name ...]SET col_name1=expr1 [, col_name2=expr2 ...][WHERE where_definition]UPDATE 以新的值更新现存表中行的列.SET 子句指出要修正哪个列和他们应当给定的值.WHERE子句假如被给出,指定哪个记载行应当被更新.不然,所有的记载行被更新.假如 ORDER BY 子句被指定,记载行将被以指定的次序更新.假如你指定症结词 LOW_PRIORITY,UPDATE 的履行将被延迟,直到没有其它的客户正直在读取表.假如你指定症结词 IGNORE,该更新语句将不会平常中断,即使在更新进程中消失反复键错误.导致冲突的记载行将不会被更新.假如在一个表达式中从 tbl_name 中拜访一个列,UPDATE 应用列的当前值.举例来说,下面的语句设置 age 列值为它的当前值加 1 :mysql> UPDATE persondata SET age=age+1;UPDATE 赋值是从左到右盘算的.举例来说,下列语句将 age 列设置为它的两倍,然后再加 1 :mysql> UPDATE persondata SET age=age*2, age=age+1;假如你设置列为其当前的值,MySQL 留意到这点,其实不更新它.UPDATE 返回现实被转变的记载行数量.在 MySQL 3.22 或更新的版本中,C API 函数 mysql_info()返回被匹配并更新的记载行数量,以及在 UPDATE时代产生的警告的数量.在 MySQL 3.23 中,你可以应用 LIMIT # 来确保只有给定的记载行数量被更改.假如一个 ORDER BY 子句被应用(从 MySQL 4.0.0 开端支撑),记载行将以指定的次序被更新.这现实上只有连同 LIMIT一路才有效.从 MySQL 4.0.4 开端,你也可以履行一个包含多个表的UPDATE 的操纵:UPDATE items,month SET items.price=month.priceWHERE items.id=month.id;留意:多表 UPDATE 不成以应用 ORDER BY 或 LIMIT.症结字: mysql启动:net start mySql; 进入:mysql -u root -p/mysql -h localhost -u root -p databaseName; 列出数据库:show databases; 选择数据库:use databaseName; 列出表格:show tables; 显示表格列的属性:show columns from tableName; 树立数据库:source fileName.txt; 匹配字符:可以用通配符_代表任何一个字符,%代表任何字符串; 增长一个字段:alter table tabelName add column fieldName dateType;增长多个字段:alter table tabelName add column fieldName1 dateType,add columns fieldName2 dateType; 多行敕令输入:留意不克不及将单词断开;当拔出或更改数据时,不克不及将字段的字符串睁开到多行里,不然硬回车将被储存到数据中; 增长一个治理员帐户:grant all on *.* to user@localhost identified by "password"; 每条语句输入完毕后要在末尾填加分号';',或者填加'\g'也可以; 查询时光:select now();查询当前用户:select user(); 查询数据库版本:select version(); 查询当前应用的数据库:select database();1.删除student_course数据库中的students数据表:rm -f student_course/students.*2.备份数据库:(将数据库test 备份) mysqldump -u root -p test>c:\test.txt 备份表格:(备份test数据库下的mytable表格) mysqldump -u root -p test mytable>c:\test.txt 将备份数据导入到数据库:(导回test数据库) mysql -u root -p test3.创建暂时表:(树立暂时表zengchao) create temporary table zengchao(name varchar(10));4.创建表是先断定表是否消失create table if not exists students(……);5.从已经有的表中复制表的构造create table table2 select * from table1 where 1<>1;6.复制表create table table2 select * from table1;7.对表从新定名alter table table1 rename as table2;8.修正列的类型alter table table1 modify id int unsigned;//修正列id的类型为int unsigned alter table table1 change id sid int unsigned;//修正列id的名字为sid,并且把属性修正为int unsigned9.创建索引alter table table1 add index ind_id (id);create index ind_id on table1 (id); create unique index ind_id on table1 (id);//树立独一性索引10.删除索引drop index idx_id on table1;alter table table1 drop index ind_id; 11.结合字符或者多个列(将列id与":"和列name和"="衔接)select concat(id,':',name,'=') from students; 12.limit(选出10到20条)<第一个记载集的编号是0> select * from students order by id limit 9,10; 13.MySQL不支撑的功效事务,视图,外键和引用完全性,存储进程和触发器14.MySQL会应用索引的操纵符号<,<=,>=,>,=,between,in,不带%或者_开首的like 15.应用索引的缺陷1)减慢增删改数据的速度; 2)占用磁盘空间; 3)增长查询优化器的累赘; 当查询优化器生成履行筹划时,会斟酌索引,太多的索引会给查询优化器增长工作量,导致无法选择最优的查询筹划; 16.剖析索引效力办法:在一般的SQL语句前加上explain; 剖析成果的寄义:1)table:表名; 2)type:衔接的类型,(ALL/Range/Ref).个中ref是最幻想的; 3)possible_keys:查询可以应用的索引名; 4)key:现实应用的索引; 5)key_len:索引中被应用部分的长度(字节); 6)ref:显示列名字或者"const"(不明确什么意思); 7)rows:显示MySQL以为在找到准确成果之前必须扫描的行数; 8)extra:MySQL的建议; 17.应用较短的定长列1)尽可能应用较短的数据类型; 2)尽可能应用定长数据类型; a)用char代替varchar,固定长度的数据处理比变长的快些; b)对于频仍修正的表,磁盘轻易形成碎片,从而影响数据库的整体机能; c)万一消失数据表解体,应用固定长度数据行的表更轻易从新构造.应用固定长度的数据行,每个记载的开端地位都是固定记载长度的倍数,可以很轻易被检测到,但是应用可变长度的数据行就不一定了; d)对于MyISAM 类型的数据表,固然转换成固定长度的数据列可以进步机能,但是占领的空间也大; 18.应用not null和enum 尽量将列界说为not null,如许可使数据的出来更快,所需的空间更少,并且在查询时,MySQL不须要检讨是否消失特例,即null值,从而优化查询; 假如一列只含有有限数量标特定值,如性别,是否有效或者入学年份等,在这种情形下应当斟酌将其转换为enum列的值,MySQL处理的更快,因为所有的enum值在体系内都是以标识数值来暗示的; 19.应用optimize table 对于经常修正的表,轻易产生碎片,使在查询数据库时必须读取更多的磁盘块,降低查询机能.具有可变长的表都消失磁盘碎片问题,这个问题对blob数据类型更为凸起,因为其尺寸变更平常大.可以经由过程应用optimize table来整顿碎片,包管数据库机能不降低,优化那些受碎片影响的数据表. optimize table可以用于MyISAM和BDB类型的数据表.现实上任何碎片整顿办法都是用mysqldump来转存数据表,然后应用转存后的文件着从新建数据表;20.应用procedure analyse() 可以应用procedure analyse()显示最佳类型的建议,应用很简略,在select语句后面加上procedure analyse()就可以了;例如:select * from students procedure analyse(); select * from students procedureanalyse(16,256); 第二条语句请求procedure analyse()不要建议含有多于16个值,或者含有多于256字节的enum类型,假如没有限制,输出可能会很长; 21.应用查询缓存1)查询缓存的工作方法:第一次履行某条select语句时,办事器记住该查询的文本内容和查询成果,存储在缓存中,下次碰着这个语句时,直接从缓存中返回成果;当更新数据表后,该数据表的任何缓存查询都变成无效的,并且会被丢弃. 2)设置装备摆设缓存参数:变量:query_cache _type,查询缓存的操纵模式.有3中模式,0:不缓存;1:缓存查询,除非与 select sql_no_cache开首;2:依据须要只缓存那些以select sql_cache开首的查询; query_cache_size:设置查询缓存的最大成果集的大小,比这个值大的不会被缓存. 22.调剂硬件1)在机械上装更多的内存; 2)增长更快的硬盘以削减I/O等待时光; 寻道时光是决议机能的重要身分,逐字地移动磁头是最慢的,一旦磁头定位,从磁道读则很快; 3)在不合的物理硬盘装备上从新分派磁盘运动; 假如可能,应将最忙碌的数据库存放在不合的物理装备上,这跟应用统一物理装备的不合分区是不合的,因为它们将争用雷同的物理资本(磁头).。
mysql分类汇总语句
在MySQL中,可以使用GROUP BY子句对结果集进行分类汇总。
以下是常见的MySQL分类汇总语句示例:1. 汇总单个字段:SELECT category, COUNT(*) AS totalFROM productsGROUP BY category;上述语句将products表按照category字段进行分类汇总,并计算每个分类中的行数。
2. 汇总多个字段:SELECT category, brand, AVG(price) AS average_priceFROM productsGROUP BY category, brand;上述语句将products表按照category 和brand字段进行分类汇总,并计算每个分类和品牌的平均价格。
3. 使用聚合函数:SELECT category, MAX(price) AS max_price, MIN(price) AS
min_price, SUM(quantity) AS total_quantityFROM productsGROUP BY category;上述语句将products表按照category字段进行分类汇总,并计算每个分类的最高价格、最低价格和总数量。
4. 过滤结果:SELECT category, COUNT(*) AS totalFROM productsWHERE price > 100GROUP BY category;上述语句将products表按照category字段进行分类汇总,并计算价格大于100的行数。
这些示例展示了一些常见的MySQL分类汇总语句,你可以根据具体的需求进行修改和扩展。
mysql排序查询语句MySQL是一种常用的关系型数据库管理系统,提供了丰富的排序查询语句来满足不同的需求。
下面列举了十个常用的MySQL排序查询语句,以及它们的使用场景和示例。
1. 按照单一字段升序排序场景:需要按照某个字段的值进行升序排序,例如按照学生的学号排序。
示例:SELECT * FROM students ORDER BY student_id ASC;2. 按照单一字段降序排序场景:需要按照某个字段的值进行降序排序,例如按照商品的价格排序。
示例:SELECT * FROM products ORDER BY price DESC;3. 按照多个字段进行排序场景:需要按照多个字段的值进行排序,例如按照学生的年级和成绩排序。
示例:SELECT * FROM students ORDER BY grade ASC, score DESC;4. 按照字段的长度排序场景:需要按照字段的长度进行排序,例如按照评论的字数排序。
示例:SELECT * FROM comments ORDER BYLENGTH(content) DESC;5. 按照字段的字母顺序排序场景:需要按照字段的字母顺序进行排序,例如按照商品的名称排序。
示例:SELECT * FROM products ORDER BY name COLLATE utf8_unicode_ci ASC;6. 按照字段的日期排序场景:需要按照字段的日期进行排序,例如按照订单的下单时间排序。
示例:SELECT * FROM orders ORDER BY order_date DESC;7. 按照字段的月份排序场景:需要按照字段的月份进行排序,例如按照文章的发布月份排序。
示例:SELECT * FROM articles ORDER BY MONTH(publish_date) ASC;8. 按照字段的年份排序场景:需要按照字段的年份进行排序,例如按照员工的入职年份排序。
MySQL服务的配置和使用修改MySQL管理员的口令:mysqladmin –u root password 密码字符串如:连接MySQL服务器,使用命令:mysql [-h 主机名或IP地址] [-u 用户名] [-p]如:mysql –u root –p如已有密码需修改root密码用命令: mysqladmin –u root –p password 新密码字符串如:mysqladmin –u root –p password 111111mysqldmin –u root password 111111创建数据库格式为:CREATE DATABASE 数据库名称;如:mysql>create database abc; 默认创建数据库保存在/var/lib/mysql 中查看数据库是 mysql>show abc;选择数据库是 USE 数据库名称; 如:mysql>use abc;删除数据库是 DROP DATABASE 数据库名称;如:mysql>drop database abc;数据库的创建和删除创建表是CREATE TABLE 表名称(字段1,字段2,…[表级约束]) [TYPE=表类型];其中字段(1,2 )格式为:字段名字段类型[字段约束]如创建一个表student,如下:mysql>create table student (sno varchar(7) not null, 字段不允许为空sname varchar (20 )not null,ssex char (1) default ‘t’,sbirthday date,sdepa char (20),primary key (sno) 表的主键);可用describe命令查看表的结构。
默认表的类型为MYISAM,并在/var/lib/mysql/abc 目录下建立student.frm(表定义文件),student.MDY(数据文件),stedent.MYI(索引文件)。
复制表CREATE TABLE 新表名称LIKE 原表名称;如:mysql>create table xtable like student;删除表DROP TABLE 表名称1[表名称2…];如:mysql> drop table xtale;修改表ALTER TABLE 表名称更改动作1[动作2];动作有ADD(增加) DROP(删除)CHANGE、MODIFY(更改字段名和类型)RENAME增加字段:mysql>alter table student add saddress varchar(25);更改字段名和字段类型:mysql>alter table student change saddress sremark test;即使不更改字段类型也要给出字段类型如:mysql>alter table student change saddress sremark varchar (25);更改字段类型:mysql> alter table student modify sremark varchar(25); 删除字段:mysql>alter table student drop sremark;更改表名称:mysql>alter table student rename to xs;表中数据的插入、删除和修改插入记录:INSERT INTO 表名称(字段名1,字段名2…V ALUES(字段1的值,字段2的值如:mysql>insert into student (sno,sname,ssex,sbirthday,sdepa)values(‘0321001’,’Liu Tao’,dagault,19870201,’math’);查看表 mysql>select * from student;插入与前面相同的记录,可用insert命令的缩写格式,如: mysql>insert into student values (‘0321001’, ‘Liu Tao’, default, 19870201, ‘mth’);如果字段名列表中没有给出表中的某些字段,那么这些字段设置为默认值,如:mysql>insert into student (sno,sname,sbirthday)values(‘0321002’,’Wang Jun’,1870112);一个单独的insert语句中可使用多个valuse字句,插入多条记录,如:mysql>insert into student values(‘0322001’, ‘Zhang Liaoyun’, ‘f’ 1971102,’computer’),(‘0322002’, ‘Li Ming’, ‘t’ 1971105,’computer’);删除记录:DELETE FROM 表名称WHERE 条件表达式;如:mysql>delete from student where sno=’0321002’;删除student表中sno字段值前4位为‘0322’的记录如:my sql>delete from student where left (sno,4)=’0322’;删除所以记录,可以不带where字句如:mysql>delete from student;删除所以记录可以用命令truncate 删除表,然后重建表,所以比delete命令快如:mysql>truncate table student;修改记录UPDATE 表名称SET 字段名1=字段值1WHERE 条件表达式如:mys ql>update student set sbirthday=1920113, sdepa=’math’ where sno=’0321002’;索引的创建与删除在创建表的同时创建索引创建表时,可用INDEX字句或UNIQUE(字段值必须惟一)字句创建索引如:创建课程表course, 课程编号cno字段为主键,课程名称cname 字段创建一个名为can的索引mysql>create table course(cno varchar(5) not null,cname varchar(30) not null,teacher varchar(20),primary key (cno),index can (cname));向已存在的表添加索引 CREATE [UNIQUE ] INDEX 索引名ON 表名称(字段名1[(长度)]);如:mysql>create index sna on student (sname);对于类型为CHAR和V ARCHAR的字段建立索引时还可指定长度值,类型为BLOB和TEXT的字段索引时必须指定长度值。
如mysql>create index sna on student (sname(10));删除索引 DROP INDEX 索引ON表名称;如:mysql>drop index sna on student;用户的创建和删除初始化时有5个MySQL授权表,其中host、tables_priv和columnts_priv 是空的,表user和db决定了MySQL默认的访问规则。
默认有mysql和test两个数据库。
授权表:user 用户从哪些主机可以连接到数据库服务器,以及对所以数据库的访问权限(全局权限)db 用户可以使用哪些权限,以及对数据库执行哪些操作(数据库级权限)host 当表db 中的host 字段值为空时,用户从哪些主机可以连接到数据库服务器。
tables_priv 连接的用户可以访问哪些表(表级权限)columnts_priv 连接的用户可以访问哪些字段(字段级权限)创建新用户以MySQL管理员连接到数据库服务器:#mysql –u root –p创建新用户guess并设置密码,同时可以从任何主机连接数据库服务器:mysql>insert into er (host,user,password)values (‘%’,’gusee’,password(‘guest’));使用password()函数,密码是加密的重载MySQL授权表:mysql>flush privileges;远程客户端连接数据库服务器:#mysql –h 192.168.0.50 –u guess –p 开放服务器的TCP断口3306查看当前用户可用数据库:show database删除用户mysql>delete from er where user=’guest’;mysql>flush privileges; 重载MySQL授权表更改用户密码如:更改guset密码为123456mysql>update er set password=password(‘123456’) where user =’guset’;mysql>flush privileges;或者是mysql>se t password for guset@’%’=password(‘123456’);用户权限的设置在表user、db和host中,所有字段声明为ENUM(‘N’,’Y’),默认是‘N’;在表tables_priv和columns_priv中,权限字段声明为SET类型修改授权表中的访问权限有两中方法,一是使用INSERT、UPDATE和DELETE等DML语句,另一中是GRANT和GRVOKE语句使用GRANT语句授权:格式如下:GRANT 权限列表[(字段列表)] on 数据库名称.表名称TO 用户名@域名或IP地址[INDETIFIED BY ‘密码值’] [WITH CRANT OPTION];授权哪个用户能连接,从哪连接如:授权用户guest从任意主机连接数据库服务器,并具有完全访问数据库abc的权限。
Mysql>grant all on abc.* to guset@’%’ identified by ‘guest’注意几点:如指定用户不存在,则创建该新用户;‘权限列表’处ALL表示授予全部权限,USAGE表不授予任何权限。
‘数据库名称.表名称’处可以使用通配符“*”。
如“abc.*”表数据库abc中所有表‘用户名@域名或IP地址’设置谁能连,从哪连。
用户名不能用通配符,但可以用‘ ’空字符串,表任何用户;域名或IP地址可以用通配符“%”,使用是用单引号括起来。