데이터 베이스 MySQL 튜토리얼 举例详解MySQL字符集_MySQL

举例详解MySQL字符集_MySQL

Jun 01, 2016 pm 01:56 PM
데이터베이스 테이블

举例详解MySQL字符集,下面是完整的一个例子:

1、创建数据库表

MySQL>CREATE DATABASE IF NOT EXISTS my_db default charset utf8 COLLATE utf8_general_ci;

#注意后面这句话 "COLLATE utf8_general_ci",大致意思是在排序时根据utf8校验集来排序

#那么在这个数据库下创建的所有数据表的默认字符集都会是utf8了

MySQL>create table my_table (name varchar(20) not null default '')type=myisam default charset utf8;

#这句话就是创建一个表了,制定默认字符集为utf8

2、写数据

例子1是通过PHP直接插入数据:

a.PHPMySQL_connect('localhost','user','password');mysql_select_db('my_db');//请注意,这步很关键,如果没有这步,所有的数据读写都会不正确的//它的作用是设置本次数据库联接过程中,数据传输的默认字符集//其他编程语言/接口也类似,例如 .net/c#/odbc//jdbc则设置连接字符串为类似"jdbc:mysql://localhost/db?user=user&password=123456&useUnicode=true&characterEncoding=UTF-8"mysql_query("set names utf8;");//必须将gb2312(本地编码)转换成utf-8,也可以使用iconv()函数mb_convert_encoding("insert into my_table values('测试');", "utf-8", "gb2312");?>b.php//输出本页编码为utf-8header("content-type:text/HTML; charset=utf-8");mysql_connect('localhost','user','password');mysql_select_db('my_db');mysql_query("set names utf8;");if(isset($_REQUEST['name')){//由于上面已经指定本页字符集为utf-8了,因此无需转换编码mysql_query(sprintf("insert into my_table values('%s');", $_REQUEST['name']));}$q = mysql_query("select * from my_table");while($r = mysql_fetch_row($q)){print_r($r);}?>

自此,使用utf8字符集的完整的例子结束了.

如果你想使用gb2312编码,那么建议你使用latin1作为数据表的默认字符集,这样就能直接用中文在命令行工具中插入数据,并且可以直接显示出来.而不要使用gb2312或者gbk等字符集,如果担心查询排序等问题,可以使用binary属性约束,例如:

create table my_table ( name varchar(20) binary not null default '')type=myisam default charset latin1;

附1:旧数据升级办法

以原来的字符集为latin1为例,升级成为utf8的字符集。原来的表: old_table (default charset=latin1),新表:new_table(default charset=utf8)。

第一步:导出旧数据

MySQLdump --default-character-set=latin1 -hlocalhost -uroot -B my_db --tables old_table > old.sql

第二步:转换编码(类似Unix/Linux环境下)

iconv -t utf-8 -f gb2312 -c old.sql > new.sql

或者可以去掉 -f 参数,让iconv自动判断原来的字符集

iconv -t utf-8 -c old.sql > new.sql

在这里,假定原来的数据默认是gb2312编码。

第三步:导入

修改old.sql,在插入/更新语句开始之前,增加一条sql语句:

"SET NAMES utf8;"

,保存。

MySQL -hlocalhost -uroot my_db

大功告成!!

附2:支持查看utf8字符集的MySQL客户端有

1.) MySQL-Front,据说这个项目已经被MySQL AB勒令停止了,不知为何,如果国内还有不少破解版可以下载(不代表我推荐使用破解版 :-P)。

2.) Navicat,另一款非常不错的MySQL客户端,汉化版刚出来,还邀请我试用过,总的来说还是不错的,不过也需要付费。

3.) PHPMyAdmin,开源的php项目,非常好。

4.) Linux下的终端工具(Linux terminal),把终端的字符集设置为utf8,连接到MySQL之后,执行 SET NAMES UTF8; 也能读写utf8数据了。

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 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 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

PHP를 사용하여 데이터베이스 테이블을 생성하고 관리하는 방법 PHP를 사용하여 데이터베이스 테이블을 생성하고 관리하는 방법 Sep 09, 2023 pm 04:48 PM

PHP를 사용하여 데이터베이스 테이블을 생성하고 관리하는 방법 인터넷의 급속한 발전으로 인해 데이터베이스는 다양한 웹사이트와 애플리케이션에서 없어서는 안 될 부분이 되었습니다. PHP에서는 MySQL과 같은 데이터베이스 관리 시스템(DBMS)을 사용하여 데이터베이스 테이블을 생성하고 관리할 수 있습니다. 이 문서에서는 해당 코드 예제와 함께 PHP를 사용하여 이 기능을 구현하는 방법을 설명합니다. 데이터베이스에 연결 먼저 PHP에서 데이터베이스에 연결해야 합니다. 이 기능을 구현하려면 PHP에서 제공하는 mysqli 확장이나 PDO를 사용할 수 있습니다.

데이터베이스 뷰와 테이블을 구별하는 방법 데이터베이스 뷰와 테이블을 구별하는 방법 Aug 22, 2023 am 11:27 AM

데이터베이스 뷰와 테이블은 서로 다른 특성과 용도를 지닌 데이터베이스의 두 가지 개념입니다. 테이블은 실제로 데이터베이스에 데이터를 저장하는 엔터티인 반면, 뷰는 하나 이상의 테이블에서 파생된 가상 테이블로, 방법을 지정하는 데 사용됩니다. 데이터를 제시하고 조작합니다. 테이블은 데이터 지속성이 더 높고, 뷰는 더 유연하고 편리한 데이터 액세스를 제공합니다.

데이터베이스 뷰와 테이블의 차이점은 무엇입니까? 데이터베이스 뷰와 테이블의 차이점은 무엇입니까? Sep 04, 2023 pm 03:13 PM

데이터베이스 뷰와 테이블의 차이점은 다음과 같습니다. 1. 테이블은 데이터베이스에 데이터를 저장하는 데 사용되는 물리적 구조인 반면, 뷰는 테이블 또는 여러 테이블을 기반으로 하는 쿼리 결과 집합입니다. 2. 테이블은 물리적 저장소입니다. 3. 뷰는 데이터베이스에 대한 고급 보안 메커니즘을 제공하며 테이블에는 보안 메커니즘이 없습니다. 4. 뷰는 여러 테이블을 결합할 수 있습니다. 6. 테이블은 데이터베이스의 영구 구조이지만 뷰는 그렇지 않습니다. 7. 뷰는 동일한 이름의 뷰를 생성할 수 있지만 테이블은 동일한 이름의 테이블을 생성할 수 없습니다.

NEAR 프로토콜 코인이란 무엇입니까? NEAR 프로토콜 통화의 특징은 무엇입니까? NEAR 프로토콜 코인이란 무엇입니까? NEAR 프로토콜 통화의 특징은 무엇입니까? Mar 04, 2024 pm 11:20 PM

NEARProtocol: 확장 가능하고 사용자 친화적인 블록체인 플랫폼 NEARProtocol은 확장성, 사용자 친화성 및 보안 측면에서 블록체인 기술이 직면한 문제를 해결하도록 설계된 샤딩 기술을 사용하는 블록체인 플랫폼입니다. 개발자에게 분산형 애플리케이션(dApp)을 쉽게 구축하고 배포할 수 있는 효율적이고 사용자 친화적인 플랫폼을 제공합니다. NEARProtocol은 높은 수준의 효율성과 보안을 제공하면서 블록체인 개발 장벽을 낮추도록 설계되었습니다. NEARProtocol은 샤딩 기술을 채택함으로써 대규모 거래를 더 잘 처리하고 사용자에게 더 빠른 거래 확인 시간을 제공할 수 있습니다. 전반적으로 NEARProtocol은 다음을 제공하도록 설계되었습니다.

데이터 내보내기: 맞춤형 데이터베이스 테이블 데이터 내보내기: 맞춤형 데이터베이스 테이블 Sep 02, 2023 pm 06:01 PM

이 시리즈의 첫 번째 기사에서 언급했듯이 사용자 정의 데이터베이스 테이블의 주요 문제점 중 하나는 기존 가져오기 및 내보내기 핸들러에서 처리되지 않는다는 것입니다. 이 기사는 이 문제를 해결하는 것을 목표로 하지만 현재 완전히 만족스러운 해결책은 없다는 점에 유의해야 합니다. 두 가지 시나리오를 고려해 보겠습니다. 사용자 정의 테이블은 기본 WordPress 테이블을 참조합니다. 사용자 정의 테이블은 기본 테이블과 완전히 독립적입니다. "최악의 시나리오"가 첫 번째 시나리오입니다. 사용자 활동 로그를 저장하는 사용자 정의 테이블을 예로 들어 보겠습니다. 이는 사용자 ID, 개체 ID 및 개체 유형을 참조하며, 모두 기본 WordPress 테이블에 저장된 데이터를 참조합니다. 이제 누군가 WordPress 웹사이트의 모든 데이터를 두 번째 웹사이트로 가져오려고 한다고 상상해 보세요. 예를 들어 완전히

데이터베이스 뷰와 테이블의 차이점은 무엇입니까? 데이터베이스 뷰와 테이블의 차이점은 무엇입니까? Aug 22, 2023 am 11:15 AM

데이터베이스 뷰와 데이터베이스의 테이블에는 다섯 가지 차이점이 있습니다. 1. 뷰는 데이터를 저장하지 않지만 테이블은 실제로 데이터를 저장하는 개체입니다. 2. 뷰의 데이터는 가상 테이블이며 테이블의 데이터는 가져올 수 있습니다. 3. 뷰는 쿼리문의 구조를 상속하지만 테이블에는 자체 구조 정의가 있습니다. 4. 뷰는 업데이트할 수 없지만 테이블은 이에 대한 직접 작업을 허용합니다. 기본 테이블에 대한 권한이 있으며 테이블에는 자체 액세스 권한이 있습니다.

Antec 650 전원 공급 장치 마더보드 케이블 인터페이스의 핀 수는 몇 개입니까? (Antec 650 전원 배선도) Antec 650 전원 공급 장치 마더보드 케이블 인터페이스의 핀 수는 몇 개입니까? (Antec 650 전원 배선도) Jan 03, 2024 am 10:46 AM

Antec 650w 마더보드 케이블에는 몇 개의 핀이 있습니까? Antec 650W 전원 공급 장치 마더보드의 전원 케이블은 일반적으로 마더보드에서 가장 큰 전원 인터페이스인 24핀입니다. 그 기능은 마더보드와 전원 공급 장치를 연결하여 마더보드와 기타 시스템 구성 요소에 전원을 공급하는 것입니다. 또한 Antec 650W 전원 공급 장치에는 CPU 및 독립 그래픽 카드와 같은 다른 구성 요소를 연결하기 위한 CPU8핀, PCIe6+2핀 등과 같은 다른 유형의 전원 인터페이스도 포함될 수 있습니다. 마더보드 라우팅 튜토리얼 마더보드 라우팅은 마더보드를 설계할 때 다양한 전자 부품 간에 회로를 연결하는 프로세스입니다. 이 과정에서는 회로 안정성, 신호 전송 속도, 정확도 등의 요소를 고려해야 합니다. 회로도에 따라 배선을 배선할 때 레이아웃에 주의하고 적절한 선 폭과 거리를 선택하여 피하십시오.

MySQL 테이블 구조를 최적화하여 연결 문제 해결 MySQL 테이블 구조를 최적화하여 연결 문제 해결 Jun 30, 2023 pm 01:04 PM

MySQL 연결 문제: 데이터베이스 테이블 구조를 최적화하는 방법은 무엇입니까? 데이터베이스 연결은 애플리케이션을 개발할 때 매우 중요한 부분입니다. MySQL 데이터베이스를 사용할 때 데이터베이스 테이블 구조를 올바르게 최적화하면 쿼리 및 연결 성능이 향상되어 애플리케이션 성능과 응답 속도가 향상됩니다. 이 기사에서는 MySQL 연결 문제를 해결하기 위해 데이터베이스 테이블 구조를 최적화하는 몇 가지 방법을 소개합니다. 1. 테이블 구조를 합리적으로 설계한다. 데이터베이스 테이블 구조를 설계할 때에는 응용프로그램의 필요에 따라 테이블 간의 관계를 합리적으로 설계하고 데이터의 양을 줄여야 한다.

See all articles