본문 바로가기

소프트웨어-이야기

[MySQL][Out Of Range] sql_mode Strict Type과 아닌 것의 차이 참고 - [Mysql]Out-Of-Range and Overflow Handling 어느날 이런 이슈가 있었다.MySql에 int type으로 설정한 컬럼이 있었다.그런데 테스트용 DB에서는 int에서 허용하는 값의 범위를 초과할 경우, Warn 경고를 주면서 알아서 값을 줄여줬다. (Mysql에서 Int가 허용하는 값은 -2147483648 ~ 2147483647 사이이다. 즉 Int로 타입이 선언된 컬럼에 2147483648 이상의 값을 저장하면, 2147483647의 값이 저장된다.) 그런데 같은 테이블을 백업해둔 다른 DB에서는 int에서 허용하는 값 이상을 저장하면 Out-of-Range Mysql error가 나면서, 알아서 값을 줄여주지 않았다. 두개의 DB가 데이터 오버플로우에 대한 처리 ..
[비주얼씽킹]비주얼 씽킹 기본 요소 따라그리는중...
[ROR]Asset Pipeline / 자바스크립트, CSS 압축 rails 설치 시, node.js를 설치해야하는 이유에 대해서 찾다보니 assets pipeline 키워드가 등장했다. 레일즈를 production 환경으로 서버를 띄우면, javascript 파일과 css가 압축된 형태로 배포된다. 그래서 그러려니.. 했었는데 그게 바로 assets pipeline에 속하는 기능이였다. 이번 포스팅은 rails guide Asset Pipeline를 번역하는 것을 기반으로 작성해나가던 중... rorlab에서 작성한 번역본을 발견하여 핑거프린트의 주의점까지만 작성하고, 블로그 작성을 끝내기로 결정!하였다. asset pipeline은 JavaScript와 CSS 파일들을 압축하는 기능을 갖고 있다. 그리고 assets 안에 다른 언어들과 커피스크립트, Sass, ER..
[ROR]루비온레일즈를 설치할 때, 왜 node.js를 설치해야할까? 이런 일이 있었다. 어느 분이 서버세팅을 하는데, 커피스크립트 쪽에서 에러가 났었다. 그러면서 node.js를 설치하지 않아서 발생한 이슈라는 것을 파악하고, node.js를 설치하면서 문제를 해결했었다. 왜... 루비온레일즈를 설치할 때 node.js가 필요한걸까? 궁금했다. 구글링을 해봤다. (참조 링크) 루비온레일즈 프레임워크를 쓰려면, JavaScript Runtime Environment가 필요하다. 레일즈 기능인 Asset Pipeline을 관리하는 데에 node.js가 사용되기 때문이다. Asset Pipeline이란.. 정확히 뭘까..?우선... 간단하게 보자면... 그 production 환경에서는 javascript랑 css가 압축된 형태로 import되는데, 그 기능에도 Asset P..
[RAILS]before_filter에 넘어오는 파라미터에 따라 필터 적용 여부 결정하기 만약 HelloWorld라는 컨트롤러에 before filter를 달고 싶은데, 넘어오는 파라미터에 따라 필터 적용 여부를 결정하고 싶을 때가 있다.이 경우에는 before_filter에 block을 넣고, if 분기를 추가하면된다. class HelloWorldController < ApplicationController before_filter(only: [:create]) do admin_log if (params[:admin_grade] == 'staff') end 예를 들면, admin_grade 파라미터에 넘어오는 값이 staff일 경우에만 어드민 접근 로그를 남기는 admin_log라는 함수를 사용하고 싶을 수 있다. 이 경우, 위에 처럼 before_filter block을 생성해서, if..
[git]STASH - 브랜치에서 다른 브랜치로 이동하기 전에, 커밋전에! 내가 한 코드 임시 저장하기! GIT STASH 이번 주에 요긴하게 쓰고, 너무 마음에 들었던 GIT Stash에 대해서 정리해보고자 한다. 일을 하다보면 이럴 때가 있다.지라 티켓을 보고, master 브랜치에서 해당 과제의 브랜치를 따서 마구 작업을 하고 있을 때 말이다. 그런데 아직 commit을 하기에는 부족할 때가 있다. p "로그로그로그" 처럼 콘솔 로그를 마구 찍으면서 로직을 파악하고 있다거나,database.yml의 db의 development 환경값을 기존 브랜치랑 다른 값으로 설정하고 있었다거나..개발용으로 수정해서, commit을 하면 안되는 그런 로직들이 있다. 그런데 갑자기 다른 과제의 로직을 봐야할 때가 생긴다. 그래서 내가 지금 작업하고 있는 브랜치에서 다른 브랜치로 check out을 해야할 때가 있다.이..
스포카 한산스체로 티스토리 글꼴 바꾸기 스포카 한산스체로 티스토리 글꼴 바꾸기 예전에 페북을 돌아다니다가 스포카에서 글꼴체를 공개했다는걸 발견했당글꼴도 깔끔하구 참신참신해서 뭔가 맘에 들었다.그래서 블로그를 꾸미면서... 스포카 한산스체를 써봐야겠단 생각을 했다. 방법은 스포카 한산스체 사이트를 참고했다. 스포카 한산스체 바꾸는 방법은 아래와 같다.HTML/CSS 관리 페이지에 들어간다. HTML 기존의 폰트 LINK들을 다 지워야 한다. 나같은 경우에는 구글 FONT 링크가 걸려있어서 지우고, 아래 태그를 추가해서 폰트 링크를 긁어왔다. CSS글자 태그에 폰트 CSS를 먹혀줘야한다. 나는 태그와 태그에 폰트를 먹혀줬다. p,a { font-family: 'Spoqa Han Sans', 'Spoqa Han Sans JP', 'Sans-seri..
[rubyonrails]active record의 timezone 설정하기 루비온 레일즈에서 데이터 베이스에 현재 시각이 다르게 나오는 이슈 해결하기루비온레일즈 콘솔로 DateTime.now를 하면 현재 시각이 잘 나오는데, DB에 저장할 경우 created_at의 시각이 다르게 나오는 현상이 발생했다. 이유를 찾아보다가... 액티브 레코드 설정값을 local로 바꾸어주면 된다는 것을 발견했다.application.rb에 default timezone을 로컬로 설정해주면 된다.config/application.rbconfig.active_record.default_timezone = :local 후훗!