데이터 베이스 MySQL 튜토리얼 MySQL新手入门指南--快速参考

MySQL新手入门指南--快速参考

Jun 07, 2016 pm 05:59 PM

MySQL新手入门指南--快速参考

一、SQL速成


  以下是一些重要的SQL快速参考,有关SQL的语法和在标准SQL上增加的特性,请查询MySQL手册。

  1.创建表

  表是数据库的最基本元素之一,表与表之间可以相互独立,也可以相互关联。创建表的基本语法如下:

  create table table_name

  (column_name datatype {identity |null|not null},

  …)

  其中参数table_name和column_name必须满足用户数据库中的识别器(identifier)的要求,参数datatype是一个标准的SQL类型或由用户数据库提供的类型。用户要使用non-null从句为各字段输入数据。

  create table还有一些其他选项,如创建临时表和使用select子句从其他的表中读取某些字段组成新表等。还有,在创建表是可用PRIMARY KEY、KEY、INDEX等标识符设定某些字段为主键或索引等。

  书写上要注意:

  在一对圆括号里的列出完整的字段清单。

  字段名间用逗号隔开。

  字段名间的逗号后要加一个空格。

  最后一个字段名后不用逗号。

  所有的SQL陈述都以分号";"结束。

  例:

  mysql> CREATE TABLE test (blob_col BLOB, index(blob_col(10)));

  2.创建索引

  索引用于对数据库的查询。一般数据库建有多种索引方案,每种方案都精于某一特定的查询类。索引可以加速对数据库的查询过程。创建索引的基本语法如下:

  create index index_name

  on table_name (col_name[(length)],... )

  例:

  mysql> CREATE INDEX part_of_name ON customer (name(10));

  3.改变表结构

  在数据库的使用过程中,有时需要改变它的表结构,包括改变字段名,甚至改变不同数据库字段间的关系。可以实现上述改变的命令是alter,其基本语法如下:

  alter table table_name alter_spec [, alter_spec ...]

  例:

  mysql> ALTER TABLE t1 CHANGE a b INTEGER;

  4.删除数据对象

  很多数据库是动态使用的,有时可能需要删除某个表或索引。大多数数据库对象可以下面的命令删除:

  drop object_name

  mysql> DROP TABLE tb1;



5.执行查询


  查询是使用最多的SQL命令。查询数据库需要凭借结构、索引和字段类型等因素。大多数数据库含有一个优化器(optimizer),把用户的查询语句转换成可选的形式,以提高查询效率。


  值得注意的是MySQL不支持SQL92标准的嵌套的where子句,即它只支持一个where子句。其基本语法如下:


  SELECT [STRAIGHT_JOIN] [SQL_SMALL_RESULT] [SQL_BIG_RESULT] [HIGH_PRIORITY] [DISTINCT | DISTINCTROW | ALL]


  select_expression,... [INTO {OUTFILE | DUMPFILE} 'file_name' export_options] [FROM table_references [WHERE where_definition] [GROUP BY col_name,...] [HAVING where_definition] [ORDER BY {unsigned_integer | col_name | formula} [ASC | DESC] ,...] [LIMIT [offset,] rows] [PROCEDURE procedure_name] ]


  其中where从句是定义选择标准的地方,where_definition可以有不同的格式,但都遵循下面的形式:


  字段名操作表达式


  字段名操作字段名


  在第一种形式下,标准把字段的值与表达式进行比较;在第二种形式下,把两个字段的值进行比较。根据所比较的数据类型,search_condition中的操作可能选以下几种:


  = 检查是否相等


  != 检查是否不等


  > (或>=) 检查左边值是否大于(或大于等于)右边值


  

  is [not] null 检查左边是否为空值


  在这里,可以用通配符_代表任何一个字符,%代表任何字符串。使用关键字、和可以生成复杂的词,它们运行检查时使用布尔表达式的多重标准集。


  例:


  mysql> select t1.name, t2.salary from employee AS t1, info AS t2 where t1.name = t2.name;


  mysql> select college, region, seed from tournament


  ORDER BY region, seed;


  mysql> select col_name from tbl_name WHERE col_name > 0;


  6.修改表中数据


  在使用数据库过程中,往往要修改其表中的数据,比如往表中添加新数据,删除表中原有数据,或对表中原有数据进行更改。它们的基本语法如下:


  数据添加:


  insert [into] table_name [(column(s))]


  values (expression(s))


  例:


  mysql> INSERT INTO tbl_name (col1,col2) VALUES(15,col1*2);


  数据删除:


  delete from table_name where search_condition


  数据更改:


  update table_name


  set column1=expression1,


  column2=expression2,…


  where search_condition


  7.数据库切换


  当存在多个数据库时,可以用下面的命令定义用户想使用的数据库:


  use database_name


  8.统计函数


  SQL有一些统计函数,它们对于生成数据表格很有帮助。下面介绍几个常用的统计函数:


  sum (exepression) 计算表达式的和


  avg (exepression) 计算表达式的平均值


  count (exepression) 对表达式进行简单的计数


  count (*) 统计记录数


  max (exepression) 求最大值


  min (exepression) 求最小值


  其中exepression为任何有效的SQL表达式,它可以是一个或多个记录,也可以是别的SQL函数的组合。



二、MySQL使用导引


  1.运用MySQL建立新数据库


  在shell下运行:


  $>mysqladmin create database01


  Database "database01" created.


  2.启动MySQL


  在shell下运行:


  $>mysql


  Welcome to the MySQL monitor. Commands end with ; or g.


  Your MySQL connection id is 22 to server version: 3.21. 29a-gamma-debug


  Type 'help' for help.


  3.更换数据库


  mysql>use database01


  database changed.


  4.创建表


  mysql>create table table01 (field01 integer, field02 char(10));


  Query OK, 0 rows affected (0.00 sec)


  5.列出表清单


  mysql>show tables;


  Tables in database01


  Table01


  table02


  6.列出表中的字段清单


  mysql>show columns from table01;


  Field Type Null Key Default Extra


  field01 int(11) YES


  field02 char(10) YES


  7.表的数据填写


  插入数据


  mysql>insert into table01 (field01, field02) values (1, 'first');


  Query OK, 1 row affected (0.00 sec)


  8.字段的增加


  ...一次一个字段


  mysql>alter table table01 add column field03 char(20);


  Query OK, l row affected (0.04 sec)


  Records: 1 Duplicates: 0 Warnings: 0


  ...一次多个字段


  mysql>alter table table01 add column field04 date, add column field05 time;


  Query OK, l row affected (0.04 sec)


  Records: 1 Duplicates: 0 Warnings: 0


  注意:每一列都必须以"add column"重新开始。


  它运行了吗?让我们看看。


  mysql>select * from table01;


  field01 field02 field03 field04 field05


  1 first NULL NULL NULL



9.多行命令输入


  MySQL命令行界面允许把陈述作为一行输入,也可以把它展开为多行输入。这两者之间并没有语法上的区别。使用多行输入,你可以将SQL陈述一步步分解,从而使你更容易理解。


  在多行方式下,注释器把每一行都添加到前面的行后,直到你用分号";"来结束这个SQL陈述。一旦键入分号并按回车键,这个陈述即被执行。


  下面的例子是同一个严格的SQL陈述的两种输入方法:


  单行输入


  Mysql>create table table33 (field01 integer, field02 char(30));


  多行输入


  Mysql>create table table33


  ->(field01


  ->integer,


  ->field02


  ->char(30));


  注意不能将单词断开,如:


  正确


  mysql>create table table33


  ->( field01


  ->integer,


  ->field02


  ->char(30));


  错误


  mysql>create table table33


  ->( field01 inte


  ->ger,


  ->field02


  ->char(30));


  当插入或更改数据时,不能将字段的字符串展开到多行里,否则硬回车将被储存到数据中:


  标准操作


  mysql>insert into table33 (field02)


  ->values


  ->('who thought of foo?');


  硬回车储存到数据中


  mysql>insert into table33 (field02)


  ->values


  ->('who thought


  ->of foo?');


  结果如下:


  mysql>select * from table33;


  field01 field02


  NULL who thought of foo?


  NULL who thought


  Of foo?


  10.表的数据嵌入


  mysql>insert into table01 (field01, field02, field03, field04, field05) values


  ->(2, 'second', 'another', '1999-10-23', '10:30:00');


  Query OK, 1 row affected (0.00 sec)


  标准日期格式是"yyyy-mm-dd"。


  标准时间格式是"hh:mm:ss"。


  引号内要求所给的是上述的标准日期和时间格式。


  日期也可以"yyyymmdd"形式,时间也可以"hhmmss"形式输入,但其值不需要再加引号。


  数字值不需要加引号。这种保存与数据类型无关,这些数据类型都有格式化的专栏来包含(例如:文本,日期,时间,整数等)。


  MySQL有一个很有用的命令缓冲区。它保存着你目前已经键入的SQL语句利用它,对于相同的命令,你就不必一遍又一遍地重复输入。下一步我们就来看这样的一个例子。


  利用命令缓冲区(及任意的日期和时间格式)增加另一个数据


  按两次键盘上的向上箭头键。


  回车。


  在圆括号内输入新的值,并以分号结尾。


  (3, 'a third', 'more', 19991024, 103004);


  回车。


  新值存在里面了吗?


  mysql>select * from table01;


  field01 field02 field03 field04 field05


  1 first NULL NULL NULL


  2 second another 1999-10-23 10:30:00


  3 a third more 1999-10-24 10:30:04


  11.表的数据更新


  一次修改一个字段


  再次注意语法。文本需要加引号但数字不要。


  mysql>update table01 set field03='new info' where field01=1;


  Query OK, 1 row affected (0.00 sec)


  一次改变多个字段


  记住在每一个更新的字段间用逗号隔开。


  mysql>update table01 set field04=19991022, field05=062218 where field01=1;


  Query OK, 1 row affected (0.00 sec)


  一次更新多个数据


  mysql>update table01 set field05=152901 where field04>19990101;


  Query OK, 3 rows affected (0.00 sec)


  12.删除数据


  mysql>delete from table01 where field01=3;


  Query OK, 1 row affected (0.00 sec)


  13.退出


  mysql>quit


  Bye


  现在你已经了解了一些运行MySQL中的数据库的根本命令。由于MySQL是通过执行SQL调用来操作的,在你的处理过程中需要一个强有力工具的充足的数组。例如,通过联接相关的字段,你可以同时显示几个表中的数据。同样,SQL允许综合显示、更新或者删除多个符合具体标准的数据。如果你还想精通掌握它,下一步就要学习所有SQL的知识。


  另外说明一下,MySQL提供了很好的网络操作安全特性。要想了解MySQL的安全及其它特性的详情,请查询MySQL网站:http://www.mysql.com


  为了方便大家查询使用MySQL手册, 我们将官方手册(Manaul)做在光盘的/docs/manaul/mysql目录下.大家可以用浏览器浏览查询.
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

MySQL에서 인덱스를 사용하는 것보다 전체 테이블 스캔이 더 빠를 수 있습니까? MySQL에서 인덱스를 사용하는 것보다 전체 테이블 스캔이 더 빠를 수 있습니까? Apr 09, 2025 am 12:05 AM

전체 테이블 스캔은 MySQL에서 인덱스를 사용하는 것보다 빠를 수 있습니다. 특정 사례는 다음과 같습니다. 1) 데이터 볼륨은 작습니다. 2) 쿼리가 많은 양의 데이터를 반환 할 때; 3) 인덱스 열이 매우 선택적이지 않은 경우; 4) 복잡한 쿼리시. 쿼리 계획을 분석하고 인덱스 최적화, 과도한 인덱스를 피하고 정기적으로 테이블을 유지 관리하면 실제 응용 프로그램에서 최상의 선택을 할 수 있습니다.

Windows 7에 MySQL을 설치할 수 있습니까? Windows 7에 MySQL을 설치할 수 있습니까? Apr 08, 2025 pm 03:21 PM

예, MySQL은 Windows 7에 설치 될 수 있으며 Microsoft는 Windows 7 지원을 중단했지만 MySQL은 여전히 ​​호환됩니다. 그러나 설치 프로세스 중에 다음 지점이 표시되어야합니다. Windows 용 MySQL 설치 프로그램을 다운로드하십시오. MySQL의 적절한 버전 (커뮤니티 또는 기업)을 선택하십시오. 설치 프로세스 중에 적절한 설치 디렉토리 및 문자를 선택하십시오. 루트 사용자 비밀번호를 설정하고 올바르게 유지하십시오. 테스트를 위해 데이터베이스에 연결하십시오. Windows 7의 호환성 및 보안 문제에 주목하고 지원되는 운영 체제로 업그레이드하는 것이 좋습니다.

MySQL : 쉽게 학습하기위한 간단한 개념 MySQL : 쉽게 학습하기위한 간단한 개념 Apr 10, 2025 am 09:29 AM

MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1) 데이터베이스 및 테이블 작성 : CreateAbase 및 CreateTable 명령을 사용하십시오. 2) 기본 작업 : 삽입, 업데이트, 삭제 및 선택. 3) 고급 운영 : 가입, 하위 쿼리 및 거래 처리. 4) 디버깅 기술 : 확인, 데이터 유형 및 권한을 확인하십시오. 5) 최적화 제안 : 인덱스 사용, 선택을 피하고 거래를 사용하십시오.

MySQL과 Mariadb가 공존 할 수 있습니다 MySQL과 Mariadb가 공존 할 수 있습니다 Apr 08, 2025 pm 02:27 PM

MySQL 및 MariaDB는 공존 할 수 있지만주의해서 구성해야합니다. 열쇠는 각 데이터베이스에 다른 포트 번호와 데이터 디렉토리를 할당하고 메모리 할당 및 캐시 크기와 같은 매개 변수를 조정하는 것입니다. 연결 풀링, 애플리케이션 구성 및 버전 차이도 고려해야하며 함정을 피하기 위해 신중하게 테스트하고 계획해야합니다. 두 개의 데이터베이스를 동시에 실행하면 리소스가 제한되는 상황에서 성능 문제가 발생할 수 있습니다.

Redshift Zero ETL과의 RDS MySQL 통합 Redshift Zero ETL과의 RDS MySQL 통합 Apr 08, 2025 pm 07:06 PM

데이터 통합 ​​단순화 : AmazonRdsMysQL 및 Redshift의 Zero ETL 통합 효율적인 데이터 통합은 데이터 중심 구성의 핵심입니다. 전통적인 ETL (추출, 변환,로드) 프로세스는 특히 데이터베이스 (예 : AmazonRDSMySQL)를 데이터웨어 하우스 (예 : Redshift)와 통합 할 때 복잡하고 시간이 많이 걸립니다. 그러나 AWS는 이러한 상황을 완전히 변경 한 Zero ETL 통합 솔루션을 제공하여 RDSMYSQL에서 Redshift로 데이터 마이그레이션을위한 단순화 된 거의 실시간 솔루션을 제공합니다. 이 기사는 RDSMYSQL ZERL ETL 통합으로 Redshift와 함께 작동하여 데이터 엔지니어 및 개발자에게 제공하는 장점과 장점을 설명합니다.

Bangla 부분 모델 검색의 Laravel Eloquent Orm) Bangla 부분 모델 검색의 Laravel Eloquent Orm) Apr 08, 2025 pm 02:06 PM

Laraveleloquent 모델 검색 : 데이터베이스 데이터를 쉽게 얻을 수 있습니다. 이 기사는 데이터베이스에서 데이터를 효율적으로 얻는 데 도움이되는 다양한 웅변 모델 검색 기술을 자세히 소개합니다. 1. 모든 기록을 얻으십시오. 모든 () 메소드를 사용하여 데이터베이스 테이블에서 모든 레코드를 가져옵니다. 이것은 컬렉션을 반환합니다. Foreach 루프 또는 기타 수집 방법을 사용하여 데이터에 액세스 할 수 있습니다 : Foreach ($ postas $ post) {echo $ post->

MySQL 사용자와 데이터베이스의 관계 MySQL 사용자와 데이터베이스의 관계 Apr 08, 2025 pm 07:15 PM

MySQL 데이터베이스에서 사용자와 데이터베이스 간의 관계는 권한과 테이블로 정의됩니다. 사용자는 데이터베이스에 액세스 할 수있는 사용자 이름과 비밀번호가 있습니다. 권한은 보조금 명령을 통해 부여되며 테이블은 Create Table 명령에 의해 생성됩니다. 사용자와 데이터베이스 간의 관계를 설정하려면 데이터베이스를 작성하고 사용자를 생성 한 다음 권한을 부여해야합니다.

MySQL : 초보자를위한 데이터 관리의 용이성 MySQL : 초보자를위한 데이터 관리의 용이성 Apr 09, 2025 am 12:07 AM

MySQL은 설치가 간단하고 강력하며 데이터를 쉽게 관리하기 쉽기 때문에 초보자에게 적합합니다. 1. 다양한 운영 체제에 적합한 간단한 설치 및 구성. 2. 데이터베이스 및 테이블 작성, 삽입, 쿼리, 업데이트 및 삭제와 같은 기본 작업을 지원합니다. 3. 조인 작업 및 하위 쿼리와 같은 고급 기능을 제공합니다. 4. 인덱싱, 쿼리 최적화 및 테이블 파티셔닝을 통해 성능을 향상시킬 수 있습니다. 5. 데이터 보안 및 일관성을 보장하기위한 지원 백업, 복구 및 보안 조치.

See all articles