Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Лидирующие нули в ID 
V
    Опции темы
Rodman
Дата 7.4.2008, 11:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 1
Всего: 122



Дароф.

Вопрос заключается в том что можно ли и в какой СУБД создать первичный ключ таблицы что бы он содержал лидирующие нули.. т.е.

00000000000001
00000000000002
.............
00000000000010

и т.д. 

т.е. какбы счетчик, но с определенным кол-во символов!

можно ли такое реализовать и как?

Сенкс
PM MAIL WWW Skype GTalk YIM MSN   Вверх
LSD
Дата 7.4.2008, 12:06 (ссылка) |   (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 24
Всего: 538



Лидирующие нули говоришь smile

Ведущие нули это не проблема СУБД (ее внутренний формат, тебе вообще безразличен), это проблема отображения. Или форматируй запрос используя что-то типа to_char(), или непосредсвенно в клиенте задавай формат отображения.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
Deniz
Дата 7.4.2008, 12:27 (ссылка) |  (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1251
Регистрация: 16.10.2004
Где: Новый Уренгой

Репутация: 7
Всего: 44



Rodman, т.е. получается обычное строковое поле фиксированной длинны и обозвать его первичным ключом.
Такое все СУБД могут сделать.
Вот только вопрос, кто его будет заполнять? Клиент или СУБД?


--------------------
"Для того чтобы сделать шаг вперед, достаточно пинка сзади" (с)
PM ICQ   Вверх
Akina
Дата 7.4.2008, 12:59 (ссылка) |    (голосов:3) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 13
Всего: 454



Rodman, первый встречный вопрос - зачем?


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
Magnifico
Дата 7.4.2008, 17:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 418
Регистрация: 23.1.2008
Где: Московская област ь

Репутация: 1
Всего: 17



Цитата

т.е. какбы счетчик, но с определенным кол-во символов!
можно ли такое реализовать и как?

делал такое но не для первичного ключа 
заполнять через процедуру по курсору  или через  update (только sql server поддерживает такой синтаксис)

Код

----------TSQL----------------------
declare @NextNumber nchar(6)
declare @i  int
set  @i = 1

declare IdentityCur CURSOR   SCROLL_LOCKS
    for 
          select GUIDCol
          from dbo.ExperimentalTable
          for update of GuidCol
open IdentityCur
        fetch next from IdentityCur into @NextNumber
        while  @@Fetch_Status=0
    begin
          update dbo.ExperimentalTable
          set GUIDCol = right('000000' + convert(nvarchar(5), @i), 6)   where current of IdentityCur
          set @i=@i+1
          fetch next from IdentityCur into @NextNumber
    end
close IdentityCur
deallocate IdentityCur


Код

declare @start_num nchar(6)
set @start_num = '0'
declare @tbl table (num nchar(6))
insert @tbl (num) values ('')
insert @tbl (num) values ('')
insert @tbl (num) values ('')
insert @tbl (num) values ('')
insert @tbl (num) values ('')
insert @tbl (num) values ('')
insert @tbl (num) values ('')
insert @tbl (num) values ('')
insert @tbl (num) values ('')
insert @tbl (num) values ('')
insert @tbl (num) values ('')

select * from @tbl
update @tbl
set 
@start_num = num = right('000000'+cast(@start_num + 1 as nvarchar(6)), 6)
select * from @tbl


основа это цикл и подстановка (в приципе можно и в тригере это сделать):
 
Код

set GUIDCol = right('000000' + convert(nvarchar(5), @i), 6)



--------------------
Всё  в  порядке   -   спасибо  зарядке  !
PM MAIL   Вверх
Rodman
Дата 8.4.2008, 12:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 1
Всего: 122



Цитата(Deniz @  7.4.2008,  11:27 Найти цитируемый пост)
т.е. получается обычное строковое поле фиксированной длинны и обозвать его первичным ключом.
я так и делал!
Цитата(Akina @  7.4.2008,  11:59 Найти цитируемый пост)
Rodman, первый встречный вопрос - зачем? 
ну вот заказчику захотелось чтобы ID таблицы совпадал с кодом продукта, который таким принципом и назначается!
Magnifico, ну шаман, но тока "right('000000' я не понял! получается не менее 6 нулей впереди?! а если меньше?

Это сообщение отредактировал(а) Rodman - 8.4.2008, 12:07
PM MAIL WWW Skype GTalk YIM MSN   Вверх
Akina
Дата 8.4.2008, 12:44 (ссылка) |    (голосов:2) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 13
Всего: 454



Цитата(Rodman @  8.4.2008,  13:05 Найти цитируемый пост)
заказчику захотелось чтобы ID таблицы совпадал с кодом продукта, который таким принципом и назначается!

Минутку... заказчик желает это ВИДЕТЬ на экране, или ему принципиально, чтобы оно ХРАНИЛОСЬ в таком формате??? 


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
skyboy
Дата 8.4.2008, 12:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


неОпытный
****


Профиль
Группа: Модератор
Сообщений: 9820
Регистрация: 18.5.2006
Где: Днепропетровск

Репутация: 5
Всего: 260



Rodman, товарищ, LSD дал тебе простой, но единственно возможный правильный совет: если заказчику нужно видеть идентификатор с лидирующими нулями, то абсолютно не обязательно это хранить в базе. Тем более, использовать в качестве первичного ключа! свяжи таблицу записей на 100 с таблицей с 1000 записей по строковому ключу и посмотри, как "быстро" это все обработается  smile 
храни число. выводи с добавлением нулей. и все!
PM MAIL   Вверх
Magnifico
Дата 8.4.2008, 13:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 418
Регистрация: 23.1.2008
Где: Московская област ь

Репутация: 1
Всего: 17



Цитата

но тока "right('000000' я не понял! получается не менее 6 нулей впереди?! а если меньше?


right это TSQL функция которая берет определенное колво символов справа (чтобы мы невылезали из разряда):

0000001
0001123
0234234

6 нулей конкатенируются с новым занчением переменной @i (преобразованной  к строке)
а @i  тип int  изменяет свое значение  в цикле 
Код


right('000000000' + convert(nvarchar(9), @i), 10)





--------------------
Всё  в  порядке   -   спасибо  зарядке  !
PM MAIL   Вверх
Rodman
Дата 8.4.2008, 16:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 1
Всего: 122



Цитата(Akina @  8.4.2008,  11:44 Найти цитируемый пост)
ему принципиально, чтобы оно ХРАНИЛОСЬ в таком формате??? 
к сожелению ДА!

Всем спасибо за обсуждение!
Я сделал выводы!
PM MAIL WWW Skype GTalk YIM MSN   Вверх
skyboy
Дата 8.4.2008, 18:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


неОпытный
****


Профиль
Группа: Модератор
Сообщений: 9820
Регистрация: 18.5.2006
Где: Днепропетровск

Репутация: 5
Всего: 260



Rodman, он в детстве головой не бился?
сделай, как нужно сделать, а для него сделай view'шку, где поле раздора будет текстовым
PM MAIL   Вверх
LSD
Дата 8.4.2008, 18:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 24
Всего: 538



Цитата(Rodman @ 8.4.2008,  17:12)
Цитата(Akina @  8.4.2008,  11:44 Найти цитируемый пост)
ему принципиально, чтобы оно ХРАНИЛОСЬ в таком формате??? 
к сожелению ДА!

Он собирается лично лазить в базу и выполнять SQL запросы?


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
Deniz
Дата 9.4.2008, 09:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1251
Регистрация: 16.10.2004
Где: Новый Уренгой

Репутация: 7
Всего: 44



Цитата(Rodman @ 8.4.2008,  19:12)
Цитата(Akina @  8.4.2008,  11:44 Найти цитируемый пост)
ему принципиально, чтобы оно ХРАНИЛОСЬ в таком формате??? 
к сожелению ДА!

Всем спасибо за обсуждение!
Я сделал выводы!

И все-таки сделай первичный ключ и еще одно поле для показа этих нулей, причем можно дать возможность заносить разное кол-во, т.е.
00001
0002
03
000000004
и т.д.
И пусть сам мучается


--------------------
"Для того чтобы сделать шаг вперед, достаточно пинка сзади" (с)
PM ICQ   Вверх
Rodman
Дата 9.4.2008, 09:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 1
Всего: 122



Цитата(LSD @  8.4.2008,  17:13 Найти цитируемый пост)
Он собирается лично лазить в базу и выполнять SQL запросы?
он код сморит!
PM MAIL WWW Skype GTalk YIM MSN   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1099 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.