찾다
데이터 베이스MySQL 튜토리얼MySQL 시작하기 튜토리얼 4 - 테이블 생성 및 테이블에 데이터 로드



1. 테이블 생성

데이터베이스를 생성하는 것은 쉬운 부분이지만, 지금은 SHOW What처럼 비어 있습니다. TABLES는 다음을 알려줍니다.

mysql> SHOW TABLES; Empty set (0.00 sec)

어려운 부분은 데이터베이스 구조가 무엇인지, 즉 필요한 데이터베이스 테이블이 무엇인지, 각 데이터베이스 테이블에 어떤 열이 있는지 결정하는 것입니다.

각 애완동물에 대한 기록이 담긴 테이블이 필요합니다. 애완동물 테이블이라고 할 수 있으며, 최소한 각 동물의 이름이 포함되어야 합니다. 이름 자체는 별로 흥미롭지 않기 때문에 표에 추가 정보가 포함되어야 합니다. 예를 들어, 가족 중에 애완동물을 키우는 사람이 두 명 이상인 경우 각 동물의 주인을 나열할 수 있습니다. 종이나 성별과 같은 기본적인 설명 정보를 기록할 수도 있습니다.

나이는 어떻게 되시나요? 재미있을 수도 있지만 데이터베이스에 저장하는 것은 좋은 일이 아닙니다. 시간이 지남에 따라 연령이 변경되므로 기록을 계속 업데이트해야 합니다. 대신 생일과 같은 고정된 값을 저장해 두어 나이가 필요할 때마다 현재 날짜와 생년월일의 차이로 계산할 수 있도록 하는 것이 좋습니다. MySQL은 날짜 연산 기능을 제공하므로 어렵지 않습니다. 나이 대신 생년월일을 저장하면 다음과 같은 장점도 있습니다.

다가오는 애완동물 생일 알림 생성과 같은 작업에 데이터베이스를 사용할 수 있습니다. (이런 종류의 쿼리가 다소 어리석다고 생각된다면 컴퓨터가 개인적인 연락을 용이하게 하기 때문에 곧 생일 축하 메시지가 전송될 기업 데이터베이스에서 고객을 식별하는 것과 동일한 문제라는 점에 유의하십시오.)

·              계산합니다. 현재 날짜뿐만 아니라 날짜를 기준으로 한 나이입니다. 예를 들어, 데이터베이스에 사망 날짜를 저장하면 애완동물이 사망했을 때 몇 살이었는지 쉽게 계산할 수 있습니다.

애완동물 테이블에 다른 유용한 정보가 있을 수도 있지만 지금은 이름, 소유자, 종, 성별, 생년월일 및 사망일 등 이것만으로 충분합니다.

CREATE TABLE 문을 사용하여 데이터베이스 테이블의 레이아웃을 지정하세요.

mysql> CREATE TABLE pet (name VARCHAR(20), owner VARCHAR(20),     -> species VARCHAR(20), sex CHAR(1), birth DATE, death DATE);

VARCHAR은 열 값이 가변 길이이므로 이름, 소유자 및 종 열에 적합합니다. 열의 길이가 모두 같을 필요는 없으며 20개일 필요도 없습니다. 1에서 65535 사이의 길이를 선택하고 가장 적합한 값을 선택할 수 있습니다. (부적절하게 선택하여 더 긴 필드가 필요한 경우 MySQL에서는 ALTER TABLE 문을 제공합니다.)

여러 유형의 값을 사용하여 동물 기록을 나타낼 수 있습니다. , 예를 들어 "m"과 "f" 또는 "남성"과 "여성"입니다. 단일 문자 "m"과 "f"를 사용하는 것이 가장 쉬운 방법입니다.

분명히 출생 및 사망 열은 DATE 데이터 클래스를 사용해야 합니다.

데이터베이스 테이블을 생성한 후 SHOW TABLES는 다음과 같은 출력을 생성해야 합니다.

mysql> SHOW TABLES; +---------------------+
| Tables in menagerie |
+---------------------+
| pet                 |
+---------------------+

테이블이 예상한 대로 생성되었는지 확인하려면 DESCRIBE 문을 사용하세요.

mysql> DESCRIBE pet;
+---------+-------------+------+-----+---------+-------+
| Field   | Type        | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+-------+
| name    | varchar(20) | YES  |     | NULL    |       |
| owner   | varchar(20) | YES  |     | NULL    |       |
| species | varchar(20) | YES  |     | NULL    |       |
| sex     | char(1)     | YES  |     | NULL    |       |
| birth   | date        | YES  |     | NULL    |       |
| death   | date        | YES  |     | NULL    |       |
+---------+-------------+------+-----+---------+-------+

예를 들어 테이블에 있는 열의 이름이나 유형을 잊어버린 경우 언제든지 DESCRIBE를 사용할 수 있습니다.

2. 테이블에 데이터 로드

테이블을 생성한 후 내용을 입력해야 합니다. 이 작업은 LOAD DATA 및 INSERT 문을 통해 수행할 수 있습니다.

당신의 애완동물 기록이 다음과 같다고 가정해 보겠습니다. (MySQL의 예상 날짜 형식은 YYYY-MM-DD라고 가정합니다. 이는 익숙한 형식과 다를 수 있습니다.)

tr>다이앤 1997 -12-09
name owner species sex birth death
Fluffy Harold cat f 1993-02-04
Claws Gwen cat m 1994-03-17
Buffy Harold dog f 1989-05-13
Fang Benny dog m 1990-08-27
Bowser Diane dog m 1979-08-31 1995-07-29
Chirpy Gwen bird f 1998-09-11
Whistler Gwen bird
1997-12-09
Slim Benny snake m 1996-04-29
이름
소유자 성별 출생 사망
푹신푹신 td> 해롤드 고양이 f 1993-02-04
발톱 그웬 고양이 m 1994-03-17 td>
버피 해롤드 f 1989-05-13
베니 m 1990-08-27
바우저 m 1979-08-31 1995-07-29
치르피 그웬 f 1998-09-11
휘슬러 그웬
슬림 베니 스네이크 td>m 1996-04-29

因为你是从一个空表开始的,填充它的一个简易方法是创建一个文本文件,每个动物各一行,然后用一个语句将文件的内容装载到表中。

你可以创建一个文本文件“pet.txt”,每行包含一个记录,用定位符(tab)把值分开,并且以CREATE TABLE语句中列出的列次序给出。对于丢失的值(例如未知的性别,或仍然活着的动物的死亡日期),你可以使用NULL值。为了在你的文本文件中表示这些内容,使用\N(反斜线,字母N)。例如,Whistler鸟的记录应为(这里值之间的空白是一个定位符):

name owner species sex birth death
Whistler Gwen bird \N 1997-12-09 \N

要想将文本文件“pet.txt”装载到pet表中,使用这个命令:

mysql> LOAD DATA LOCAL INFILE '/path/pet.txt' INTO TABLE pet;

请注意如果用Windows中的编辑器(使用\r\n做为行的结束符)创建文件,应使用:

mysql> LOAD DATA LOCAL INFILE '/path/pet.txt' INTO TABLE pet     -> LINES TERMINATED BY '\r\n';

(在运行OS X的Apple机上,应使用行结束符'\r'。)

如果你愿意,你能明确地在LOAD DATA语句中指出列值的分隔符和行尾标记,但是默认标记是定位符和换行符。这对读入文件“pet.txt”的语句已经足够。

如果该语句失败,可能是你安装的MySQL不与使用默认值的本地文件兼容。

如果想要一次增加一个新记录,可以使用INSERT语句。最简单的形式是,提供每一列的值,其顺序与CREATE TABLE语句中列的顺序相同。假定Diane把一只新仓鼠命名为Puffball,你可以使用下面的INSERT语句添加一条新记录:

mysql> INSERT INTO pet     -> VALUES ('Puffball','Diane','hamster','f','1999-03-30',NULL);

注意,这里字符串和日期值均为引号扩起来的字符串。另外,可以直接用INSERT语句插入NULL代表不存在的值。不能使用LOAD DATA中所示的的\N。

从这个例子,你应该能看到涉及很多的键入用多个INSERT语句而非单个LOAD DATA语句装载你的初始记录。

 以上就是MySQL入门教程4 —— 创建表并将数据装入表的内容,更多相关内容请关注PHP中文网(www.php.cn)! 


성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
MySQL : Blob 및 기타없는 SQL 스토리지, 차이점은 무엇입니까?MySQL : Blob 및 기타없는 SQL 스토리지, 차이점은 무엇입니까?May 13, 2025 am 12:14 AM

mysql'sblobissuilableforstoringbinarydatawithinareldatabase, whilenosqloptionslikemongodb, redis, and cassandraofferflexible, scalablesolutionsforunstuctureddata.blobissimplerbutcanslowwownperformance를 사용하는 것들보업 betterscal randaysand

MySQL 추가 사용자 : 구문, 옵션 및 보안 모범 사례MySQL 추가 사용자 : 구문, 옵션 및 보안 모범 사례May 13, 2025 am 12:12 AM

TOADDAUSERINMYSQL, 사용 : CreateUser'UserName '@'host'IdentifiedBy'Password '; 여기서'showTodoitseciRely : 1) ChoosetheHostCareLyTocon trolaccess.2) setResourcelimitswithOptionslikemax_queries_per_hour.3) Usestrong, iriquepasswords.4) enforcessl/tlsconnectionswith

MySQL : 문자열 데이터 유형을 피하는 방법 일반적인 실수?MySQL : 문자열 데이터 유형을 피하는 방법 일반적인 실수?May 13, 2025 am 12:09 AM

toavoidcommonmistakeswithstringdatatypesinmysql, stroundStringTypenuances, chooseTherightType, andManageEncodingAndCollationSettingSefectively.1) usecharforfixed-lengthstrings, varcharvariable-length, andtext/blobforlargerdata.2) setcarcatter

MySQL : 문자열 데이터 유형 및 열거?MySQL : 문자열 데이터 유형 및 열거?May 13, 2025 am 12:05 AM

mysqloffersechar, varchar, text, anddenumforstringdata.usecharforfixed-lengthstrings, varcharerforvariable 길이, 텍스트 forlarger 텍스트, andenumforenforcingdataantegritystofvalues.

MySQL Blob : Blobs 요청을 최적화하는 방법MySQL Blob : Blobs 요청을 최적화하는 방법May 13, 2025 am 12:03 AM

mysqlblob 요청 최적화는 다음 전략을 통해 수행 할 수 있습니다. 1. Blob 쿼리의 빈도를 줄이거나 독립적 인 요청을 사용하거나 지연로드를 사용하십시오. 2. 적절한 Blob 유형 (예 : TinyBlob)을 선택하십시오. 3. Blob 데이터를 별도의 테이블로 분리하십시오. 4. 응용 프로그램 계층에서 블로브 데이터를 압축합니다. 5. Blob Metadata를 색인하십시오. 이러한 방법은 실제 애플리케이션에서 모니터링, 캐싱 및 데이터 샤딩을 결합하여 성능을 효과적으로 향상시킬 수 있습니다.

MySQL에 사용자 추가 : 완전한 튜토리얼MySQL에 사용자 추가 : 완전한 튜토리얼May 12, 2025 am 12:14 AM

MySQL 사용자를 추가하는 방법을 마스터하는 것은 데이터베이스 관리자 및 개발자가 데이터베이스의 보안 및 액세스 제어를 보장하기 때문에 데이터베이스 관리자 및 개발자에게 중요합니다. 1) CreateUser 명령을 사용하여 새 사용자를 만듭니다. 2) 보조금 명령을 통해 권한 할당, 3) FlushPrivileges를 사용하여 권한이 적용되도록하십시오.

MySQL 문자열 데이터 유형 마스터 링 : Varchar vs. Text vs. CharMySQL 문자열 데이터 유형 마스터 링 : Varchar vs. Text vs. CharMay 12, 2025 am 12:12 AM

ChooseCharfixed-lengthdata, varcharforvariable-lengthdata, andtextforlargetextfields.1) charisefficientsconsentent-lengthdatalikecodes.2) varcharsuitsvariable-lengthdatalikeNames, 밸런싱 플렉스 및 성능

MySQL : 문자열 데이터 유형 및 인덱싱 : 모범 사례MySQL : 문자열 데이터 유형 및 인덱싱 : 모범 사례May 12, 2025 am 12:11 AM

MySQL에서 문자열 데이터 유형 및 인덱스를 처리하기위한 모범 사례는 다음과 같습니다. 1) 고정 길이의 Char, 가변 길이의 Varchar 및 큰 텍스트의 텍스트와 같은 적절한 문자열 유형 선택; 2) 인덱싱에 신중하고, 과도한 인덱싱을 피하고, 공통 쿼리에 대한 인덱스를 만듭니다. 3) 접두사 인덱스 및 전체 텍스트 인덱스를 사용하여 긴 문자열 검색을 최적화합니다. 4) 인덱스를 작고 효율적으로 유지하기 위해 인덱스를 정기적으로 모니터링하고 최적화합니다. 이러한 방법을 통해 읽기 및 쓰기 성능의 균형을 맞추고 데이터베이스 효율성을 향상시킬 수 있습니다.

See all articles

핫 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 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.