'2016/03/13'에 해당되는 글 3건

  1. 2016.03.13 MySql DB 작성해보기 (1)
  2. 2016.03.13 php 기초 실습
  3. 2016.03.13 php 입문 사전 지식

Mysql 설치부터 말썽이더니.. 이번에는 접속이 제대로 안됬다. Workbench를 이용하려는데 접속이 안되서 무엇인고 하니.. MySql 자체를 실행을 안해서 그랬다;;;; 



ㄴ 요 창 보기 싫으면 반드시 관리자 권한으로 가동한 후 net start mysql로 키고 net stop mysql로 끄거나 할 수 있다.



다 필요없고, Mysql Notifier라는 프로그램으로 원버튼 클릭에 껐다 켰다 할 수 있으니 그것도 좋다.





테스트용으로 db를 작성해보려는데.. localhost가 아닌 127.0.0.1를 입력하는 참사를 일으켰다. 그러지 말고 정상적으로 localhost를 입력했더니 정상적으로 된다.


schema를 작성하려고 하니.. 

name과

collation 이라는 것이 나온다.




collation은 사전을 보니 ① 대조 ② 간단한 식사 ③ 조사 라는 의미로 나온다.


찾아보았다.


출처 : http://blog.daum.net/warmfeel/106


  1. 문자셋(Character Set)
    • 말 그대로 특정 '문자(좀 더 정확히는 symbol)'가 컴퓨터에 저장될 때 어떠한 '코드'로 인코딩되어 저장될 것인지에 대한 규칙이 정의되어있는 집합을 말함. (character set is a set of symbols and encodings.
    • 대표적인 것으로는 ASCII, 한글을 지원하는 EUC-KR, 유니코드 UTF-8, UTF-16 등이 있음.
    • 문자셋은 자신이 처리할 문자 집합이 얼마나 큰가에 따라 하나의 '문자'를 저장하는데 필요한 저장공간의 크기가 달라지게 된다. 또한 항상 모든 문자들을 동일한 크기로 인코딩하는 고정폭 방식의 문자셋이 있는가하면, EUC-KR(1~2바이트)이나 UTF-8(1~3바이트)과 같이 가변폭 방식의 인코딩을 사용하는 문자셋도 있다.
  2. 콜레이션(Collation)
    • 이것은 특정 문자셋에 의해 데이터베이스에 저장된 값들을 검색하거나 정렬 등의 작업을 위해 문자들간에 서로 '비교'할때 사용하는 규칙들의 집합이다. (collation is a set of rules for comparing characters in a character set.) 따라서, 일반적인 Data Type에는 적용되지 않고, CHAR, VARCHAR, TEXT와 같은 데이터 타입을 가지는 칼럼들에 대해서만 적용된다.
    • 주로 대소문자를 구별하는 binary 형식을 사용할 것인지, 대소문자를 구별하지 않는 Case Insensitive 형식을 사용할 것인지로 나누어진다. Case Insensitive 형식을 사용하는 collation들은 모두 collation 이름의 끝에 'ci'라는 문자가 붙어있다.

 

'특정 문자 셋'에 의해 DB에 저장된 값들을 검색 , 정렬등을 위해 문자들을 '비교'할 때 사용되는 규칙의 집합...


특별히, MySQL에서의 문자셋과 collation 에 대한 문제는 단순히 데이터를 저장하는 공간에 대한 관점만이 아니라, MySQL 서버와 MySQL 서버에게 요청을 하는 클라이언트 사이에 주고받는 상호작용에 대한 관점까지도 포함한다는 것을 꼭 기억할 필요가 있다. 

  • 데이터를 저장하는 관점 : MySQL은 Server 레벨, Database 레벨, Table 레벨, Column 레벨까지 총 4개의 레벨을 지원하는 특징을 가지고 있음.

서로 지원하는 문자 규칙이 안맞는 경우 아예 변환 자체도 불가능한데 (가까운 예로 ANSI와 UTF-8) 클라이언트 (주로 웹)와의 상호 작용에 대한 관점 까지 포함하는 듯 하다.


서버와 클라이언트간의 상호작용 관점 : MySQL은 이 관점에서 문자셋과 관련한 총 3개의 서로 다른 타입을 제공한다.

  • character_set_client : 클라이언트에서 문장이 떠날 때 해당 문장은 어떤 문자셋으로 이루어져있는가의 문제
  • character_set_connection : 클라이언트에서 넘어온 문장을 서버에서는 어떤 문자셋을 기준으로 해석해야하는가의 문제.
  • character_set_results : 서버에서 클라이언트로 응답을 넘겨줄때 어떤 문자셋으로 넘겨야하는가의 문제.
    • 따라서, 데이터베이스 레벨에서 euckr 문자셋이 기본값으로 지정되어있는 데이터베이스를 생성한 후 해당 데이터베이스에 데이터를 잘 입력하였는데 이상하게 브라우저로 넘기면 데이터베이스에서 읽어온 문자만 글자가 깨지는 상황이 벌어진다면(브라우저의 인코딩 설정 등은 정상적이라고 가정) 다음과 같이 체크해봐야 한다.
      • Database 레벨, Table 레벨, Column 레벨에서 원하는 문자셋으로 잘 지정되어있는지를 확인
      • client, connection, results 에서의 문자셋도 적절하게 지정되어있는지를 확인. (대개 글자가 깨지는 경우라면, 아마도 이쪽이 잘못 지정되어있을 가능성이 높다)
    • SQL 문장 중에 'SET NAMES euckr [COLLATE collation_name]'을 사용하면 앞에서 살펴본 client, connection, results 3가지에 대한 문자셋을 한꺼번에 지정해줄 수 있음. (서버 실행중에도 변경이 가능. 단, 서버 실행중에 SQL 문장으로 변경하는 것은 영구 변경이 아니라 현재 연결에 한해서만 임시로 변경하는 것임)
    • 임시 변경이 아닌 영구 변경을 하려면, MySQL 서버가 처음 시작할 때 참고하는 my.cnf 환경설정 파일내에 'init_connect=SET NAMES euckr' 이런식으로 지정해두면 됨.
    • 이렇게 영구 변경과 임시 변경 방법을 활용하면 좀 더 다양한 응용이 가능해진다.
      • 서버가 시작하는 단계에서 지정하는 경우 : 대개 환경설정 파일인 my.cnf 파일에서 'init_connect=SET NAMES euckr' 명령어로 지정. 이렇게 했을때는 해당 서버를 사용하는 모든 애플리케이션들에게 이 설정이 기본값으로서의 영향을 미친다.
      • 시작 단계가 아니라 서버가 실행중에 데이터베이스 별로 다른 문자셋을 사용하도록 지정하는 경우 : 일단 클라이언트가 서버로 연결을 한 이후에 곧바로 'SET NAMES euckr' 명령어를 실행시켜서 현재 연결에 대한 연결 관련 문자셋들을 수정해놓고 시작한다. 이렇게 하면, 각각의 데이터베이스별로 서로 다른 연결 관련 문자셋을 지정할 수 있게 됨(!!!)
      • 즉, 동일한 서버내에서 대부분의 애플리케이션은 utf-8 문자셋을 사용하는데 특정 애플리케이션만 euckr 문자셋을 사용하고자 할 경우에 위와 같은 방법을 사용하면 가능.
      • 참고로, PHP에서 사용하는 mysqli 확장에서는 'SET NAMES ...'를 query 메소드로 실행시키는 방법 이외에 'set_charset' 이라는 더 나은 메소드를 통해서 동일한 효과를 얻을 수도 있음.
  1. (질문) PHPMyAdmin에서 새로운 데이터베이스를 생성할 때, 해당 데이터베이스에서 사용할 Default collation 만을 지정하게 되는데... 그렇다면, 해당 데이터베이스이 Default Character Set은 어떻게 되는 것일까?
    • (대답) 뭐... 당연한 이야기겠지만, Default collation 만을 지정하게 되면 해당 collation이 속해있는 Character Set이 자동으로 그 데이터베이스의 Default Character Set으로 지정됨. 물론, PHPMyAdmin의 GUI 방식을 사용하지 않고, 직접 DDL 문장을 사용하면 하나 하나 별도로 지정해줄 수도 있음. 또한, PHPMyAdmin에서 데이터베이스를 생성할 때, Default collation 조차도 지정하지 않게 되면, 당연히 MySQL의 환경설정 파일인 my.cnf(또는 my.ini)에서 지정되어있는 시스템의 기본적인 Character Set이 적용되게 되며 Collation은 해당 Character Set의 Default collation이 적용되게 됨.


결론적으로 내가 이 db의 데이터를 어떤 문자셋으로 관리할 것인지, 또 그것과 상호작용할 대상은 누구인지를 생각하고 써야하는 것 같다. 이번에 해보려고 한 것은 웹에서 구동되게 만들어보려 했으니, UTF-8을 선택하게 되었다.



예약하는 것을 만들어보려고 했는데, 해당 날짜에 존재하는 몇 곳 테이블(자리)에 대한 작성이었기 때문에 같은 날짜의 행이 있을 수 없고, 그것을 기반으로 테이블이 딸려오기 때문에 날짜(date)를 PK 값으로 잡고, 나머지는 예약이 있을 수도 없을 수도 있기에 NOT NULL을 설정하지 않을까 하였으나.. 무결성이 날아가는 것 같아 ""라도 쓰도록 NOT NULL을 강제했다.




상당히 단촐한 테이블 구성이 완료되었는데, 이곳에 쓰일 SP를 작성하면 DB에서의 작업은 거의 끝난 것 같다.








'프로그래밍 > MySQL' 카테고리의 다른 글

이벤트 스케줄러(Event Scheduler)  (1) 2016.06.21
MySql DB 작성해보기  (1) 2016.03.13
MySQL 저장 프로시져 내에서 발생한 에러 처리 (Error Handling)  (0) 2016.02.23
MySql 설치하기  (0) 2016.02.21
Auto Increment란  (0) 2016.02.05
MySql 주석을 달자  (0) 2016.02.01
Posted by GENESIS8

댓글을 달아 주세요

  1. 1466100957 2016.06.17 03:15  댓글주소  수정/삭제  댓글쓰기

    잘 읽고 가여~





내가 원한 것과 달리 한글이 특수문자로 번역되어 나온다.



다음의 설정을 해주자. 인코딩 방식을 변경해주지 않으면 웹 환경에서 한글을 원활히 쓸 수가 없다. (아마도 iis와 파일 사이의 문제인듯 ..)


->

.NET 에서는 문자열 처리를 명시적으로 지정하지 않는 한, 기본적으로 "System.Text.UTF8Encoding" 으로 처리를 합니다. 문제는 거기서 발생을 하지요.

해당 HTML 텍스트 한글 파일은 메모장에서 "ASCII" 형식으로 저장된 것이었고, 디코딩을 UTF-8 로 해버리니 당연히 깨질 수 밖에 없습니다.


라는 답변을 찾을 수 있었다. ANSI를 말하는 것인 듯하다. ASCII 표준에 각국에 맞는 상태로 변경을 한다고 하니..




작은 따옴표에서는 특수문자(\n 등)와 변수가 작동을 안한다는 강좌의 내용을 확인한다.

웹 페이지 상에서는 \n가 안 먹히길래 보니까.. <BR>로 개행할 수 있다.





배열은 다른 언어와 다를 게 없다... 고 하는 데 출력이 좀 웃긴다.




1차원 배열은 변수와 마찬가지로 " " 내부에 작성하게 될 경우 정상적으로 값이 보이는 반면,

2차원 배열은 저처럼 ehco $arr[0][0] 과 같이 해주지 않으면 arr 0 과 같이 값이 보인다..

마치 값이 아니라 포인터를 출력하고 있는 듯한 느낌인데.. 이거야 원..


아무튼 다음은 클래스다. 

php도 c와 마찬가지로 클래스를 구성할 수 있다.

심지어 기호도 ->다.




클래스 내에서 변수를 사용한다면 꼭 $this->a 와 같이 해주어야한다. 그 사실을 모르고 찾으니 암에 걸릴 뻔.. 친절한 분들 감사하다. 연산자는 애로우연산자는 물론 스코프 연산자(::)도  c와 같은 방식으로 사용한다.


다음은 폼이다.




폼을 이용할 때 register_globals 옵션을 안 키면 겪는 여러 문제 때문에 헤맸는데, 보안적인 문제 ex) 비밀번호가 맞으면 이동을 위해 지역 플래그를 변경하는 코드일 때, 그것을 전역에서 간섭할 수 있는 문제.. 같은 문제가 있으므로 키지 않고 쓰는 코딩 습관이 옳다고 한다.




'프로그래밍 > 웹 프로그래밍' 카테고리의 다른 글

php 기초 실습  (0) 2016.03.13
php 입문 사전 지식  (0) 2016.03.13
html 중급?  (0) 2016.02.21
HTML 기초  (0) 2016.02.21
비즈니스 로직(Business logic)?  (0) 2016.02.14
웹서버(Web Server) / 웹 서버 어플리케이션(WSA)  (0) 2016.02.14
Posted by GENESIS8

댓글을 달아 주세요




CGI는 위와 같은 구조를 가지는데.. ( HTML은 1과 4의 과정만 있음 )
보시는 바와 같이 HTML 보다 한단계 더 처리를 함으로써 계산과 처리 기능이 추가되었습니다. 이로인해 우리는 정적인 변화 없는 웹 페이지에서 변화가 자유롭고 방문자와 홈페이지 제작자간에 서로 상호작용이 가능한 웹 페이지를 만들 수 있게 된 것입니다.
그러나 여기서 주의해야 할 점은 3번에서 보듯이 CGI로 처리된 값은 HTML로 전송되어 집니다.
웹 브라우저는 HTML밖에 모르니 HTML로 바꿔서 보여줘야 하는 것입니다.
( PHP를 하려면 당연히 HTML을 알고 있어야겠죠? )

그러면 CGI와 PHP는 어떤 관계인가?

PHP는 약간 다르긴 하지만 일종의 CGI라고 볼 수 있습니다.


CGI는 일반적으로 웹서버로 요청이 들어오면 CGI 프로그램을 실행하여 하나의 프로세스를 생성하고 그 처리 결과를 웹서버로 전송한 후 프로세스가 종료되는 형식입니다.
100개의 요청이 들어오면 CGI 프로세스가 100개가 생성이 됩니다.

PHP는 CGI와 달리 아파치 웹서버에 모듈로 장착되어 있습니다.
따라서 매회 실행시마다 프로세스가 생성되는 CGI와 달리 하나의 프로세스에 여러개의 쓰레드를 생성하여 처리가 가능합니다. 

그래서 프로세스방식인 CGI 보다 쓰레드방식인 PHP가 성능이 우수합니다.



PHP는 무엇인가?

PHP (공식적 PHP Hypertext Preprocessor) 는 Server - side HTML-embedded 스크립트 언어입니다.
즉, PHP는 서버에서 실행되며 HTML을 포함한 스크립트 언어라는 말입니다.
HTML을 포함하고 있기 때문에 HTML 파일을 PHP 확장자 (.php )로 저장하여도 아무 지장없이 사용할 수 있습니다.

시작(<?php)과 끝 태그(?>)를 이용하여 HTML과 PHP를 구분합니다.



php도 세미콜론으로 한 문장을 파악하므로 줄의 끝에는 세미콜론이 필요.


주석은 // , # , /* */



Type (변수형)

진리값 , 정수 , 실수 , 문자열 , 배열 , 객체 , 리소스 , 널 총 8가지의 변수형


특수문자

의미

\n

 개행문자 ( 줄 바꿈 )

\r

 캐리지 리턴

\\

 역 슬래쉬

\t

 수평 탭

\"

 따옴표

\$

 달러 표시


<php?

?>

안의 내용이 php 내용이 된다.



2) 따옴표 내의 변수사용

큰 따옴표내에서는 변수의 사용이 가능합니다.
예를 들어 $name 이라는 변수에 "조명진" 이라는 문자열이 저장되어 있다면,
$str = "나의 이름은 $name입니다.";
라고 하였을 때 $str = "나의 이름은 조명진입니다."; 와 같은 효과를 가지게 됩니다.

2. 작은 따옴표

'나는 문자열이다.' 와 같이 작은 따옴표 안에 문자열을 넣으면 됩니다.
작은 따옴표를 이용한 방법은 큰 따옴표를 이용할 때와 차이가 있는데,
작은 따옴표 내부에 쓰여진 특수문자와 변수가 허용되지 않는 다는 것입니다.
echo '작은 따옴표 안에서는\n 특수문자와 변수가 $name 동작을 안해요.';
의 결과는 작은 따옴표 안에서는\n 특수문자와 변수가 $name 동작을 안해요. 처럼 그대로 표현됩니다.

3. 히어닥 문법

$str = <<<EOD
문자열이라네~
나도 문자열이라네~

EOD;


PHP에서는 0부터 시작하는 숫자형 인덱스와 foo 같이 문자로 구분하는 인덱스 두가지가 있습니다


<?
class Human {  //인간 클래스를 정의 합니다.

        var $Name;
        var $Age;
        var $Height;
        var $Weight;  

        function Eat ( ) { 먹는 행위를 함수로 정의 }
        function Walk ( ) { 걷는 행위를 함수로 정의 }
        function Work ( ) { 일하는 행위를 함수로 정의 }
        function Talk ( $words ) { 말하는 행위를 함수로 정의 }
}    

    $철수 = new Human; //인간 클래스를 이용해 철수 객체를 생성
    $철수->Eat(); // 철수야!! 밥먹어라~!
    $철수->Talk($철수->Age); // 철수야~ 몇살이야? 말해봐!!
?>

php에서는 클래스를 이렇게 정의한다.


상속도 있다.


<?

class Baby Extends Human { //인간 클래스를 상속받아 아기 클래스를 정의 합니다. }

?>


static은 지역 변수 허용,

전역 변수는 전역 위치에 선언하되 지역변수와 혼선시 global $a와 같이 식별가능

define("상수명","상수에 저장될 값");



미리 정의된 변수

변수에는 우리가 만들어 사용할 수 있는 변수와 미리 정의되어진 변수가 있습니다.
우선 미리 정의된 변수는 서버 종류, 버전 등이나 기타 환경에 따라 변하는 변수들입니다.
아파치와 PHP 각각 몇 개의 변수를 지정해 놓은 상태이며 이 변수들은 우리가 인위적으로 값을
수정하거나 일반 변수로 사용할 수 없습니다.

수퍼 전역변수

$_GET

 HTTP GET 방식으로 넘어온 변수

$_POST

 HTTP POST 방식으로 넘어온 변수

$_COOKIE

 HTTP 쿠키 변수

$_FILES

 업로드시 파일 정보 변수

$_SESSION

 세션 변수

$_SERVER

 웹서버와 PHP 환경에서의 환경 설정 변수

외부로 부터의 변수

내부에 선언없이 외부로부터 넘어오는 변수입니다.
예제를 보시면 이해가 가실 겁니다.


출처 : http://www.ezphp.net/lecture/lecture5.php

였었는데..


보던 곳이 <?php 와 <?에 의한 문제 발생이라던가, 코드가 제대로 실행되지 않는 등.. 상태가 좋지 않아 다른 곳으로.


출처 : http://www.apmsetup.com/php.php



논리 연산자




$a and $b
:  $a 와 $b 가 모두 참(true) 이면 참(true)

$a or $b
:  $a 와 $b 중 하나라도 참(true) 이면 참(true)

$a xor $b
:  $a 와 $b 중 하나만 참(true) 이면 참(true)

!$a
:  $a 가 참(true) 이면 거짓(false), 거짓(false) 이면 참(true)

$a && $b
:  $a 와 $b 가 모두 참(true) 이면 참(true)

$a || $b
:  $a 와 $b 중 하나라도 참(true) 이면 참(true)


$_POST[변수명]

$_POST[$변수명] -> PHP 설정 파일 (ini)의 register_globals = on 인 상태에서만 가능하다. 

register_globals를 켜면 변수등을 사용할 때 앞에 _SERER 등을 안 붙이거나 하는 등 전역변수를 편히 쓸 수 있지만.. 안전성이 떨어진다고 한다/



산술 , 대입 연산은 동일하니 생략.


비교 연산은 다음과 같이 한다.

if($a == "hi" && $b == "bye")


switch case도 동일하다. $변수 로 넣어야한다는 것 뿐..

그 외의 경우를 의미하는 default도 그대로다


include 제어문

<header.inc>

<?
$string = "Hello World";
?>


<output.php>

<?
include "./header.inc";

echo("$string");
?>



class는 C와 같으며, 상속은 자바와 같이 extends 를 사용한다.

상위 클래스 접근 시 parent 키워드를 사용할면 된다.


심지어 접근 연산자 (access modifier)도 있다;







'프로그래밍 > 웹 프로그래밍' 카테고리의 다른 글

php 기초 실습  (0) 2016.03.13
php 입문 사전 지식  (0) 2016.03.13
html 중급?  (0) 2016.02.21
HTML 기초  (0) 2016.02.21
비즈니스 로직(Business logic)?  (0) 2016.02.14
웹서버(Web Server) / 웹 서버 어플리케이션(WSA)  (0) 2016.02.14
Posted by GENESIS8

댓글을 달아 주세요